Wed, 21 Dec 2005 18:43:39 +0000
[gaim-migrate @ 14935]
Jason LeBrun wrote to gaim-devel:
"I have found a small quirk in the way gdk_pixbuf_loader works. When you
are using it without signalling, the proper way to use it is to call
gdk_pixbuf_loader_close *before* calling gdk_pixbuf_loader_get_animation
or gdk_pixbuf_loader_get_pixbuf. The call to gdk_pixbuf_loader_close
signals that no more writes will be occuring.
In particular, this affects images that are less than 1k in size. If
gdk_pixbuf_loader_close is not called before _get_animation, the loader
will not return anything unless it has received more than 1k of data
(the file type sniffing buffer size) or it has been closed.
So, the proper order of calls for loaders in the gtk*.c code is:
gdk_pixbuf_loader_new();
gdk_pixbuf_loader_write();
gdk_pixbuf_loader_close();
gdk_pixbuf_loader_get_animation();"
I know we fixed a bug by changing this in one place. I've gone through and updated the rest.
| 7432 | 1 | /** |
| 2 | * @file gtklog.c 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. | |
|
7537
4c3be2f554b1
[gaim-migrate @ 8150]
Christian Hammond <chipx86@chipx86.com>
parents:
7535
diff
changeset
|
10 | * |
| 7432 | 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 | */ | |
| 9791 | 25 | #include "internal.h" |
| 26 | #include "gtkgaim.h" | |
| 7432 | 27 | |
| 28 | #include "account.h" | |
| 29 | #include "gtkblist.h" | |
| 30 | #include "gtkimhtml.h" | |
| 31 | #include "gtklog.h" | |
| 32 | #include "gtkutils.h" | |
| 33 | #include "log.h" | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
34 | #include "notify.h" |
| 10636 | 35 | #include "util.h" |
| 7432 | 36 | |
| 37 | static GHashTable *log_viewers = NULL; | |
| 7535 | 38 | static void populate_log_tree(GaimGtkLogViewer *lv); |
| 8573 | 39 | static GaimGtkLogViewer *syslog_viewer = NULL; |
| 7432 | 40 | |
| 41 | struct log_viewer_hash_t { | |
| 10663 | 42 | GaimLogType type; |
| 7432 | 43 | char *screenname; |
| 44 | GaimAccount *account; | |
| 10663 | 45 | GaimContact *contact; |
| 7432 | 46 | }; |
| 47 | ||
| 7440 | 48 | static guint log_viewer_hash(gconstpointer data) |
| 7432 | 49 | { |
| 7440 | 50 | const struct log_viewer_hash_t *viewer = data; |
| 51 | ||
| 10663 | 52 | if (viewer->contact != NULL) |
| 53 | return g_direct_hash(viewer->contact); | |
| 54 | ||
| 55 | return g_str_hash(viewer->screenname) + | |
| 56 | g_str_hash(gaim_account_get_username(viewer->account)); | |
| 7432 | 57 | } |
| 58 | ||
| 10663 | 59 | static gboolean log_viewer_equal(gconstpointer y, gconstpointer z) |
| 7432 | 60 | { |
| 7440 | 61 | const struct log_viewer_hash_t *a, *b; |
| 7432 | 62 | int ret; |
| 7440 | 63 | char *normal; |
| 64 | ||
| 65 | a = y; | |
| 66 | b = z; | |
| 67 | ||
| 10663 | 68 | if (a->contact != NULL) { |
| 69 | if (b->contact != NULL) | |
| 70 | return (a->contact == b->contact); | |
| 71 | else | |
| 72 | return FALSE; | |
| 73 | } else { | |
| 74 | if (b->contact != NULL) | |
| 75 | return FALSE; | |
| 76 | } | |
| 77 | ||
| 7440 | 78 | normal = g_strdup(gaim_normalize(a->account, a->screenname)); |
| 79 | ret = (a->account == b->account) && | |
| 80 | !strcmp(normal, gaim_normalize(b->account, b->screenname)); | |
| 7432 | 81 | g_free(normal); |
| 10663 | 82 | |
| 7432 | 83 | return ret; |
| 84 | } | |
| 85 | ||
| 7535 | 86 | static void search_cb(GtkWidget *button, GaimGtkLogViewer *lv) |
| 87 | { | |
| 88 | const char *search_term = gtk_entry_get_text(GTK_ENTRY(lv->entry)); | |
| 89 | GList *logs; | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
90 | GdkCursor *cursor; |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
91 | |
| 10663 | 92 | if (lv->search != NULL) |
| 7535 | 93 | g_free(lv->search); |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
94 | |
| 11585 | 95 | gtk_tree_store_clear(lv->treestore); |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
96 | if (!(*search_term)) { |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
97 | /* reset the tree */ |
| 7535 | 98 | populate_log_tree(lv); |
| 99 | lv->search = NULL; | |
|
7537
4c3be2f554b1
[gaim-migrate @ 8150]
Christian Hammond <chipx86@chipx86.com>
parents:
7535
diff
changeset
|
100 | gtk_imhtml_search_clear(GTK_IMHTML(lv->imhtml)); |
| 7535 | 101 | return; |
| 102 | } | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
103 | |
| 7535 | 104 | lv->search = g_strdup(search_term); |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
105 | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
106 | cursor = gdk_cursor_new(GDK_WATCH); |
| 7535 | 107 | gdk_window_set_cursor(lv->window->window, cursor); |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
108 | gdk_cursor_unref(cursor); |
| 7535 | 109 | while (gtk_events_pending()) |
| 110 | gtk_main_iteration(); | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
111 | |
| 7535 | 112 | for (logs = lv->logs; logs != NULL; logs = logs->next) { |
| 113 | char *read = gaim_log_read((GaimLog*)logs->data, NULL); | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
114 | if (read && *read && gaim_strcasestr(read, search_term)) { |
| 7535 | 115 | GtkTreeIter iter; |
| 116 | GaimLog *log = logs->data; | |
| 117 | char title[64]; | |
| 7676 | 118 | char *title_utf8; /* temporary variable for utf8 conversion */ |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
119 | |
| 10636 | 120 | gaim_strftime(title, sizeof(title), "%c", localtime(&log->time)); |
| 7676 | 121 | title_utf8 = gaim_utf8_try_convert(title); |
| 122 | strncpy(title, title_utf8, sizeof(title)); | |
| 123 | g_free(title_utf8); | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
124 | |
| 7535 | 125 | gtk_tree_store_append (lv->treestore, &iter, NULL); |
| 126 | gtk_tree_store_set(lv->treestore, &iter, | |
| 127 | 0, title, | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
128 | 1, log, -1); |
| 7535 | 129 | } |
|
10574
5abb2931b6ff
[gaim-migrate @ 11966]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
10181
diff
changeset
|
130 | g_free(read); |
| 7535 | 131 | } |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
132 | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
133 | gdk_window_set_cursor(lv->window->window, NULL); |
| 7535 | 134 | } |
| 135 | ||
|
7454
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
136 | static gboolean destroy_cb(GtkWidget *w, gint resp, struct log_viewer_hash_t *ht) { |
| 8573 | 137 | GaimGtkLogViewer *lv = syslog_viewer; |
|
7454
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
138 | |
| 10663 | 139 | if (ht != NULL) { |
| 8573 | 140 | lv = g_hash_table_lookup(log_viewers, ht); |
| 141 | g_hash_table_remove(log_viewers, ht); | |
| 10663 | 142 | |
| 143 | if (ht->screenname != NULL) | |
| 144 | g_free(ht->screenname); | |
| 145 | ||
| 8573 | 146 | g_free(ht); |
| 147 | } else | |
| 148 | syslog_viewer = NULL; | |
| 149 | ||
| 10663 | 150 | while (lv->logs != NULL) { |
| 7535 | 151 | GList *logs2; |
| 10663 | 152 | |
| 153 | gaim_log_free((GaimLog *)lv->logs->data); | |
| 154 | ||
| 7535 | 155 | logs2 = lv->logs->next; |
| 156 | g_list_free_1(lv->logs); | |
| 157 | lv->logs = logs2; | |
| 7533 | 158 | } |
| 10663 | 159 | |
| 160 | if (lv->search != NULL) | |
| 7535 | 161 | g_free(lv->search); |
| 10663 | 162 | |
| 8573 | 163 | g_free(lv); |
|
7454
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
164 | gtk_widget_destroy(w); |
|
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
165 | |
|
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
166 | return TRUE; |
|
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
167 | } |
|
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
168 | |
| 10663 | 169 | static void log_row_activated_cb(GtkTreeView *tv, GtkTreePath *path, GtkTreeViewColumn *col, GaimGtkLogViewer *viewer) { |
| 170 | if (gtk_tree_view_row_expanded(tv, path)) | |
| 171 | gtk_tree_view_collapse_row(tv, path); | |
| 172 | else | |
| 173 | gtk_tree_view_expand_row(tv, path, FALSE); | |
| 8573 | 174 | } |
| 10663 | 175 | |
|
7454
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
176 | static void log_select_cb(GtkTreeSelection *sel, GaimGtkLogViewer *viewer) { |
| 7432 | 177 | GtkTreeIter iter; |
|
12600
7ecd4441fdc7
[gaim-migrate @ 14934]
Richard Laager <rlaager@pidgin.im>
parents:
12232
diff
changeset
|
178 | GValue val; |
| 7432 | 179 | GtkTreeModel *model = GTK_TREE_MODEL(viewer->treestore); |
| 180 | GaimLog *log = NULL; | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
181 | GdkCursor *cursor; |
| 7432 | 182 | GaimLogReadFlags flags; |
| 183 | char *read = NULL; | |
| 184 | char time[64]; | |
| 185 | ||
| 10663 | 186 | if (!gtk_tree_selection_get_selected(sel, &model, &iter)) |
| 7432 | 187 | return; |
|
12600
7ecd4441fdc7
[gaim-migrate @ 14934]
Richard Laager <rlaager@pidgin.im>
parents:
12232
diff
changeset
|
188 | |
|
7ecd4441fdc7
[gaim-migrate @ 14934]
Richard Laager <rlaager@pidgin.im>
parents:
12232
diff
changeset
|
189 | val.g_type = 0; |
| 7432 | 190 | gtk_tree_model_get_value (model, &iter, 1, &val); |
| 191 | log = g_value_get_pointer(&val); | |
| 192 | g_value_unset(&val); | |
| 193 | ||
| 10663 | 194 | if (log == NULL) |
| 7432 | 195 | return; |
| 196 | ||
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
197 | /* When we set the initial log, this gets called and the window is still NULL. */ |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
198 | if (viewer->window->window != NULL) |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
199 | { |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
200 | cursor = gdk_cursor_new(GDK_WATCH); |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
201 | gdk_window_set_cursor(viewer->window->window, cursor); |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
202 | gdk_cursor_unref(cursor); |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
203 | while (gtk_events_pending()) |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
204 | gtk_main_iteration(); |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
205 | } |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
206 | |
| 10663 | 207 | if (log->type != GAIM_LOG_SYSTEM) { |
| 208 | char *title; | |
| 209 | char *title_utf8; /* temporary variable for utf8 conversion */ | |
| 210 | ||
| 211 | gaim_strftime(time, sizeof(time), "%c", localtime(&log->time)); | |
| 212 | ||
| 213 | if (log->type == GAIM_LOG_CHAT) | |
| 214 | title = g_strdup_printf(_("Conversation in %s on %s"), log->name, time); | |
| 215 | else | |
| 216 | title = g_strdup_printf(_("Conversation with %s on %s"), log->name, time); | |
| 217 | ||
| 218 | title_utf8 = gaim_utf8_try_convert(title); | |
| 219 | g_free(title); | |
| 220 | ||
| 221 | title = g_strdup_printf("<span size='larger' weight='bold'>%s</span>", title_utf8); | |
| 222 | g_free(title_utf8); | |
| 223 | ||
| 224 | gtk_label_set_markup(GTK_LABEL(viewer->label), title); | |
| 225 | g_free(title); | |
| 226 | } | |
| 227 | ||
| 7432 | 228 | read = gaim_log_read(log, &flags); |
| 229 | viewer->flags = flags; | |
| 10663 | 230 | |
| 7432 | 231 | gtk_imhtml_clear(GTK_IMHTML(viewer->imhtml)); |
|
10645
f00e65bebc8b
[gaim-migrate @ 12157]
Richard Laager <rlaager@pidgin.im>
parents:
10636
diff
changeset
|
232 | gtk_imhtml_set_protocol_name(GTK_IMHTML(viewer->imhtml), |
|
f00e65bebc8b
[gaim-migrate @ 12157]
Richard Laager <rlaager@pidgin.im>
parents:
10636
diff
changeset
|
233 | gaim_account_get_protocol_name(log->account)); |
|
10574
5abb2931b6ff
[gaim-migrate @ 11966]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
10181
diff
changeset
|
234 | gtk_imhtml_append_text(GTK_IMHTML(viewer->imhtml), read, |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
235 | GTK_IMHTML_NO_COMMENTS | GTK_IMHTML_NO_TITLE | GTK_IMHTML_NO_SCROLL | |
| 7432 | 236 | ((flags & GAIM_LOG_READ_NO_NEWLINE) ? GTK_IMHTML_NO_NEWLINE : 0)); |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
237 | g_free(read); |
| 7535 | 238 | |
| 10663 | 239 | if (viewer->search != NULL) { |
|
10574
5abb2931b6ff
[gaim-migrate @ 11966]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
10181
diff
changeset
|
240 | gtk_imhtml_search_clear(GTK_IMHTML(viewer->imhtml)); |
|
7537
4c3be2f554b1
[gaim-migrate @ 8150]
Christian Hammond <chipx86@chipx86.com>
parents:
7535
diff
changeset
|
241 | gtk_imhtml_search_find(GTK_IMHTML(viewer->imhtml), viewer->search); |
|
10574
5abb2931b6ff
[gaim-migrate @ 11966]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
10181
diff
changeset
|
242 | } |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
243 | |
|
12232
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
244 | /* When we set the initial log, this gets called and the window is still NULL. */ |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
245 | if (viewer->window->window != NULL) |
|
857f087ec86b
[gaim-migrate @ 14534]
Richard Laager <rlaager@pidgin.im>
parents:
11869
diff
changeset
|
246 | gdk_window_set_cursor(viewer->window->window, NULL); |
| 7432 | 247 | } |
| 248 | ||
| 249 | /* I want to make this smarter, but haven't come up with a cool algorithm to do so, yet. | |
| 250 | * I want the tree to be divided into groups like "Today," "Yesterday," "Last week," | |
| 251 | * "August," "2002," etc. based on how many conversation took place in each subdivision. | |
| 252 | * | |
| 253 | * For now, I'll just make it a flat list. | |
| 254 | */ | |
| 255 | static void populate_log_tree(GaimGtkLogViewer *lv) | |
| 11585 | 256 | /* Logs are made from trees in real life. |
| 7432 | 257 | This is a tree made from logs */ |
| 258 | { | |
| 9435 | 259 | char month[30]; |
| 7440 | 260 | char title[64]; |
| 10663 | 261 | char prev_top_month[30] = ""; |
| 9435 | 262 | char *utf8_tmp; /* temporary variable for utf8 conversion */ |
| 263 | GtkTreeIter toplevel, child; | |
| 7432 | 264 | GList *logs = lv->logs; |
| 10663 | 265 | |
| 266 | while (logs != NULL) { | |
| 7432 | 267 | GaimLog *log = logs->data; |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
268 | |
| 10636 | 269 | gaim_strftime(month, sizeof(month), "%B %Y", localtime(&log->time)); |
| 270 | gaim_strftime(title, sizeof(title), "%c", localtime(&log->time)); | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
271 | |
| 9435 | 272 | /* do utf8 conversions */ |
| 273 | utf8_tmp = gaim_utf8_try_convert(month); | |
| 274 | strncpy(month, utf8_tmp, sizeof(month)); | |
|
10574
5abb2931b6ff
[gaim-migrate @ 11966]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
10181
diff
changeset
|
275 | g_free(utf8_tmp); |
| 9435 | 276 | utf8_tmp = gaim_utf8_try_convert(title); |
| 277 | strncpy(title, utf8_tmp, sizeof(title)); | |
| 278 | g_free(utf8_tmp); | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
279 | |
| 9435 | 280 | if (strncmp(month, prev_top_month, sizeof(month)) != 0) { |
| 281 | /* top level */ | |
| 282 | gtk_tree_store_append(lv->treestore, &toplevel, NULL); | |
| 283 | gtk_tree_store_set(lv->treestore, &toplevel, 0, month, 1, NULL, -1); | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
284 | |
|
10680
e4a00ce2fc35
[gaim-migrate @ 12226]
Richard Laager <rlaager@pidgin.im>
parents:
10669
diff
changeset
|
285 | strncpy(prev_top_month, month, sizeof(prev_top_month)); |
|
e4a00ce2fc35
[gaim-migrate @ 12226]
Richard Laager <rlaager@pidgin.im>
parents:
10669
diff
changeset
|
286 | } |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
287 | |
|
10680
e4a00ce2fc35
[gaim-migrate @ 12226]
Richard Laager <rlaager@pidgin.im>
parents:
10669
diff
changeset
|
288 | /* sub */ |
|
e4a00ce2fc35
[gaim-migrate @ 12226]
Richard Laager <rlaager@pidgin.im>
parents:
10669
diff
changeset
|
289 | gtk_tree_store_append(lv->treestore, &child, &toplevel); |
|
e4a00ce2fc35
[gaim-migrate @ 12226]
Richard Laager <rlaager@pidgin.im>
parents:
10669
diff
changeset
|
290 | gtk_tree_store_set(lv->treestore, &child, 0, title, 1, log, -1); |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
291 | |
| 7432 | 292 | logs = logs->next; |
| 293 | } | |
| 294 | } | |
| 295 | ||
| 10663 | 296 | static GaimGtkLogViewer *display_log_viewer(struct log_viewer_hash_t *ht, GList *logs, |
| 11585 | 297 | const char *title, GdkPixbuf *pixbuf, int log_size) |
| 10663 | 298 | { |
| 299 | GaimGtkLogViewer *lv; | |
| 300 | GtkWidget *title_box; | |
| 301 | char *text; | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
302 | GtkWidget *pane; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
303 | GtkWidget *sw; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
304 | GtkCellRenderer *rend; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
305 | GtkTreeViewColumn *col; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
306 | GtkTreeSelection *sel; |
|
11780
9aee3bde84b9
[gaim-migrate @ 14071]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
11769
diff
changeset
|
307 | #if GTK_CHECK_VERSION(2,2,0) |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
308 | GtkTreePath *path_to_first_log; |
|
11780
9aee3bde84b9
[gaim-migrate @ 14071]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
11769
diff
changeset
|
309 | #endif |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
310 | GtkWidget *vbox; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
311 | GtkWidget *frame; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
312 | GtkWidget *hbox; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
313 | GtkWidget *button; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
314 | GtkWidget *size_label; |
| 7432 | 315 | |
| 316 | lv = g_new0(GaimGtkLogViewer, 1); | |
| 10663 | 317 | lv->logs = logs; |
| 318 | ||
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
319 | if (logs == NULL) |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
320 | { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
321 | /* No logs were found. */ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
322 | const char *log_preferences = NULL; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
323 | |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
324 | if (ht == NULL) { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
325 | if (!gaim_prefs_get_bool("/core/logging/log_system")) |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
326 | log_preferences = _("System events will only be logged if the \"Log all status changes to system log\" preference is enabled."); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
327 | } else { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
328 | if (ht->type == GAIM_LOG_IM) { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
329 | if (!gaim_prefs_get_bool("/core/logging/log_ims")) |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
330 | log_preferences = _("Instant messages will only be logged if the \"Log all instant messages\" preference is enabled."); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
331 | } else if (ht->type == GAIM_LOG_CHAT) { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
332 | if (!gaim_prefs_get_bool("/core/logging/log_chats")) |
|
11869
e77f2f29b09d
[gaim-migrate @ 14160]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
11780
diff
changeset
|
333 | log_preferences = _("Chats will only be logged if the \"Log all chats\" preference is enabled."); |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
334 | } |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
335 | } |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
336 | |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
337 | gaim_notify_info(NULL, title, _("No logs were found"), log_preferences); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
338 | return NULL; |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
339 | } |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
340 | |
| 10663 | 341 | if (ht != NULL) |
| 342 | g_hash_table_insert(log_viewers, ht, lv); | |
| 7432 | 343 | |
| 344 | /* Window ***********/ | |
| 10663 | 345 | lv->window = gtk_dialog_new_with_buttons(title, NULL, 0, |
| 7432 | 346 | GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE, NULL); |
| 11243 | 347 | gtk_container_set_border_width (GTK_CONTAINER(lv->window), GAIM_HIG_BOX_SPACE); |
| 7432 | 348 | gtk_dialog_set_has_separator(GTK_DIALOG(lv->window), FALSE); |
| 349 | gtk_box_set_spacing(GTK_BOX(GTK_DIALOG(lv->window)->vbox), 0); | |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
350 | g_signal_connect(G_OBJECT(lv->window), "response", |
|
7454
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
351 | G_CALLBACK(destroy_cb), ht); |
|
11004
2323998d6cb9
[gaim-migrate @ 12859]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents:
10884
diff
changeset
|
352 | gtk_window_set_role(GTK_WINDOW(lv->window), "log_viewer"); |
|
7454
c99a2070471e
[gaim-migrate @ 8067]
Mark Doliner <markdoliner@pidgin.im>
parents:
7440
diff
changeset
|
353 | |
| 10663 | 354 | /* Icon *************/ |
| 355 | if (pixbuf != NULL) { | |
| 356 | GdkPixbuf *scale; | |
| 357 | GtkWidget *icon; | |
| 7432 | 358 | |
| 11243 | 359 | title_box = gtk_hbox_new(FALSE, GAIM_HIG_BOX_SPACE); |
| 360 | gtk_container_set_border_width(GTK_CONTAINER(title_box), GAIM_HIG_BOX_SPACE); | |
| 10663 | 361 | gtk_box_pack_start(GTK_BOX(GTK_DIALOG(lv->window)->vbox), title_box, FALSE, FALSE, 0); |
| 362 | ||
| 363 | scale = gdk_pixbuf_scale_simple(pixbuf, 16, 16, GDK_INTERP_BILINEAR); | |
| 364 | icon = gtk_image_new_from_pixbuf(scale); | |
| 365 | gtk_box_pack_start(GTK_BOX(title_box), icon, FALSE, FALSE, 0); | |
| 366 | g_object_unref(G_OBJECT(pixbuf)); | |
| 367 | g_object_unref(G_OBJECT(scale)); | |
| 368 | } else | |
| 369 | title_box = GTK_DIALOG(lv->window)->vbox; | |
| 7432 | 370 | |
| 371 | /* Label ************/ | |
| 10663 | 372 | lv->label = gtk_label_new(NULL); |
| 373 | ||
| 374 | text = g_strdup_printf("<span size='larger' weight='bold'>%s</span>", title); | |
| 9624 | 375 | |
| 10663 | 376 | gtk_label_set_markup(GTK_LABEL(lv->label), text); |
| 377 | gtk_misc_set_alignment(GTK_MISC(lv->label), 0, 0); | |
| 378 | gtk_box_pack_start(GTK_BOX(title_box), lv->label, FALSE, FALSE, 0); | |
| 7432 | 379 | g_free(text); |
| 380 | ||
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
381 | /* Pane *************/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
382 | pane = gtk_hpaned_new(); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
383 | gtk_container_set_border_width(GTK_CONTAINER(pane), GAIM_HIG_BOX_SPACE); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
384 | gtk_box_pack_start(GTK_BOX(GTK_DIALOG(lv->window)->vbox), pane, TRUE, TRUE, 0); |
| 7432 | 385 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
386 | /* List *************/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
387 | sw = gtk_scrolled_window_new (NULL, NULL); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
388 | gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (sw), GTK_SHADOW_IN); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
389 | gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(sw), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
390 | gtk_paned_add1(GTK_PANED(pane), sw); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
391 | lv->treestore = gtk_tree_store_new (2, G_TYPE_STRING, G_TYPE_POINTER); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
392 | lv->treeview = gtk_tree_view_new_with_model (GTK_TREE_MODEL (lv->treestore)); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
393 | rend = gtk_cell_renderer_text_new(); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
394 | col = gtk_tree_view_column_new_with_attributes ("time", rend, "markup", 0, NULL); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
395 | gtk_tree_view_append_column (GTK_TREE_VIEW(lv->treeview), col); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
396 | gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (lv->treeview), FALSE); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
397 | gtk_container_add (GTK_CONTAINER (sw), lv->treeview); |
|
11402
1be90c47f022
[gaim-migrate @ 13637]
Peter McCurdy <cpirate@users.sourceforge.net>
parents:
11243
diff
changeset
|
398 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
399 | populate_log_tree(lv); |
|
11402
1be90c47f022
[gaim-migrate @ 13637]
Peter McCurdy <cpirate@users.sourceforge.net>
parents:
11243
diff
changeset
|
400 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
401 | sel = gtk_tree_view_get_selection (GTK_TREE_VIEW (lv->treeview)); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
402 | g_signal_connect (G_OBJECT (sel), "changed", |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
403 | G_CALLBACK (log_select_cb), |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
404 | lv); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
405 | g_signal_connect (G_OBJECT(lv->treeview), "row-activated", |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
406 | G_CALLBACK(log_row_activated_cb), |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
407 | lv); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
408 | gaim_set_accessible_label(lv->treeview, lv->label); |
| 11585 | 409 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
410 | /* Log size ************/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
411 | if(log_size) { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
412 | char *sz_txt = gaim_str_size_to_units(log_size); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
413 | text = g_strdup_printf("<span weight='bold'>%s</span> %s", _("Total log size:"), sz_txt); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
414 | size_label = gtk_label_new(NULL); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
415 | gtk_label_set_markup(GTK_LABEL(size_label), text); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
416 | /* gtk_paned_add1(GTK_PANED(pane), size_label); */ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
417 | gtk_misc_set_alignment(GTK_MISC(size_label), 0, 0); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
418 | gtk_box_pack_end(GTK_BOX(GTK_DIALOG(lv->window)->vbox), size_label, FALSE, FALSE, 0); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
419 | g_free(sz_txt); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
420 | g_free(text); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
421 | } |
|
11402
1be90c47f022
[gaim-migrate @ 13637]
Peter McCurdy <cpirate@users.sourceforge.net>
parents:
11243
diff
changeset
|
422 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
423 | /* A fancy little box ************/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
424 | vbox = gtk_vbox_new(FALSE, GAIM_HIG_BOX_SPACE); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
425 | gtk_paned_add2(GTK_PANED(pane), vbox); |
|
11402
1be90c47f022
[gaim-migrate @ 13637]
Peter McCurdy <cpirate@users.sourceforge.net>
parents:
11243
diff
changeset
|
426 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
427 | /* Viewer ************/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
428 | frame = gaim_gtk_create_imhtml(FALSE, &lv->imhtml, NULL); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
429 | gtk_widget_set_name(lv->imhtml, "gaim_gtklog_imhtml"); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
430 | gtk_widget_set_size_request(lv->imhtml, 320, 200); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
431 | gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 0); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
432 | gtk_widget_show(frame); |
|
10181
2425c3773266
[gaim-migrate @ 11296]
Mark Doliner <markdoliner@pidgin.im>
parents:
10175
diff
changeset
|
433 | |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
434 | /* Search box **********/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
435 | hbox = gtk_hbox_new(FALSE, GAIM_HIG_BOX_SPACE); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
436 | gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
437 | lv->entry = gtk_entry_new(); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
438 | gtk_box_pack_start(GTK_BOX(hbox), lv->entry, TRUE, TRUE, 0); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
439 | button = gtk_button_new_from_stock(GTK_STOCK_FIND); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
440 | gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, FALSE, 0); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
441 | g_signal_connect(GTK_ENTRY(lv->entry), "activate", G_CALLBACK(search_cb), lv); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
442 | g_signal_connect(GTK_BUTTON(button), "activate", G_CALLBACK(search_cb), lv); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
443 | g_signal_connect(GTK_BUTTON(button), "clicked", G_CALLBACK(search_cb), lv); |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
444 | |
|
11780
9aee3bde84b9
[gaim-migrate @ 14071]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
11769
diff
changeset
|
445 | #if GTK_CHECK_VERSION(2,2,0) |
|
11769
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
446 | /* Show most recent log **********/ |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
447 | path_to_first_log = gtk_tree_path_new_from_string("0:0"); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
448 | if (path_to_first_log) |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
449 | { |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
450 | gtk_tree_view_expand_to_path(GTK_TREE_VIEW(lv->treeview), path_to_first_log); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
451 | gtk_tree_selection_select_path(sel, path_to_first_log); |
|
66e922bf0ebd
[gaim-migrate @ 14060]
Mark Doliner <markdoliner@pidgin.im>
parents:
11703
diff
changeset
|
452 | gtk_tree_path_free(path_to_first_log); |
| 10663 | 453 | } |
|
11780
9aee3bde84b9
[gaim-migrate @ 14071]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
11769
diff
changeset
|
454 | #endif |
| 7432 | 455 | |
| 456 | gtk_widget_show_all(lv->window); | |
| 10663 | 457 | |
| 458 | return lv; | |
| 459 | } | |
| 460 | ||
| 461 | void gaim_gtk_log_show(GaimLogType type, const char *screenname, GaimAccount *account) { | |
| 462 | struct log_viewer_hash_t *ht = g_new0(struct log_viewer_hash_t, 1); | |
| 463 | GaimGtkLogViewer *lv = NULL; | |
| 464 | const char *name = screenname; | |
| 465 | char *title; | |
| 466 | ||
| 467 | g_return_if_fail(account != NULL); | |
| 468 | g_return_if_fail(screenname != NULL); | |
| 469 | ||
| 470 | ht->type = type; | |
| 471 | ht->screenname = g_strdup(screenname); | |
| 472 | ht->account = account; | |
| 473 | ||
| 474 | if (log_viewers == NULL) { | |
| 475 | log_viewers = g_hash_table_new(log_viewer_hash, log_viewer_equal); | |
| 476 | } else if ((lv = g_hash_table_lookup(log_viewers, ht))) { | |
| 477 | gtk_window_present(GTK_WINDOW(lv->window)); | |
| 478 | g_free(ht); | |
| 479 | return; | |
| 480 | } | |
| 481 | ||
| 482 | if (type == GAIM_LOG_CHAT) { | |
| 483 | GaimChat *chat; | |
| 484 | ||
| 485 | chat = gaim_blist_find_chat(account, screenname); | |
| 486 | if (chat != NULL) | |
| 487 | name = gaim_chat_get_name(chat); | |
| 488 | ||
| 489 | title = g_strdup_printf(_("Conversations in %s"), name); | |
| 490 | } else { | |
| 491 | GaimBuddy *buddy; | |
| 492 | ||
| 493 | buddy = gaim_find_buddy(account, screenname); | |
| 494 | if (buddy != NULL) | |
| 495 | name = gaim_buddy_get_contact_alias(buddy); | |
| 496 | ||
| 497 | title = g_strdup_printf(_("Conversations with %s"), name); | |
| 498 | } | |
| 499 | ||
| 500 | display_log_viewer(ht, gaim_log_get_logs(type, screenname, account), | |
| 11585 | 501 | title, gaim_gtk_create_prpl_icon(account), gaim_log_get_total_size(type, screenname, account)); |
| 10663 | 502 | g_free(title); |
| 503 | } | |
| 504 | ||
| 505 | void gaim_gtk_log_show_contact(GaimContact *contact) { | |
| 506 | struct log_viewer_hash_t *ht = g_new0(struct log_viewer_hash_t, 1); | |
| 507 | GaimBlistNode *child; | |
| 508 | GaimGtkLogViewer *lv = NULL; | |
| 509 | GList *logs = NULL; | |
| 510 | char *filename; | |
| 511 | GdkPixbuf *pixbuf; | |
| 512 | const char *name = NULL; | |
| 513 | char *title; | |
| 11585 | 514 | int total_log_size = 0; |
| 10663 | 515 | |
| 516 | g_return_if_fail(contact != NULL); | |
| 517 | ||
| 518 | ht->type = GAIM_LOG_IM; | |
| 519 | ht->contact = contact; | |
| 520 | ||
| 521 | if (log_viewers == NULL) { | |
| 522 | log_viewers = g_hash_table_new(log_viewer_hash, log_viewer_equal); | |
| 523 | } else if ((lv = g_hash_table_lookup(log_viewers, ht))) { | |
| 524 | gtk_window_present(GTK_WINDOW(lv->window)); | |
| 525 | g_free(ht); | |
| 526 | return; | |
| 527 | } | |
| 528 | ||
| 529 | for (child = contact->node.child ; child ; child = child->next) { | |
| 530 | if (!GAIM_BLIST_NODE_IS_BUDDY(child)) | |
| 531 | continue; | |
| 532 | ||
|
11703
6b22ef099870
[gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents:
11700
diff
changeset
|
533 | logs = g_list_concat(gaim_log_get_logs(GAIM_LOG_IM, ((GaimBuddy *)child)->name, |
|
6b22ef099870
[gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents:
11700
diff
changeset
|
534 | ((GaimBuddy *)child)->account), logs); |
| 11585 | 535 | total_log_size += gaim_log_get_total_size(GAIM_LOG_IM, ((GaimBuddy *)child)->name, ((GaimBuddy *)child)->account); |
| 10663 | 536 | } |
| 537 | logs = g_list_sort(logs, gaim_log_compare); | |
| 538 | ||
| 539 | filename = g_build_filename(DATADIR, "pixmaps", "gaim", "icons", "online.png", NULL); | |
| 540 | pixbuf = gdk_pixbuf_new_from_file(filename, NULL); | |
| 541 | g_free(filename); | |
| 542 | ||
| 543 | if (contact->alias != NULL) | |
| 544 | name = contact->alias; | |
| 545 | else if (contact->priority != NULL) | |
| 546 | name = gaim_buddy_get_contact_alias(contact->priority); | |
| 547 | ||
| 548 | title = g_strdup_printf(_("Conversations with %s"), name); | |
| 11585 | 549 | display_log_viewer(ht, logs, title, pixbuf, total_log_size); |
| 10663 | 550 | g_free(title); |
| 7432 | 551 | } |
| 8573 | 552 | |
| 553 | void gaim_gtk_syslog_show() | |
| 554 | { | |
| 555 | GList *accounts = NULL; | |
| 10663 | 556 | GList *logs = NULL; |
| 8573 | 557 | |
|
10181
2425c3773266
[gaim-migrate @ 11296]
Mark Doliner <markdoliner@pidgin.im>
parents:
10175
diff
changeset
|
558 | if (syslog_viewer != NULL) { |
| 8573 | 559 | gtk_window_present(GTK_WINDOW(syslog_viewer->window)); |
| 560 | return; | |
| 561 | } | |
| 562 | ||
| 10663 | 563 | for(accounts = gaim_accounts_get_all(); accounts != NULL; accounts = accounts->next) { |
| 8573 | 564 | |
| 565 | GaimAccount *account = (GaimAccount *)accounts->data; | |
| 10663 | 566 | if(gaim_find_prpl(gaim_account_get_protocol_id(account)) == NULL) |
| 8573 | 567 | continue; |
| 568 | ||
|
11703
6b22ef099870
[gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents:
11700
diff
changeset
|
569 | logs = g_list_concat(gaim_log_get_system_logs(account), logs); |
| 8573 | 570 | } |
| 10663 | 571 | logs = g_list_sort(logs, gaim_log_compare); |
|
10175
2bf5ed145e8a
[gaim-migrate @ 11290]
Mark Doliner <markdoliner@pidgin.im>
parents:
9917
diff
changeset
|
572 | |
| 11585 | 573 | syslog_viewer = display_log_viewer(NULL, logs, _("System Log"), NULL, 0); |
| 8573 | 574 | } |