Mercurial > pidgin
changeset 7433:6fdc55dd636a
[gaim-migrate @ 8038]
Because all the log reading and writing is abstracted, it makes it real easy
to tell Gaim, "give me entire contents of the last conversation," which is
useful for, say, a history.c plugin. This code is now much simpler, and it
took no time at all to port it.
Sort-by-log will be a bit harder.
And because two people asked me within a minute of me committing it, there
exists an "old log" GaimLogLogger that doesn't write logs, but can list and
read them. So, you'll be able to seamlessly see your old logs along with
your new logs together in the log viewer.
committer: Tailor Script <tailor@pidgin.im>
author | Sean Egan <seanegan@gmail.com> |
---|---|
date | Wed, 05 Nov 2003 06:39:05 +0000 |
parents | 31faec55ef8e |
children | f05d735c2eac |
files | plugins/history.c |
diffstat | 1 files changed, 11 insertions(+), 43 deletions(-) [+] |
line wrap: on
line diff
--- a/plugins/history.c Wed Nov 05 06:16:25 2003 +0000 +++ b/plugins/history.c Wed Nov 05 06:39:05 2003 +0000 @@ -5,6 +5,7 @@ #include "conversation.h" #include "debug.h" +#include "log.h" #include "prefs.h" #include "signals.h" #include "util.h" @@ -21,57 +22,24 @@ { GaimGtkConversation *gtkconv; const char *name = gaim_conversation_get_name(c); - struct stat st; - FILE *fd; - char *userdir = g_strdup(gaim_user_dir()); - char *logfile = g_strdup_printf("%s.log", gaim_normalize(c->account, name)); - char *path = g_build_filename(userdir, "logs", logfile, NULL); - char buf[HISTORY_SIZE+1]; - char *tmp, *tmp2; - int size; + char *history = NULL; + int flags; GtkIMHtmlOptions options = GTK_IMHTML_NO_COLOURS; GtkTextIter end; - - if (stat(path, &st) || S_ISDIR(st.st_mode) || st.st_size == 0 || - !(fd = fopen(path, "r"))) { - g_free(userdir); - g_free(logfile); - g_free(path); + GList *logs = gaim_log_get_logs(gaim_conversation_get_name(c), gaim_conversation_get_account(c)); + if (!logs) return; - } - - fseek(fd, st.st_size > HISTORY_SIZE ? st.st_size - HISTORY_SIZE : 0, SEEK_SET); - size = fread(buf, 1, HISTORY_SIZE, fd); - tmp = buf; - tmp[size] = 0; - - /* start the history at a newline */ - while (*tmp && *tmp != '\n') - tmp++; - - if (*tmp) tmp++; - - if(*tmp == '<') + history = gaim_log_read((GaimLog*)logs->data, &flags); + gtkconv = GAIM_GTK_CONVERSATION(c); + if (flags & GAIM_LOG_READ_NO_NEWLINE) options |= GTK_IMHTML_NO_NEWLINE; - - if (gaim_prefs_get_bool("/gaim/gtk/conversations/show_urls_as_links")) - tmp2 = gaim_markup_linkify(tmp); - else - tmp2 = g_strdup(tmp); - - gtkconv = GAIM_GTK_CONVERSATION(c); - - gtk_imhtml_append_text(GTK_IMHTML(gtkconv->imhtml), tmp2, options); - gtk_imhtml_append_text(GTK_IMHTML(gtkconv->imhtml), "<br>", options); + gtk_imhtml_append_text(GTK_IMHTML(gtkconv->imhtml), history, options); + gtk_imhtml_append_text(GTK_IMHTML(gtkconv->imhtml), "<hr>", options); gtk_text_buffer_get_end_iter(GTK_IMHTML(gtkconv->imhtml)->text_buffer, &end); gtk_text_view_scroll_to_iter(GTK_TEXT_VIEW(gtkconv->imhtml), &end, 0, TRUE, 0, 0); - - g_free(tmp2); - g_free(userdir); - g_free(logfile); - g_free(path); + g_free(history); } static gboolean