Fri, 20 Aug 2004 03:40:33 +0000
[gaim-migrate @ 10655]
after an utter failure to get comments on this since it was updated, and
thinking that the functionality is worth having, i present to you:
" This is a patch to blist.c and blist.h to modify the
GaimBuddy structure to add a field for flags. It also
adds a single flag GAIM_BUDDY_NO_SAVE, which can be
used to indicate that a particular buddy should not be
saved to file. This will be particularly useful for
prpls with dynamic group support (which I am working on
adding to Meanwhile), such as Oscar's recent buddies group.
I used a negative flag (NO_SAVE rather than SAVE)
because the default should be for saving to happen, and
I didn't want to have to initiate the buddy with a save
flag set. To counteract this, there is a macro called
GAIM_BUDDY_SHOULD_SAVE which checks for the absense of
the flag. Woo-hoo double negative!!
The beefy part of this patch also factors out the
deeply nested loops of the saving code into separate
functions.
This code also fixes a minor possible bug wherein when
saving only a particular account, a group could be
written containing empty contacts (due to checking for
the specific account only at the group and buddy levels)
Here's a version that places the flags field in the
BlistNode, and checks for it at each stage (group, chat,
contact, buddy). It didn't erase my buddy list when I tried
it, so that's nice at least." --Christopher (siege) O'Brien
committer: Luke Schierer <lschiere@pidgin.im>
| 7432 | 1 | /** |
| 2 | * @file gtklog.h GTK+ Log viewer | |
| 3 | * @ingroup gtkui | |
| 4 | * | |
| 5 | * gaim | |
| 6 | * | |
| 8046 | 7 | * Gaim is the legal property of its developers, whose names are too numerous |
| 8 | * to list here. Please refer to the COPYRIGHT file distributed with this | |
| 9 | * source distribution. | |
| 7432 | 10 | * |
| 11 | * This program is free software; you can redistribute it and/or modify | |
| 12 | * it under the terms of the GNU General Public License as published by | |
| 13 | * the Free Software Foundation; either version 2 of the License, or | |
| 14 | * (at your option) any later version. | |
| 15 | * | |
| 16 | * This program is distributed in the hope that it will be useful, | |
| 17 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 18 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 19 | * GNU General Public License for more details. | |
| 20 | * | |
| 21 | * You should have received a copy of the GNU General Public License | |
| 22 | * along with this program; if not, write to the Free Software | |
| 23 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
| 24 | */ | |
| 25 | ||
| 26 | #include "gtkinternal.h" | |
| 27 | #include "log.h" | |
| 28 | ||
| 29 | #include "account.h" | |
| 30 | ||
| 31 | typedef struct _GaimGtkLogViewer GaimGtkLogViewer; | |
| 32 | ||
| 33 | /** | |
| 34 | * A GTK+ Log Viewer. You can look at logs with it. | |
| 35 | */ | |
| 36 | struct _GaimGtkLogViewer { | |
| 37 | GList *logs; /**< The list of logs viewed in this viewer */ | |
| 38 | ||
| 39 | GtkWidget *window; /**< The viewer's window */ | |
| 40 | GtkTreeStore *treestore; /**< The treestore containing said logs */ | |
| 41 | GtkWidget *treeview; /**< The treeview representing said treestore */ | |
| 42 | GtkWidget *imhtml; /**< The imhtml to display said logs, which were said | |
| 43 | * before said treestore was said */ | |
| 44 | GtkWidget *entry; /**< The search entry, in which search terms are | |
| 45 | * entered */ | |
| 46 | GaimLogReadFlags flags; /**< The most recently used log flags */ | |
| 7535 | 47 | char *search; /**< The string currently being searched for */ |
| 7432 | 48 | }; |
| 49 | ||
| 50 | ||
| 51 | ||
| 52 | void gaim_gtk_log_show(const char *screenname, GaimAccount *account); | |
|
8574
bb17814fbeb7
[gaim-migrate @ 9322]
Mark Doliner <markdoliner@pidgin.im>
parents:
8046
diff
changeset
|
53 | |
|
bb17814fbeb7
[gaim-migrate @ 9322]
Mark Doliner <markdoliner@pidgin.im>
parents:
8046
diff
changeset
|
54 | void gaim_gtk_syslog_show(); |