libpurple/log.c

Thu, 20 Sep 2007 16:30:17 +0000

author
Sadrul Habib Chowdhury <sadrul@pidgin.im>
date
Thu, 20 Sep 2007 16:30:17 +0000
branch
sadrul.currentmedia
changeset 21193
e918a1846d03
parent 20330
650a7af9c238
child 21389
e1dd8142bb87
permissions
-rw-r--r--

Use an independant status type for 'current media' stuff, instead of using
status attributes. This includes changes in both xmpp and msn.
Also, in MSN, CurrentMedia is sent with PSM if you turn on the status and
set the attributes on the account.

7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1 /**
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
2 * @file log.c Logging API
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
3 * @ingroup core
20330
650a7af9c238 remove gpl boilerplate from doxygen docs
Sean Egan <seanegan@pidgin.im>
parents: 19859
diff changeset
4 */
650a7af9c238 remove gpl boilerplate from doxygen docs
Sean Egan <seanegan@pidgin.im>
parents: 19859
diff changeset
5
650a7af9c238 remove gpl boilerplate from doxygen docs
Sean Egan <seanegan@pidgin.im>
parents: 19859
diff changeset
6 /* purple
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
7 *
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
8 * Purple is the legal property of its developers, whose names are too numerous
8046
c581b20a47d6 [gaim-migrate @ 8730]
Sean Egan <seanegan@pidgin.im>
parents: 8027
diff changeset
9 * to list here. Please refer to the COPYRIGHT file distributed with this
c581b20a47d6 [gaim-migrate @ 8730]
Sean Egan <seanegan@pidgin.im>
parents: 8027
diff changeset
10 * source distribution.
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
11 *
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
12 * This program is free software; you can redistribute it and/or modify
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
13 * it under the terms of the GNU General Public License as published by
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
14 * the Free Software Foundation; either version 2 of the License, or
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
15 * (at your option) any later version.
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
16 *
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
17 * This program is distributed in the hope that it will be useful,
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
20 * GNU General Public License for more details.
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
21 *
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
22 * You should have received a copy of the GNU General Public License
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
23 * along with this program; if not, write to the Free Software
19859
71d37b57eff2 The FSF changed its address a while ago; our files were out of date.
John Bailey <rekkanoryo@rekkanoryo.org>
parents: 19832
diff changeset
24 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
25 */
4195
37449660e3d5 [gaim-migrate @ 4426]
Nicolás Lichtmaier <nico@lichtmaier.com.ar>
parents: 4192
diff changeset
26
13930
91f702895cd9 [gaim-migrate @ 16334]
Daniel Atallah <datallah@pidgin.im>
parents: 13762
diff changeset
27 #include "internal.h"
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
28 #include "account.h"
13762
a6c3092757f3 [gaim-migrate @ 16171]
Mark Doliner <markdoliner@pidgin.im>
parents: 13624
diff changeset
29 #include "dbus-maybe.h"
5872
754c63f29b77 [gaim-migrate @ 6304]
Christian Hammond <chipx86@chipx86.com>
parents: 5839
diff changeset
30 #include "debug.h"
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
31 #include "internal.h"
5872
754c63f29b77 [gaim-migrate @ 6304]
Christian Hammond <chipx86@chipx86.com>
parents: 5839
diff changeset
32 #include "log.h"
5548
200682124464 [gaim-migrate @ 5949]
Nathan Walp <nwalp@pidgin.im>
parents: 5528
diff changeset
33 #include "prefs.h"
5872
754c63f29b77 [gaim-migrate @ 6304]
Christian Hammond <chipx86@chipx86.com>
parents: 5839
diff changeset
34 #include "util.h"
7764
b1bb74f2f79d [gaim-migrate @ 8409]
Ethan Blanton <elb@pidgin.im>
parents: 7761
diff changeset
35 #include "stringref.h"
18101
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
36 #include "imgstore.h"
5872
754c63f29b77 [gaim-migrate @ 6304]
Christian Hammond <chipx86@chipx86.com>
parents: 5839
diff changeset
37
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
38 static GSList *loggers = NULL;
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
39
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
40 static PurpleLogLogger *html_logger;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
41 static PurpleLogLogger *txt_logger;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
42 static PurpleLogLogger *old_logger;
5872
754c63f29b77 [gaim-migrate @ 6304]
Christian Hammond <chipx86@chipx86.com>
parents: 5839
diff changeset
43
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
44 struct _purple_logsize_user {
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
45 char *name;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
46 PurpleAccount *account;
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
47 };
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
48 static GHashTable *logsize_users = NULL;
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
49
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
50 static void log_get_log_sets_common(GHashTable *sets);
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
51
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
52 static gsize html_logger_write(PurpleLog *log, PurpleMessageFlags type,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
53 const char *from, time_t time, const char *message);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
54 static void html_logger_finalize(PurpleLog *log);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
55 static GList *html_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
56 static GList *html_logger_list_syslog(PurpleAccount *account);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
57 static char *html_logger_read(PurpleLog *log, PurpleLogReadFlags *flags);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
58 static int html_logger_total_size(PurpleLogType type, const char *name, PurpleAccount *account);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
59
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
60 static GList *old_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
61 static int old_logger_total_size(PurpleLogType type, const char *name, PurpleAccount *account);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
62 static char * old_logger_read (PurpleLog *log, PurpleLogReadFlags *flags);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
63 static int old_logger_size (PurpleLog *log);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
64 static void old_logger_get_log_sets(PurpleLogSetCallback cb, GHashTable *sets);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
65 static void old_logger_finalize(PurpleLog *log);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
66
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
67 static gsize txt_logger_write(PurpleLog *log,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
68 PurpleMessageFlags type,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
69 const char *from, time_t time, const char *message);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
70 static void txt_logger_finalize(PurpleLog *log);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
71 static GList *txt_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
72 static GList *txt_logger_list_syslog(PurpleAccount *account);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
73 static char *txt_logger_read(PurpleLog *log, PurpleLogReadFlags *flags);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
74 static int txt_logger_total_size(PurpleLogType type, const char *name, PurpleAccount *account);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
75
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
76 /**************************************************************************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
77 * PUBLIC LOGGING FUNCTIONS ***********************************************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
78 **************************************************************************/
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
79
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
80 PurpleLog *purple_log_new(PurpleLogType type, const char *name, PurpleAccount *account,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
81 PurpleConversation *conv, time_t time, const struct tm *tm)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
82 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
83 PurpleLog *log;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
84
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
85 /* IMPORTANT: Make sure to initialize all the members of PurpleLog */
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
86 log = g_slice_new(PurpleLog);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
87 PURPLE_DBUS_REGISTER_POINTER(log, PurpleLog);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
88
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
89 log->type = type;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
90 log->name = g_strdup(purple_normalize(account, name));
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
91 log->account = account;
11292
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
92 log->conv = conv;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
93 log->time = time;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
94 log->logger = purple_log_logger_get();
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
95 log->logger_data = NULL;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
96
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
97 if (tm == NULL)
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
98 log->tm = NULL;
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
99 else
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
100 {
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
101 /* There's no need to zero this as we immediately do a direct copy. */
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
102 log->tm = g_slice_new(struct tm);
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
103
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
104 *(log->tm) = *tm;
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
105
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
106 #ifdef HAVE_STRUCT_TM_TM_ZONE
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
107 /* XXX: This is so wrong... */
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
108 if (log->tm->tm_zone != NULL)
13161
8f84bea3949f [gaim-migrate @ 15523]
Richard Laager <rlaager@pidgin.im>
parents: 13160
diff changeset
109 {
8f84bea3949f [gaim-migrate @ 15523]
Richard Laager <rlaager@pidgin.im>
parents: 13160
diff changeset
110 char *tmp = g_locale_from_utf8(log->tm->tm_zone, -1, NULL, NULL, NULL);
8f84bea3949f [gaim-migrate @ 15523]
Richard Laager <rlaager@pidgin.im>
parents: 13160
diff changeset
111 if (tmp != NULL)
14036
9026f0f99d96 [gaim-migrate @ 16532]
Evan Schoenberg <evands@pidgin.im>
parents: 13930
diff changeset
112 log->tm->tm_zone = tmp;
13161
8f84bea3949f [gaim-migrate @ 15523]
Richard Laager <rlaager@pidgin.im>
parents: 13160
diff changeset
113 else
8f84bea3949f [gaim-migrate @ 15523]
Richard Laager <rlaager@pidgin.im>
parents: 13160
diff changeset
114 /* Just shove the UTF-8 bytes in and hope... */
14097
0c340861ab79 [gaim-migrate @ 16638]
Mark Doliner <markdoliner@pidgin.im>
parents: 14068
diff changeset
115 log->tm->tm_zone = g_strdup(log->tm->tm_zone);
13161
8f84bea3949f [gaim-migrate @ 15523]
Richard Laager <rlaager@pidgin.im>
parents: 13160
diff changeset
116 }
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
117 #endif
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
118 }
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
119
7440
e0d8f6bc36c2 [gaim-migrate @ 8045]
Nathan Walp <nwalp@pidgin.im>
parents: 7436
diff changeset
120 if (log->logger && log->logger->create)
e0d8f6bc36c2 [gaim-migrate @ 8045]
Nathan Walp <nwalp@pidgin.im>
parents: 7436
diff changeset
121 log->logger->create(log);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
122 return log;
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
123 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
124
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
125 void purple_log_free(PurpleLog *log)
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
126 {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
127 g_return_if_fail(log);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
128 if (log->logger && log->logger->finalize)
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
129 log->logger->finalize(log);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
130 g_free(log->name);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
131
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
132 if (log->tm != NULL)
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
133 {
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
134 #ifdef HAVE_STRUCT_TM_TM_ZONE
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
135 /* XXX: This is so wrong... */
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
136 g_free((char *)log->tm->tm_zone);
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
137 #endif
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
138 g_slice_free(struct tm, log->tm);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
139 }
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
140
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
141 PURPLE_DBUS_UNREGISTER_POINTER(log);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
142 g_slice_free(PurpleLog, log);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
143 }
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
144
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
145 void purple_log_write(PurpleLog *log, PurpleMessageFlags type,
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
146 const char *from, time_t time, const char *message)
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
147 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
148 struct _purple_logsize_user *lu;
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
149 gsize written, total = 0;
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
150 gpointer ptrsize;
10173
335358c9cee4 [gaim-migrate @ 11287]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 10171
diff changeset
151
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
152 g_return_if_fail(log);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
153 g_return_if_fail(log->logger);
7442
247b4506d446 [gaim-migrate @ 8047]
Nathan Walp <nwalp@pidgin.im>
parents: 7441
diff changeset
154 g_return_if_fail(log->logger->write);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
155
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
156 written = (log->logger->write)(log, type, from, time, message);
10171
814764a2d24c [gaim-migrate @ 11263]
Luke Schierer <lschiere@pidgin.im>
parents: 10087
diff changeset
157
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
158 lu = g_new(struct _purple_logsize_user, 1);
9892
281f62b8824e [gaim-migrate @ 10780]
Luke Schierer <lschiere@pidgin.im>
parents: 9883
diff changeset
159
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
160 lu->name = g_strdup(purple_normalize(log->account, log->name));
10171
814764a2d24c [gaim-migrate @ 11263]
Luke Schierer <lschiere@pidgin.im>
parents: 10087
diff changeset
161 lu->account = log->account;
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
162
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
163 if(g_hash_table_lookup_extended(logsize_users, lu, NULL, &ptrsize)) {
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
164 total = GPOINTER_TO_INT(ptrsize);
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
165 total += written;
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
166 g_hash_table_replace(logsize_users, lu, GINT_TO_POINTER(total));
13077
418101346d08 [gaim-migrate @ 15438]
Richard Laager <rlaager@pidgin.im>
parents: 13069
diff changeset
167 } else {
418101346d08 [gaim-migrate @ 15438]
Richard Laager <rlaager@pidgin.im>
parents: 13069
diff changeset
168 g_free(lu->name);
418101346d08 [gaim-migrate @ 15438]
Richard Laager <rlaager@pidgin.im>
parents: 13069
diff changeset
169 g_free(lu);
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
170 }
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
171
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
172 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
173
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
174 char *purple_log_read(PurpleLog *log, PurpleLogReadFlags *flags)
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
175 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
176 PurpleLogReadFlags mflags;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
177 g_return_val_if_fail(log && log->logger, NULL);
7462
c51a6ec98ba7 [gaim-migrate @ 8075]
Nathan Walp <nwalp@pidgin.im>
parents: 7461
diff changeset
178 if (log->logger->read) {
7535
eff069bf9f27 [gaim-migrate @ 8148]
Sean Egan <seanegan@pidgin.im>
parents: 7501
diff changeset
179 char *ret = (log->logger->read)(log, flags ? flags : &mflags);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
180 purple_str_strip_char(ret, '\r');
7462
c51a6ec98ba7 [gaim-migrate @ 8075]
Nathan Walp <nwalp@pidgin.im>
parents: 7461
diff changeset
181 return ret;
c51a6ec98ba7 [gaim-migrate @ 8075]
Nathan Walp <nwalp@pidgin.im>
parents: 7461
diff changeset
182 }
13107
704041197f4d [gaim-migrate @ 15468]
Richard Laager <rlaager@pidgin.im>
parents: 13105
diff changeset
183 return g_strdup(_("<b><font color=\"red\">The logger has no read function</font></b>"));
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
184 }
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
185
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
186 int purple_log_get_size(PurpleLog *log)
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
187 {
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
188 g_return_val_if_fail(log && log->logger, 0);
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
189
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
190 if (log->logger->size)
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
191 return log->logger->size(log);
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
192 return 0;
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
193 }
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
194
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
195 static guint _purple_logsize_user_hash(struct _purple_logsize_user *lu)
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
196 {
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
197 return g_str_hash(lu->name);
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
198 }
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
199
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
200 static guint _purple_logsize_user_equal(struct _purple_logsize_user *lu1,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
201 struct _purple_logsize_user *lu2)
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
202 {
13078
724fb0043eea [gaim-migrate @ 15439]
Richard Laager <rlaager@pidgin.im>
parents: 13077
diff changeset
203 return (lu1->account == lu2->account && (!strcmp(lu1->name, lu2->name)));
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
204 }
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
205
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
206 static void _purple_logsize_user_free_key(struct _purple_logsize_user *lu)
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
207 {
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
208 g_free(lu->name);
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
209 g_free(lu);
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
210 }
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
211
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
212 int purple_log_get_total_size(PurpleLogType type, const char *name, PurpleAccount *account)
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
213 {
9677
1e4f158006e1 [gaim-migrate @ 10529]
Nathan Walp <nwalp@pidgin.im>
parents: 9613
diff changeset
214 gpointer ptrsize;
1e4f158006e1 [gaim-migrate @ 10529]
Nathan Walp <nwalp@pidgin.im>
parents: 9613
diff changeset
215 int size = 0;
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
216 GSList *n;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
217 struct _purple_logsize_user *lu;
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
218
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
219 lu = g_new(struct _purple_logsize_user, 1);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
220 lu->name = g_strdup(purple_normalize(account, name));
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
221 lu->account = account;
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
222
9677
1e4f158006e1 [gaim-migrate @ 10529]
Nathan Walp <nwalp@pidgin.im>
parents: 9613
diff changeset
223 if(g_hash_table_lookup_extended(logsize_users, lu, NULL, &ptrsize)) {
1e4f158006e1 [gaim-migrate @ 10529]
Nathan Walp <nwalp@pidgin.im>
parents: 9613
diff changeset
224 size = GPOINTER_TO_INT(ptrsize);
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
225 g_free(lu->name);
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
226 g_free(lu);
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
227 } else {
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
228 for (n = loggers; n; n = n->next) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
229 PurpleLogLogger *logger = n->data;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
230
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
231 if(logger->total_size){
8898
85f5615bc27e [gaim-migrate @ 9667]
Mark Doliner <markdoliner@pidgin.im>
parents: 8635
diff changeset
232 size += (logger->total_size)(type, name, account);
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
233 } else if(logger->list) {
8898
85f5615bc27e [gaim-migrate @ 9667]
Mark Doliner <markdoliner@pidgin.im>
parents: 8635
diff changeset
234 GList *logs = (logger->list)(type, name, account);
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
235 int this_size = 0;
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
236
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
237 while (logs) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
238 PurpleLog *log = (PurpleLog*)(logs->data);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
239 this_size += purple_log_get_size(log);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
240 purple_log_free(log);
13568
406e8503a006 [gaim-migrate @ 15946]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13520
diff changeset
241 logs = g_list_delete_link(logs, logs);
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
242 }
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
243
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
244 size += this_size;
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
245 }
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
246 }
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
247
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
248 g_hash_table_replace(logsize_users, lu, GINT_TO_POINTER(size));
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
249 }
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
250 return size;
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
251 }
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
252
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
253 gboolean purple_log_is_deletable(PurpleLog *log)
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
254 {
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
255 g_return_val_if_fail(log != NULL, FALSE);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
256 g_return_val_if_fail(log->logger != NULL, FALSE);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
257
16116
bccaa68c86ad "delete" is a reserved word in C++, rename the "delete" member of
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 15981
diff changeset
258 if (log->logger->remove == NULL)
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
259 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
260
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
261 if (log->logger->is_deletable != NULL)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
262 return log->logger->is_deletable(log);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
263
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
264 return TRUE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
265 }
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
266
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
267 gboolean purple_log_delete(PurpleLog *log)
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
268 {
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
269 g_return_val_if_fail(log != NULL, FALSE);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
270 g_return_val_if_fail(log->logger != NULL, FALSE);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
271
16116
bccaa68c86ad "delete" is a reserved word in C++, rename the "delete" member of
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 15981
diff changeset
272 if (log->logger->remove != NULL)
bccaa68c86ad "delete" is a reserved word in C++, rename the "delete" member of
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 15981
diff changeset
273 return log->logger->remove(log);
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
274
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
275 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
276 }
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
277
10822
142911801a14 [gaim-migrate @ 12484]
Kevin Stange <kstange@pidgin.im>
parents: 10735
diff changeset
278 char *
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
279 purple_log_get_log_dir(PurpleLogType type, const char *name, PurpleAccount *account)
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
280 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
281 PurplePlugin *prpl;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
282 PurplePluginProtocolInfo *prpl_info;
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
283 const char *prpl_name;
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
284 char *acct_name;
9926
9957e01fd88a [gaim-migrate @ 10818]
Nathan Walp <nwalp@pidgin.im>
parents: 9923
diff changeset
285 const char *target;
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
286 char *dir;
9926
9957e01fd88a [gaim-migrate @ 10818]
Nathan Walp <nwalp@pidgin.im>
parents: 9923
diff changeset
287
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
288 prpl = purple_find_prpl(purple_account_get_protocol_id(account));
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
289 if (!prpl)
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
290 return NULL;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
291 prpl_info = PURPLE_PLUGIN_PROTOCOL_INFO(prpl);
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
292 prpl_name = prpl_info->list_icon(account, NULL);
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
293
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
294 acct_name = g_strdup(purple_escape_filename(purple_normalize(account,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
295 purple_account_get_username(account))));
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
296
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
297 if (type == PURPLE_LOG_CHAT) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
298 char *temp = g_strdup_printf("%s.chat", purple_normalize(account, name));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
299 target = purple_escape_filename(temp);
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
300 g_free(temp);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
301 } else if(type == PURPLE_LOG_SYSTEM) {
9926
9957e01fd88a [gaim-migrate @ 10818]
Nathan Walp <nwalp@pidgin.im>
parents: 9923
diff changeset
302 target = ".system";
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
303 } else {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
304 target = purple_escape_filename(purple_normalize(account, name));
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
305 }
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
306
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
307 dir = g_build_filename(purple_user_dir(), "logs", prpl_name, acct_name, target, NULL);
9926
9957e01fd88a [gaim-migrate @ 10818]
Nathan Walp <nwalp@pidgin.im>
parents: 9923
diff changeset
308
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
309 g_free(acct_name);
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
310
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
311 return dir;
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
312 }
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
313
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
314 /****************************************************************************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
315 * LOGGER FUNCTIONS *********************************************************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
316 ****************************************************************************/
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
317
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
318 static PurpleLogLogger *current_logger = NULL;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
319
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
320 static void logger_pref_cb(const char *name, PurplePrefType type,
12816
5f93e09fa9a6 [gaim-migrate @ 15164]
Mark Doliner <markdoliner@pidgin.im>
parents: 12738
diff changeset
321 gconstpointer value, gpointer data)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
322 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
323 PurpleLogLogger *logger;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
324 GSList *l = loggers;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
325 while (l) {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
326 logger = l->data;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
327 if (!strcmp(logger->id, value)) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
328 purple_log_logger_set(logger);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
329 return;
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
330 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
331 l = l->next;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
332 }
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
333 purple_log_logger_set(txt_logger);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
334 }
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
335
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
336
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
337 PurpleLogLogger *purple_log_logger_new(const char *id, const char *name, int functions, ...)
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
338 {
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
339 #if 0
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
340 void(*create)(PurpleLog *),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
341 gsize(*write)(PurpleLog *, PurpleMessageFlags, const char *, time_t, const char *),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
342 void(*finalize)(PurpleLog *),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
343 GList*(*list)(PurpleLogType type, const char*, PurpleAccount*),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
344 char*(*read)(PurpleLog*, PurpleLogReadFlags*),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
345 int(*size)(PurpleLog*),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
346 int(*total_size)(PurpleLogType type, const char *name, PurpleAccount *account),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
347 GList*(*list_syslog)(PurpleAccount *account),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
348 void(*get_log_sets)(PurpleLogSetCallback cb, GHashTable *sets),
16116
bccaa68c86ad "delete" is a reserved word in C++, rename the "delete" member of
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 15981
diff changeset
349 gboolean(*remove)(PurpleLog *log),
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
350 gboolean(*is_deletable)(PurpleLog *log))
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
351 {
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
352 #endif
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
353 PurpleLogLogger *logger;
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
354 va_list args;
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
355
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
356 g_return_val_if_fail(id != NULL, NULL);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
357 g_return_val_if_fail(name != NULL, NULL);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
358 g_return_val_if_fail(functions >= 1, NULL);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
359
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
360 logger = g_new0(PurpleLogLogger, 1);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
361 logger->id = g_strdup(id);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
362 logger->name = g_strdup(name);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
363
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
364 va_start(args, functions);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
365
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
366 if (functions >= 1)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
367 logger->create = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
368 if (functions >= 2)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
369 logger->write = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
370 if (functions >= 3)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
371 logger->finalize = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
372 if (functions >= 4)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
373 logger->list = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
374 if (functions >= 5)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
375 logger->read = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
376 if (functions >= 6)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
377 logger->size = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
378 if (functions >= 7)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
379 logger->total_size = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
380 if (functions >= 8)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
381 logger->list_syslog = va_arg(args, void *);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
382 if (functions >= 9)
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
383 logger->get_log_sets = va_arg(args, void *);
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
384 if (functions >= 10)
16116
bccaa68c86ad "delete" is a reserved word in C++, rename the "delete" member of
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 15981
diff changeset
385 logger->remove = va_arg(args, void *);
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
386 if (functions >= 11)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
387 logger->is_deletable = va_arg(args, void *);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
388
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
389 if (functions >= 12)
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
390 purple_debug_info("log", "Dropping new functions for logger: %s (%s)\n", name, id);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
391
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
392 va_end(args);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
393
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
394 return logger;
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
395 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
396
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
397 void purple_log_logger_free(PurpleLogLogger *logger)
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
398 {
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
399 g_free(logger->name);
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
400 g_free(logger->id);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
401 g_free(logger);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
402 }
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
403
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
404 void purple_log_logger_add (PurpleLogLogger *logger)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
405 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
406 g_return_if_fail(logger);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
407 if (g_slist_find(loggers, logger))
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
408 return;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
409 loggers = g_slist_append(loggers, logger);
18166
3edbd0ef7f1f Custom logger selection doesn't work after a restart. To fix this, we do a
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 18152
diff changeset
410 if (strcmp(purple_prefs_get_string("/purple/logging/format"), logger->id) == 0) {
3edbd0ef7f1f Custom logger selection doesn't work after a restart. To fix this, we do a
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 18152
diff changeset
411 purple_prefs_trigger_callback("/purple/logging/format");
3edbd0ef7f1f Custom logger selection doesn't work after a restart. To fix this, we do a
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 18152
diff changeset
412 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
413 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
414
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
415 void purple_log_logger_remove (PurpleLogLogger *logger)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
416 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
417 g_return_if_fail(logger);
12574
3c80324a3ea5 [gaim-migrate @ 14896]
Mark Doliner <markdoliner@pidgin.im>
parents: 12241
diff changeset
418 loggers = g_slist_remove(loggers, logger);
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
419 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
420
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
421 void purple_log_logger_set (PurpleLogLogger *logger)
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
422 {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
423 g_return_if_fail(logger);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
424 current_logger = logger;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
425 }
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
426
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
427 PurpleLogLogger *purple_log_logger_get()
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
428 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
429 return current_logger;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
430 }
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
431
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
432 GList *purple_log_logger_get_options(void)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
433 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
434 GSList *n;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
435 GList *list = NULL;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
436 PurpleLogLogger *data;
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
437
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
438 for (n = loggers; n; n = n->next) {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
439 data = n->data;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
440 if (!data->write)
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
441 continue;
12241
29b388429db5 [gaim-migrate @ 14543]
Richard Laager <rlaager@pidgin.im>
parents: 12240
diff changeset
442 list = g_list_append(list, data->name);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
443 list = g_list_append(list, data->id);
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
444 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
445
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
446 return list;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
447 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
448
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
449 gint purple_log_compare(gconstpointer y, gconstpointer z)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
450 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
451 const PurpleLog *a = y;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
452 const PurpleLog *b = z;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
453
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
454 return b->time - a->time;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
455 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
456
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
457 GList *purple_log_get_logs(PurpleLogType type, const char *name, PurpleAccount *account)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
458 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
459 GList *logs = NULL;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
460 GSList *n;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
461 for (n = loggers; n; n = n->next) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
462 PurpleLogLogger *logger = n->data;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
463 if (!logger->list)
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
464 continue;
11703
6b22ef099870 [gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents: 11698
diff changeset
465 logs = g_list_concat(logger->list(type, name, account), logs);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
466 }
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
467
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
468 return g_list_sort(logs, purple_log_compare);
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
469 }
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
470
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
471 gint purple_log_set_compare(gconstpointer y, gconstpointer z)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
472 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
473 const PurpleLogSet *a = y;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
474 const PurpleLogSet *b = z;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
475 gint ret = 0;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
476
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
477 /* This logic seems weird at first...
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
478 * If either account is NULL, we pretend the accounts are
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
479 * equal. This allows us to detect duplicates that will
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
480 * exist if one logger knows the account and another
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
481 * doesn't. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
482 if (a->account != NULL && b->account != NULL) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
483 ret = strcmp(purple_account_get_username(a->account), purple_account_get_username(b->account));
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
484 if (ret != 0)
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
485 return ret;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
486 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
487
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
488 ret = strcmp(a->normalized_name, b->normalized_name);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
489 if (ret != 0)
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
490 return ret;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
491
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
492 return (gint)b->type - (gint)a->type;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
493 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
494
11677
89c2ab8d2ebf [gaim-migrate @ 13963]
Mark Doliner <markdoliner@pidgin.im>
parents: 11503
diff changeset
495 static guint
89c2ab8d2ebf [gaim-migrate @ 13963]
Mark Doliner <markdoliner@pidgin.im>
parents: 11503
diff changeset
496 log_set_hash(gconstpointer key)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
497 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
498 const PurpleLogSet *set = key;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
499
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
500 /* The account isn't hashed because we need PurpleLogSets with NULL accounts
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
501 * to be found when we search by a PurpleLogSet that has a non-NULL account
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
502 * but the same type and name. */
15483
bfcce3ec6848 Patch #1600087 from Richard 'wabz' Nelson: "Don't include a buddy's name when logging error/raw messages"
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 15444
diff changeset
503 return g_int_hash(&set->type) + g_str_hash(set->name);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
504 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
505
11677
89c2ab8d2ebf [gaim-migrate @ 13963]
Mark Doliner <markdoliner@pidgin.im>
parents: 11503
diff changeset
506 static gboolean
89c2ab8d2ebf [gaim-migrate @ 13963]
Mark Doliner <markdoliner@pidgin.im>
parents: 11503
diff changeset
507 log_set_equal(gconstpointer a, gconstpointer b)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
508 {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
509 /* I realize that the choices made for GList and GHashTable
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
510 * make sense for those data types, but I wish the comparison
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
511 * functions were compatible. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
512 return !purple_log_set_compare(a, b);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
513 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
514
11677
89c2ab8d2ebf [gaim-migrate @ 13963]
Mark Doliner <markdoliner@pidgin.im>
parents: 11503
diff changeset
515 static void
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
516 log_add_log_set_to_hash(GHashTable *sets, PurpleLogSet *set)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
517 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
518 PurpleLogSet *existing_set = g_hash_table_lookup(sets, set);
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
519
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
520 if (existing_set == NULL)
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
521 g_hash_table_insert(sets, set, set);
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
522 else if (existing_set->account == NULL && set->account != NULL)
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
523 g_hash_table_replace(sets, set, set);
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
524 else
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
525 purple_log_set_free(set);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
526 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
527
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
528 GHashTable *purple_log_get_log_sets(void)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
529 {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
530 GSList *n;
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
531 GHashTable *sets = g_hash_table_new_full(log_set_hash, log_set_equal,
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
532 (GDestroyNotify)purple_log_set_free, NULL);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
533
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
534 /* Get the log sets from all the loggers. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
535 for (n = loggers; n; n = n->next) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
536 PurpleLogLogger *logger = n->data;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
537
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
538 if (!logger->get_log_sets)
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
539 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
540
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
541 logger->get_log_sets(log_add_log_set_to_hash, sets);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
542 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
543
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
544 log_get_log_sets_common(sets);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
545
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
546 /* Return the GHashTable of unique PurpleLogSets. */
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
547 return sets;
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
548 }
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
549
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
550 void purple_log_set_free(PurpleLogSet *set)
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
551 {
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
552 g_return_if_fail(set != NULL);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
553
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
554 g_free(set->name);
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
555 if (set->normalized_name != set->name)
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
556 g_free(set->normalized_name);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
557
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
558 g_slice_free(PurpleLogSet, set);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
559 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
560
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
561 GList *purple_log_get_system_logs(PurpleAccount *account)
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
562 {
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
563 GList *logs = NULL;
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
564 GSList *n;
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
565 for (n = loggers; n; n = n->next) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
566 PurpleLogLogger *logger = n->data;
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
567 if (!logger->list_syslog)
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
568 continue;
11703
6b22ef099870 [gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents: 11698
diff changeset
569 logs = g_list_concat(logger->list_syslog(account), logs);
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
570 }
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
571
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
572 return g_list_sort(logs, purple_log_compare);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
573 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
574
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
575 /****************************************************************************
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
576 * LOG SUBSYSTEM ************************************************************
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
577 ****************************************************************************/
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
578
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
579 void *
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
580 purple_log_get_handle(void)
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
581 {
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
582 static int handle;
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
583
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
584 return &handle;
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
585 }
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
586
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
587 void purple_log_init(void)
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
588 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
589 void *handle = purple_log_get_handle();
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
590
16478
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
591 purple_prefs_add_none("/purple/logging");
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
592 purple_prefs_add_bool("/purple/logging/log_ims", FALSE);
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
593 purple_prefs_add_bool("/purple/logging/log_chats", FALSE);
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
594 purple_prefs_add_bool("/purple/logging/log_system", FALSE);
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
595
16478
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
596 purple_prefs_add_string("/purple/logging/format", "txt");
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
597
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
598 html_logger = purple_log_logger_new("html", _("HTML"), 11,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
599 NULL,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
600 html_logger_write,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
601 html_logger_finalize,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
602 html_logger_list,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
603 html_logger_read,
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
604 purple_log_common_sizer,
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
605 html_logger_total_size,
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
606 html_logger_list_syslog,
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
607 NULL,
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
608 purple_log_common_deleter,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
609 purple_log_common_is_deletable);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
610 purple_log_logger_add(html_logger);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
611
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
612 txt_logger = purple_log_logger_new("txt", _("Plain text"), 11,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
613 NULL,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
614 txt_logger_write,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
615 txt_logger_finalize,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
616 txt_logger_list,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
617 txt_logger_read,
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
618 purple_log_common_sizer,
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
619 txt_logger_total_size,
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
620 txt_logger_list_syslog,
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
621 NULL,
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
622 purple_log_common_deleter,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
623 purple_log_common_is_deletable);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
624 purple_log_logger_add(txt_logger);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
625
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
626 old_logger = purple_log_logger_new("old", _("Old flat format"), 9,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
627 NULL,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
628 NULL,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
629 old_logger_finalize,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
630 old_logger_list,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
631 old_logger_read,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
632 old_logger_size,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
633 old_logger_total_size,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
634 NULL,
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
635 old_logger_get_log_sets);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
636 purple_log_logger_add(old_logger);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
637
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
638 purple_signal_register(handle, "log-timestamp",
14057
e49b2ca2f5e6 [gaim-migrate @ 16573]
Sean Egan <seanegan@pidgin.im>
parents: 14056
diff changeset
639 #if SIZEOF_TIME_T == 4
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
640 purple_marshal_POINTER__POINTER_INT_BOOLEAN,
14057
e49b2ca2f5e6 [gaim-migrate @ 16573]
Sean Egan <seanegan@pidgin.im>
parents: 14056
diff changeset
641 #elif SIZEOF_TIME_T == 8
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
642 purple_marshal_POINTER__POINTER_INT64_BOOLEAN,
14057
e49b2ca2f5e6 [gaim-migrate @ 16573]
Sean Egan <seanegan@pidgin.im>
parents: 14056
diff changeset
643 #else
e49b2ca2f5e6 [gaim-migrate @ 16573]
Sean Egan <seanegan@pidgin.im>
parents: 14056
diff changeset
644 #error Unknown size of time_t
e49b2ca2f5e6 [gaim-migrate @ 16573]
Sean Egan <seanegan@pidgin.im>
parents: 14056
diff changeset
645 #endif
15981
23dede2805a0 Fix a one time memleak of 24 bytes. purple_log_init() was passing
Mark Doliner <markdoliner@pidgin.im>
parents: 15884
diff changeset
646 purple_value_new(PURPLE_TYPE_STRING), 3,
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
647 purple_value_new(PURPLE_TYPE_SUBTYPE,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
648 PURPLE_SUBTYPE_LOG),
14054
20b2d18319cb [gaim-migrate @ 16566]
Richard Laager <rlaager@pidgin.im>
parents: 14049
diff changeset
649 #if SIZEOF_TIME_T == 4
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
650 purple_value_new(PURPLE_TYPE_INT),
14068
57ba332d37fc [gaim-migrate @ 16591]
Richard Laager <rlaager@pidgin.im>
parents: 14057
diff changeset
651 #elif SIZEOF_TIME_T == 8
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
652 purple_value_new(PURPLE_TYPE_INT64),
14054
20b2d18319cb [gaim-migrate @ 16566]
Richard Laager <rlaager@pidgin.im>
parents: 14049
diff changeset
653 #else
20b2d18319cb [gaim-migrate @ 16566]
Richard Laager <rlaager@pidgin.im>
parents: 14049
diff changeset
654 # error Unknown size of time_t
20b2d18319cb [gaim-migrate @ 16566]
Richard Laager <rlaager@pidgin.im>
parents: 14049
diff changeset
655 #endif
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
656 purple_value_new(PURPLE_TYPE_BOOLEAN));
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
657
16478
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
658 purple_prefs_connect_callback(NULL, "/purple/logging/format",
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
659 logger_pref_cb, NULL);
16478
19107605c565 Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@pidgin.im>
parents: 16116
diff changeset
660 purple_prefs_trigger_callback("/purple/logging/format");
8635
a0c7f0bfedfa [gaim-migrate @ 9387]
Nathan Walp <nwalp@pidgin.im>
parents: 8619
diff changeset
661
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
662 logsize_users = g_hash_table_new_full((GHashFunc)_purple_logsize_user_hash,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
663 (GEqualFunc)_purple_logsize_user_equal,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
664 (GDestroyNotify)_purple_logsize_user_free_key, NULL);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
665 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
666
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
667 void
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
668 purple_log_uninit(void)
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
669 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
670 purple_signals_unregister_by_instance(purple_log_get_handle());
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
671 }
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
672
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
673 /****************************************************************************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
674 * LOGGERS ******************************************************************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
675 ****************************************************************************/
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
676
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
677 static char *log_get_timestamp(PurpleLog *log, time_t when)
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
678 {
15575
bd1e13b63e4b In Pidgin, display a full date on the timestamp of the first message to
Richard Laager <rlaager@pidgin.im>
parents: 15483
diff changeset
679 gboolean show_date;
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
680 char *date;
14049
c15c41423e19 [gaim-migrate @ 16559]
Richard Laager <rlaager@pidgin.im>
parents: 14036
diff changeset
681 struct tm tm;
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
682
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
683 show_date = (log->type == PURPLE_LOG_SYSTEM) || (time(NULL) > when + 20*60);
15575
bd1e13b63e4b In Pidgin, display a full date on the timestamp of the first message to
Richard Laager <rlaager@pidgin.im>
parents: 15483
diff changeset
684
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
685 date = purple_signal_emit_return_1(purple_log_get_handle(),
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
686 "log-timestamp",
15575
bd1e13b63e4b In Pidgin, display a full date on the timestamp of the first message to
Richard Laager <rlaager@pidgin.im>
parents: 15483
diff changeset
687 log, when, show_date);
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
688 if (date != NULL)
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
689 return date;
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
690
14049
c15c41423e19 [gaim-migrate @ 16559]
Richard Laager <rlaager@pidgin.im>
parents: 14036
diff changeset
691 tm = *(localtime(&when));
15575
bd1e13b63e4b In Pidgin, display a full date on the timestamp of the first message to
Richard Laager <rlaager@pidgin.im>
parents: 15483
diff changeset
692 if (show_date)
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
693 return g_strdup(purple_date_format_long(&tm));
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
694 else
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
695 return g_strdup(purple_time_format(&tm));
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
696 }
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
697
18101
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
698 /* NOTE: This can return msg (which you may or may not want to g_free())
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
699 * NOTE: or a newly allocated string which you MUST g_free(). */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
700 static char *
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
701 convert_image_tags(const PurpleLog *log, const char *msg)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
702 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
703 const char *tmp;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
704 const char *start;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
705 const char *end;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
706 GData *attributes;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
707 GString *newmsg = NULL;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
708
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
709 tmp = msg;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
710
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
711 while (purple_markup_find_tag("img", tmp, &start, &end, &attributes)) {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
712 int imgid = 0;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
713 char *idstr = NULL;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
714
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
715 if (newmsg == NULL)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
716 newmsg = g_string_new("");
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
717
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
718 /* copy any text before the img tag */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
719 if (tmp < start)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
720 g_string_append_len(newmsg, tmp, start - tmp);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
721
19224
d4f5029288a6 bug fix
Daniel Atallah <datallah@pidgin.im>
parents: 18186
diff changeset
722 if ((idstr = g_datalist_get_data(&attributes, "id")) != NULL)
d4f5029288a6 bug fix
Daniel Atallah <datallah@pidgin.im>
parents: 18186
diff changeset
723 imgid = atoi(idstr);
18101
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
724
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
725 if (imgid != 0)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
726 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
727 FILE *image_file;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
728 char *dir;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
729 PurpleStoredImage *image;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
730 gconstpointer image_data;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
731 char *new_filename = NULL;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
732 char *path = NULL;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
733 size_t image_byte_count;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
734
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
735 image = purple_imgstore_find_by_id(imgid);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
736 if (image == NULL)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
737 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
738 /* This should never happen. */
19224
d4f5029288a6 bug fix
Daniel Atallah <datallah@pidgin.im>
parents: 18186
diff changeset
739 /* This *does* happen for failed Direct-IMs -DAA */
18101
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
740 g_string_free(newmsg, TRUE);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
741 g_return_val_if_reached((char *)msg);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
742 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
743
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
744 image_data = purple_imgstore_get_data(image);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
745 image_byte_count = purple_imgstore_get_size(image);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
746 dir = purple_log_get_log_dir(log->type, log->name, log->account);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
747 new_filename = purple_util_get_image_filename(image_data, image_byte_count);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
748
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
749 path = g_build_filename(dir, new_filename, NULL);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
750
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
751 /* Only save unique files. */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
752 if (!g_file_test(path, G_FILE_TEST_EXISTS))
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
753 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
754 if ((image_file = g_fopen(path, "wb")) != NULL)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
755 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
756 if (!fwrite(image_data, image_byte_count, 1, image_file))
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
757 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
758 purple_debug_error("log", "Error writing %s: %s\n",
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
759 path, strerror(errno));
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
760 fclose(image_file);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
761
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
762 /* Attempt to not leave half-written files around. */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
763 unlink(path);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
764 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
765 else
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
766 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
767 purple_debug_info("log", "Wrote image file: %s\n", path);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
768 fclose(image_file);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
769 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
770 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
771 else
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
772 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
773 purple_debug_error("log", "Unable to create file %s: %s\n",
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
774 path, strerror(errno));
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
775 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
776 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
777
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
778 /* Write the new image tag */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
779 g_string_append_printf(newmsg, "<IMG SRC=\"%s\">", new_filename);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
780 g_free(new_filename);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
781 g_free(path);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
782 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
783
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
784 /* Continue from the end of the tag */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
785 tmp = end + 1;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
786 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
787
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
788 if (newmsg == NULL)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
789 {
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
790 /* No images were found to change. */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
791 return (char *)msg;
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
792 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
793
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
794 /* Append any remaining message data */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
795 g_string_append(newmsg, tmp);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
796
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
797 return g_string_free(newmsg, FALSE);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
798 }
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
799
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
800 void purple_log_common_writer(PurpleLog *log, const char *ext)
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
801 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
802 PurpleLogCommonLoggerData *data = log->logger_data;
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
803
11292
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
804 if (data == NULL)
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
805 {
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
806 /* This log is new */
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
807 char *dir;
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
808 struct tm *tm;
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
809 const char *tz;
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
810 const char *date;
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
811 char *filename;
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
812 char *path;
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
813
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
814 dir = purple_log_get_log_dir(log->type, log->name, log->account);
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
815 if (dir == NULL)
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
816 return;
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
817
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
818 purple_build_dir (dir, S_IRUSR | S_IWUSR | S_IXUSR);
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
819
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
820 tm = localtime(&log->time);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
821 tz = purple_escape_filename(purple_utf8_strftime("%Z", tm));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
822 date = purple_utf8_strftime("%Y-%m-%d.%H%M%S%z", tm);
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
823
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
824 filename = g_strdup_printf("%s%s%s", date, tz, ext ? ext : "");
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
825
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
826 path = g_build_filename(dir, filename, NULL);
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
827 g_free(dir);
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
828 g_free(filename);
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
829
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
830 log->logger_data = data = g_slice_new0(PurpleLogCommonLoggerData);
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
831
10589
4e10236e06d4 [gaim-migrate @ 11994]
Daniel Atallah <datallah@pidgin.im>
parents: 10577
diff changeset
832 data->file = g_fopen(path, "a");
11292
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
833 if (data->file == NULL)
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
834 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
835 purple_debug(PURPLE_DEBUG_ERROR, "log",
9892
281f62b8824e [gaim-migrate @ 10780]
Luke Schierer <lschiere@pidgin.im>
parents: 9883
diff changeset
836 "Could not create log file %s\n", path);
11292
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
837
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
838 if (log->conv != NULL)
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
839 purple_conversation_write(log->conv, NULL, _("Logging of this conversation failed."),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
840 PURPLE_MESSAGE_ERROR, time(NULL));
11292
13068c68def6 [gaim-migrate @ 13492]
Richard Laager <rlaager@pidgin.im>
parents: 11256
diff changeset
841
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
842 g_free(path);
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
843 return;
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
844 }
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
845 g_free(path);
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
846 }
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
847 }
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
848
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
849 GList *purple_log_common_lister(PurpleLogType type, const char *name, PurpleAccount *account, const char *ext, PurpleLogLogger *logger)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
850 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
851 GDir *dir;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
852 GList *list = NULL;
13160
8177a80d9e27 [gaim-migrate @ 15522]
Richard Laager <rlaager@pidgin.im>
parents: 13157
diff changeset
853 const char *filename;
8111
8c8fa8901d53 [gaim-migrate @ 8812]
Nathan Walp <nwalp@pidgin.im>
parents: 8096
diff changeset
854 char *path;
8c8fa8901d53 [gaim-migrate @ 8812]
Nathan Walp <nwalp@pidgin.im>
parents: 8096
diff changeset
855
8c8fa8901d53 [gaim-migrate @ 8812]
Nathan Walp <nwalp@pidgin.im>
parents: 8096
diff changeset
856 if(!account)
8c8fa8901d53 [gaim-migrate @ 8812]
Nathan Walp <nwalp@pidgin.im>
parents: 8096
diff changeset
857 return NULL;
8c8fa8901d53 [gaim-migrate @ 8812]
Nathan Walp <nwalp@pidgin.im>
parents: 8096
diff changeset
858
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
859 path = purple_log_get_log_dir(type, name, account);
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
860 if (path == NULL)
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
861 return NULL;
7447
4876aeb16c60 [gaim-migrate @ 8058]
Mark Doliner <markdoliner@pidgin.im>
parents: 7443
diff changeset
862
12969
823d3591438c [gaim-migrate @ 15322]
Richard Laager <rlaager@pidgin.im>
parents: 12958
diff changeset
863 if (!(dir = g_dir_open(path, 0, NULL)))
823d3591438c [gaim-migrate @ 15322]
Richard Laager <rlaager@pidgin.im>
parents: 12958
diff changeset
864 {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
865 g_free(path);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
866 return NULL;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
867 }
8898
85f5615bc27e [gaim-migrate @ 9667]
Mark Doliner <markdoliner@pidgin.im>
parents: 8635
diff changeset
868
13160
8177a80d9e27 [gaim-migrate @ 15522]
Richard Laager <rlaager@pidgin.im>
parents: 13157
diff changeset
869 while ((filename = g_dir_read_name(dir)))
12969
823d3591438c [gaim-migrate @ 15322]
Richard Laager <rlaager@pidgin.im>
parents: 12958
diff changeset
870 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
871 if (purple_str_has_suffix(filename, ext) &&
12969
823d3591438c [gaim-migrate @ 15322]
Richard Laager <rlaager@pidgin.im>
parents: 12958
diff changeset
872 strlen(filename) >= (17 + strlen(ext)))
823d3591438c [gaim-migrate @ 15322]
Richard Laager <rlaager@pidgin.im>
parents: 12958
diff changeset
873 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
874 PurpleLog *log;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
875 PurpleLogCommonLoggerData *data;
13582
54ac10e3c3cc [gaim-migrate @ 15963]
Richard Laager <rlaager@pidgin.im>
parents: 13568
diff changeset
876 struct tm tm;
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
877 #if defined (HAVE_TM_GMTOFF) && defined (HAVE_STRUCT_TM_TM_ZONE)
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
878 long tz_off;
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
879 const char *rest;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
880 time_t stamp = purple_str_to_time(purple_unescape_filename(filename), FALSE, &tm, &tz_off, &rest);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
881 char *end;
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
882
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
883 /* As zero is a valid offset, PURPLE_NO_TZ_OFF means no offset was
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
884 * provided. See util.h. Yes, it's kinda ugly. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
885 if (tz_off != PURPLE_NO_TZ_OFF)
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
886 tm.tm_gmtoff = tz_off - tm.tm_gmtoff;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
887
17005
ee9efeb18039 Fix log viewer crash when the log filename is doesn't contain a date in the expected format. Fixes #588.
Daniel Atallah <datallah@pidgin.im>
parents: 16478
diff changeset
888 if (stamp == 0 || rest == NULL || (end = strchr(rest, '.')) == NULL || strchr(rest, ' ') != NULL)
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
889 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
890 log = purple_log_new(type, name, account, NULL, stamp, NULL);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
891 }
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
892 else
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
893 {
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
894 char *tmp = g_strndup(rest, end - rest);
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
895 tm.tm_zone = tmp;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
896 log = purple_log_new(type, name, account, NULL, stamp, &tm);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
897 g_free(tmp);
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
898 }
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
899 #else
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
900 time_t stamp = purple_str_to_time(filename, FALSE, &tm, NULL, NULL);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
901
17005
ee9efeb18039 Fix log viewer crash when the log filename is doesn't contain a date in the expected format. Fixes #588.
Daniel Atallah <datallah@pidgin.im>
parents: 16478
diff changeset
902 log = purple_log_new(type, name, account, NULL, stamp, (stamp != 0) ? &tm : NULL);
13120
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
903 #endif
c25222322810 [gaim-migrate @ 15481]
Richard Laager <rlaager@pidgin.im>
parents: 13107
diff changeset
904
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
905 log->logger = logger;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
906 log->logger_data = data = g_slice_new0(PurpleLogCommonLoggerData);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
907
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
908 data->path = g_build_filename(path, filename, NULL);
11703
6b22ef099870 [gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents: 11698
diff changeset
909 list = g_list_prepend(list, log);
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
910 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
911 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
912 g_dir_close(dir);
7447
4876aeb16c60 [gaim-migrate @ 8058]
Mark Doliner <markdoliner@pidgin.im>
parents: 7443
diff changeset
913 g_free(path);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
914 return list;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
915 }
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
916
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
917 int purple_log_common_total_sizer(PurpleLogType type, const char *name, PurpleAccount *account, const char *ext)
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
918 {
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
919 GDir *dir;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
920 int size = 0;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
921 const char *filename;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
922 char *path;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
923
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
924 if(!account)
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
925 return 0;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
926
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
927 path = purple_log_get_log_dir(type, name, account);
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
928 if (path == NULL)
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
929 return 0;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
930
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
931 if (!(dir = g_dir_open(path, 0, NULL)))
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
932 {
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
933 g_free(path);
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
934 return 0;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
935 }
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
936
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
937 while ((filename = g_dir_read_name(dir)))
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
938 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
939 if (purple_str_has_suffix(filename, ext) &&
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
940 strlen(filename) >= (17 + strlen(ext)))
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
941 {
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
942 char *tmp = g_build_filename(path, filename, NULL);
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
943 struct stat st;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
944 if (g_stat(tmp, &st))
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
945 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
946 purple_debug_error("log", "Error stating log file: %s\n", tmp);
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
947 g_free(tmp);
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
948 continue;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
949 }
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
950 g_free(tmp);
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
951 size += st.st_size;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
952 }
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
953 }
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
954 g_dir_close(dir);
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
955 g_free(path);
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
956 return size;
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
957 }
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
958
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
959 int purple_log_common_sizer(PurpleLog *log)
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
960 {
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
961 struct stat st;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
962 PurpleLogCommonLoggerData *data = log->logger_data;
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
963
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
964 g_return_val_if_fail(data != NULL, 0);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
965
10589
4e10236e06d4 [gaim-migrate @ 11994]
Daniel Atallah <datallah@pidgin.im>
parents: 10577
diff changeset
966 if (!data->path || g_stat(data->path, &st))
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
967 st.st_size = 0;
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
968
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
969 return st.st_size;
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
970 }
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
971
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
972 /* This will build log sets for all loggers that use the common logger
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
973 * functions because they use the same directory structure. */
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
974 static void log_get_log_sets_common(GHashTable *sets)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
975 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
976 gchar *log_path = g_build_filename(purple_user_dir(), "logs", NULL);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
977 GDir *log_dir = g_dir_open(log_path, 0, NULL);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
978 const gchar *protocol;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
979
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
980 if (log_dir == NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
981 g_free(log_path);
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
982 return;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
983 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
984
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
985 while ((protocol = g_dir_read_name(log_dir)) != NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
986 gchar *protocol_path = g_build_filename(log_path, protocol, NULL);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
987 GDir *protocol_dir;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
988 const gchar *username;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
989 gchar *protocol_unescaped;
18122
9bf9970c1b6a disapproval of revision '2d8ea56b90971e7851442d96b7d74ecb4f052126'
Richard Laager <rlaager@pidgin.im>
parents: 18121
diff changeset
990 GList *account_iter;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
991 GList *accounts = NULL;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
992
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
993 if ((protocol_dir = g_dir_open(protocol_path, 0, NULL)) == NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
994 g_free(protocol_path);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
995 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
996 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
997
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
998 /* Using g_strdup() to cover the one-in-a-million chance that a
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
999 * prpl's list_icon function uses purple_unescape_filename(). */
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1000 protocol_unescaped = g_strdup(purple_unescape_filename(protocol));
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1001
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1002 /* Find all the accounts for protocol. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1003 for (account_iter = purple_accounts_get_all() ; account_iter != NULL ; account_iter = account_iter->next) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1004 PurplePlugin *prpl;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1005 PurplePluginProtocolInfo *prpl_info;
14097
0c340861ab79 [gaim-migrate @ 16638]
Mark Doliner <markdoliner@pidgin.im>
parents: 14068
diff changeset
1006
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1007 prpl = purple_find_prpl(purple_account_get_protocol_id((PurpleAccount *)account_iter->data));
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1008 if (!prpl)
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1009 continue;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1010 prpl_info = PURPLE_PLUGIN_PROTOCOL_INFO(prpl);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1011
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1012 if (!strcmp(protocol_unescaped, prpl_info->list_icon((PurpleAccount *)account_iter->data, NULL)))
11703
6b22ef099870 [gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents: 11698
diff changeset
1013 accounts = g_list_prepend(accounts, account_iter->data);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1014 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1015 g_free(protocol_unescaped);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1016
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1017 while ((username = g_dir_read_name(protocol_dir)) != NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1018 gchar *username_path = g_build_filename(protocol_path, username, NULL);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1019 GDir *username_dir;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1020 const gchar *username_unescaped;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1021 PurpleAccount *account = NULL;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1022 gchar *name;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1023
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1024 if ((username_dir = g_dir_open(username_path, 0, NULL)) == NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1025 g_free(username_path);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1026 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1027 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1028
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1029 /* Find the account for username in the list of accounts for protocol. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1030 username_unescaped = purple_unescape_filename(username);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1031 for (account_iter = g_list_first(accounts) ; account_iter != NULL ; account_iter = account_iter->next) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1032 if (!strcmp(((PurpleAccount *)account_iter->data)->username, username_unescaped)) {
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1033 account = account_iter->data;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1034 break;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1035 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1036 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1037
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1038 /* Don't worry about the cast, name will point to dynamically allocated memory shortly. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1039 while ((name = (gchar *)g_dir_read_name(username_dir)) != NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1040 size_t len;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1041 PurpleLogSet *set;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1042
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1043 /* IMPORTANT: Always initialize all members of PurpleLogSet */
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1044 set = g_slice_new(PurpleLogSet);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1045
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1046 /* Unescape the filename. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1047 name = g_strdup(purple_unescape_filename(name));
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1048
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1049 /* Get the (possibly new) length of name. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1050 len = strlen(name);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1051
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1052 set->type = PURPLE_LOG_IM;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1053 set->name = name;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1054 set->account = account;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1055 /* set->buddy is always set below */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1056 set->normalized_name = g_strdup(purple_normalize(account, name));
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1057
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1058 /* Chat for .chat or .system at the end of the name to determine the type. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1059 if (len > 7) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1060 gchar *tmp = &name[len - 7];
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1061 if (!strcmp(tmp, ".system")) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1062 set->type = PURPLE_LOG_SYSTEM;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1063 *tmp = '\0';
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1064 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1065 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1066 if (len > 5) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1067 gchar *tmp = &name[len - 5];
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1068 if (!strcmp(tmp, ".chat")) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1069 set->type = PURPLE_LOG_CHAT;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1070 *tmp = '\0';
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1071 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1072 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1073
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1074 /* Determine if this (account, name) combination exists as a buddy. */
11458
68f0a3698528 [gaim-migrate @ 13697]
Richard Laager <rlaager@pidgin.im>
parents: 11292
diff changeset
1075 if (account != NULL)
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1076 set->buddy = (purple_find_buddy(account, name) != NULL);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1077 else
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1078 set->buddy = FALSE;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1079
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
1080 log_add_log_set_to_hash(sets, set);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1081 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1082 g_free(username_path);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1083 g_dir_close(username_dir);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1084 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1085 g_free(protocol_path);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1086 g_dir_close(protocol_dir);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1087 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1088 g_free(log_path);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1089 g_dir_close(log_dir);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1090 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1091
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1092 gboolean purple_log_common_deleter(PurpleLog *log)
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1093 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1094 PurpleLogCommonLoggerData *data;
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1095 int ret;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1096
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1097 g_return_val_if_fail(log != NULL, FALSE);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1098
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1099 data = log->logger_data;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1100 if (data == NULL)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1101 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1102
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1103 if (data->path == NULL)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1104 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1105
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1106 ret = g_unlink(data->path);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1107 if (ret == 0)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1108 return TRUE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1109 else if (ret == -1)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1110 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1111 purple_debug_error("log", "Failed to delete: %s - %s\n", data->path, strerror(errno));
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1112 }
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1113 else
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1114 {
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1115 /* I'm not sure that g_unlink() will ever return
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1116 * something other than 0 or -1. -- rlaager */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1117 purple_debug_error("log", "Failed to delete: %s\n", data->path);
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1118 }
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1119
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1120 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1121 }
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1122
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1123 gboolean purple_log_common_is_deletable(PurpleLog *log)
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1124 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1125 PurpleLogCommonLoggerData *data;
15676
5f5dc48279f4 Unused variables
Daniel Atallah <datallah@pidgin.im>
parents: 15595
diff changeset
1126 #ifndef _WIN32
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1127 gchar *dirname;
15676
5f5dc48279f4 Unused variables
Daniel Atallah <datallah@pidgin.im>
parents: 15595
diff changeset
1128 #endif
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1129
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1130 g_return_val_if_fail(log != NULL, FALSE);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1131
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1132 data = log->logger_data;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1133 if (data == NULL)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1134 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1135
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1136 if (data->path == NULL)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1137 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1138
15585
93dff667b2a3 I had the wrong arguments for gaim_log_logger_new(). It didn't work, but
Richard Laager <rlaager@pidgin.im>
parents: 15584
diff changeset
1139 #ifndef _WIN32
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1140 dirname = g_path_get_dirname(data->path);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1141 if (g_access(dirname, W_OK) == 0)
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1142 {
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1143 g_free(dirname);
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1144 return TRUE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1145 }
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1146 purple_debug_info("log", "access(%s) failed: %s\n", dirname, strerror(errno));
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1147 g_free(dirname);
15585
93dff667b2a3 I had the wrong arguments for gaim_log_logger_new(). It didn't work, but
Richard Laager <rlaager@pidgin.im>
parents: 15584
diff changeset
1148 #else
93dff667b2a3 I had the wrong arguments for gaim_log_logger_new(). It didn't work, but
Richard Laager <rlaager@pidgin.im>
parents: 15584
diff changeset
1149 /* Unless and until someone writes equivalent win32 code,
93dff667b2a3 I had the wrong arguments for gaim_log_logger_new(). It didn't work, but
Richard Laager <rlaager@pidgin.im>
parents: 15584
diff changeset
1150 * we'll assume the file is deletable. */
93dff667b2a3 I had the wrong arguments for gaim_log_logger_new(). It didn't work, but
Richard Laager <rlaager@pidgin.im>
parents: 15584
diff changeset
1151 return TRUE;
93dff667b2a3 I had the wrong arguments for gaim_log_logger_new(). It didn't work, but
Richard Laager <rlaager@pidgin.im>
parents: 15584
diff changeset
1152 #endif
15584
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1153
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1154 return FALSE;
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1155 }
f4d9ac6f94b8 This is the core code to support log deletion. It's untested.
Richard Laager <rlaager@pidgin.im>
parents: 15575
diff changeset
1156
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1157 static char *process_txt_log(char *txt, char *to_free)
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1158 {
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1159 char *tmp;
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1160
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1161 /* The to_free argument allows us to save a
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1162 * g_strdup() in some cases. */
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1163
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1164 if (to_free == NULL)
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1165 to_free = txt;
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1166
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1167 /* g_markup_escape_text requires valid UTF-8 */
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1168 if (!g_utf8_validate(txt, -1, NULL))
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1169 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1170 tmp = purple_utf8_salvage(txt);
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1171 g_free(to_free);
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1172 to_free = txt = tmp;
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1173 }
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1174
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1175 tmp = g_markup_escape_text(txt, -1);
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1176 g_free(to_free);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1177 txt = purple_markup_linkify(tmp);
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1178 g_free(tmp);
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1179
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1180 return txt;
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1181 }
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1182
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1183 #if 0 /* Maybe some other time. */
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1184 /****************
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1185 ** XML LOGGER **
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1186 ****************/
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1187
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1188 static const char *str_from_msg_type (PurpleMessageFlags type)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1189 {
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1190
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1191 return "";
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1192
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1193 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1194
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1195 static void xml_logger_write(PurpleLog *log,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1196 PurpleMessageFlags type,
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1197 const char *from, time_t time, const char *message)
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1198 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1199 char *xhtml = NULL;
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
1200
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1201 if (!log->logger_data) {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1202 /* This log is new. We could use the loggers 'new' function, but
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1203 * creating a new file there would result in empty files in the case
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1204 * that you open a convo with someone, but don't say anything.
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1205 */
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1206 struct tm *tm;
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1207 const char *tz;
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
1208 const char *date;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1209 char *dir = purple_log_get_log_dir(log->type, log->name, log->account);
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1210 char *name;
13155
fa27cdf2986e [gaim-migrate @ 15517]
Richard Laager <rlaager@pidgin.im>
parents: 13120
diff changeset
1211 char *filename;
10577
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
1212
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
1213 if (dir == NULL)
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
1214 return;
f27149d1cddf [gaim-migrate @ 11971]
Richard Laager <rlaager@pidgin.im>
parents: 10173
diff changeset
1215
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1216 tm = localtime(&log->time);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1217 tz = purple_escape_filename(purple_utf8_strftime("%Z", tm);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1218 date = purple_utf8_strftime("%Y-%m-%d.%H%M%S%z", tm);
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1219
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1220 name = g_strdup_printf("%s%s%s", date, tz, ext ? ext : "");
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1221
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1222 purple_build_dir (dir, S_IRUSR | S_IWUSR | S_IXUSR);
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1223
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1224 filename = g_build_filename(dir, name, NULL);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1225 g_free(dir);
13163
2026e49825df [gaim-migrate @ 15525]
Richard Laager <rlaager@pidgin.im>
parents: 13161
diff changeset
1226 g_free(name);
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1227
10589
4e10236e06d4 [gaim-migrate @ 11994]
Daniel Atallah <datallah@pidgin.im>
parents: 10577
diff changeset
1228 log->logger_data = g_fopen(filename, "a");
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1229 if (!log->logger_data) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1230 purple_debug(PURPLE_DEBUG_ERROR, "log", "Could not create log file %s\n", filename);
7564
baab99d239d8 [gaim-migrate @ 8180]
Nathan Walp <nwalp@pidgin.im>
parents: 7556
diff changeset
1231 g_free(filename);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1232 return;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1233 }
7564
baab99d239d8 [gaim-migrate @ 8180]
Nathan Walp <nwalp@pidgin.im>
parents: 7556
diff changeset
1234 g_free(filename);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1235 fprintf(log->logger_data, "<?xml version='1.0' encoding='UTF-8' ?>\n"
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1236 "<?xml-stylesheet href='file:///usr/src/web/htdocs/log-stylesheet.xsl' type='text/xml' ?>\n");
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1237
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1238 date = purple_utf8_strftime("%Y-%m-%d %H:%M:%S", localtime(&log->time));
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1239 fprintf(log->logger_data, "<conversation time='%s' screenname='%s' protocol='%s'>\n",
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1240 date, log->name, prpl);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1241 }
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1242
9923
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
1243 /* if we can't write to the file, give up before we hurt ourselves */
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
1244 if(!data->file)
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
1245 return;
f3060096e964 [gaim-migrate @ 10815]
Daniel Atallah <datallah@pidgin.im>
parents: 9892
diff changeset
1246
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1247 date = log_get_timestamp(log, time);
12692
249f9d844f6f [gaim-migrate @ 15035]
Douglas Thrift <douglas@douglasthrift.net>
parents: 12574
diff changeset
1248
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1249 purple_markup_html_to_xhtml(message, &xhtml, NULL);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1250 if (from)
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1251 fprintf(log->logger_data, "<message %s %s from='%s' time='%s'>%s</message>\n",
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1252 str_from_msg_type(type),
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1253 type & PURPLE_MESSAGE_SEND ? "direction='sent'" :
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1254 type & PURPLE_MESSAGE_RECV ? "direction='received'" : "",
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1255 from, date, xhtml);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1256 else
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1257 fprintf(log->logger_data, "<message %s %s time='%s'>%s</message>\n",
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1258 str_from_msg_type(type),
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1259 type & PURPLE_MESSAGE_SEND ? "direction='sent'" :
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1260 type & PURPLE_MESSAGE_RECV ? "direction='received'" : "",
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1261 date, xhtml):
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1262 fflush(log->logger_data);
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1263 g_free(date);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1264 g_free(xhtml);
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1265 }
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1266
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1267 static void xml_logger_finalize(PurpleLog *log)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1268 {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1269 if (log->logger_data) {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1270 fprintf(log->logger_data, "</conversation>\n");
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1271 fclose(log->logger_data);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1272 log->logger_data = NULL;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1273 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1274 }
7443
16eb71497755 [gaim-migrate @ 8048]
Luke Schierer <lschiere@pidgin.im>
parents: 7442
diff changeset
1275
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1276 static GList *xml_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1277 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1278 return purple_log_common_lister(type, sn, account, ".xml", &xml_logger);
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
1279 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
1280
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1281 static PurpleLogLogger xml_logger = {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1282 N_("XML"), "xml",
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1283 NULL,
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1284 xml_logger_write,
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1285 xml_logger_finalize,
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1286 xml_logger_list,
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1287 NULL,
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1288 NULL,
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1289 NULL
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1290 };
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1291 #endif
5563
d5a7852aa0cb [gaim-migrate @ 5965]
Christian Hammond <chipx86@chipx86.com>
parents: 5560
diff changeset
1292
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1293 /****************************
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1294 ** HTML LOGGER *************
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1295 ****************************/
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1296
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1297 static gsize html_logger_write(PurpleLog *log, PurpleMessageFlags type,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
1298 const char *from, time_t time, const char *message)
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1299 {
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1300 char *msg_fixed;
18101
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1301 char *image_corrected_msg;
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1302 char *date;
13514
735953c0929d [gaim-migrate @ 15889]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 13513
diff changeset
1303 char *header;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1304 PurplePlugin *plugin = purple_find_prpl(purple_account_get_protocol_id(log->account));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1305 PurpleLogCommonLoggerData *data = log->logger_data;
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1306 gsize written = 0;
9613
cd81e0c76ec0 [gaim-migrate @ 10456]
Kevin Stange <kstange@pidgin.im>
parents: 9592
diff changeset
1307
7618
b5ecf6d2c93b [gaim-migrate @ 8242]
Nathan Walp <nwalp@pidgin.im>
parents: 7616
diff changeset
1308 if(!data) {
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1309 const char *prpl =
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1310 PURPLE_PLUGIN_PROTOCOL_INFO(plugin)->list_icon(log->account, NULL);
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
1311 const char *date;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1312 purple_log_common_writer(log, ".html");
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1313
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1314 data = log->logger_data;
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1315
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1316 /* if we can't write to the file, give up before we hurt ourselves */
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1317 if(!data->file)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1318 return 0;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1319
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1320 date = purple_date_format_full(localtime(&log->time));
13105
8f9c66e4af87 [gaim-migrate @ 15466]
Richard Laager <rlaager@pidgin.im>
parents: 13078
diff changeset
1321
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1322 written += fprintf(data->file, "<html><head>");
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1323 written += fprintf(data->file, "<meta http-equiv=\"content-type\" content=\"text/html; charset=UTF-8\">");
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1324 written += fprintf(data->file, "<title>");
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1325 if (log->type == PURPLE_LOG_SYSTEM)
13514
735953c0929d [gaim-migrate @ 15889]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 13513
diff changeset
1326 header = g_strdup_printf("System log for account %s (%s) connected at %s",
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1327 purple_account_get_username(log->account), prpl, date);
13509
38ebac941c40 [gaim-migrate @ 15884]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13474
diff changeset
1328 else
13514
735953c0929d [gaim-migrate @ 15889]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 13513
diff changeset
1329 header = g_strdup_printf("Conversation with %s at %s on %s (%s)",
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1330 log->name, date, purple_account_get_username(log->account), prpl);
13509
38ebac941c40 [gaim-migrate @ 15884]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13474
diff changeset
1331
13514
735953c0929d [gaim-migrate @ 15889]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 13513
diff changeset
1332 written += fprintf(data->file, "%s", header);
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1333 written += fprintf(data->file, "</title></head><body>");
13509
38ebac941c40 [gaim-migrate @ 15884]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13474
diff changeset
1334 written += fprintf(data->file, "<h3>%s</h3>\n", header);
13514
735953c0929d [gaim-migrate @ 15889]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 13513
diff changeset
1335 g_free(header);
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1336 }
7623
ea9fc2f9c46b [gaim-migrate @ 8247]
Nathan Walp <nwalp@pidgin.im>
parents: 7618
diff changeset
1337
9892
281f62b8824e [gaim-migrate @ 10780]
Luke Schierer <lschiere@pidgin.im>
parents: 9883
diff changeset
1338 /* if we can't write to the file, give up before we hurt ourselves */
281f62b8824e [gaim-migrate @ 10780]
Luke Schierer <lschiere@pidgin.im>
parents: 9883
diff changeset
1339 if(!data->file)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1340 return 0;
9892
281f62b8824e [gaim-migrate @ 10780]
Luke Schierer <lschiere@pidgin.im>
parents: 9883
diff changeset
1341
18101
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1342 image_corrected_msg = convert_image_tags(log, message);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1343 purple_markup_html_to_xhtml(image_corrected_msg, &msg_fixed, NULL);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1344
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1345 /* Yes, this breaks encapsulation. But it's a static function and
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1346 * this saves a needless strdup(). */
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1347 if (image_corrected_msg != message)
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1348 g_free(image_corrected_msg);
3ce21b5a182c A patch from David Grohmann (dave1g) to log embedded images.
Richard Laager <rlaager@pidgin.im>
parents: 17005
diff changeset
1349
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1350 date = log_get_timestamp(log, time);
7882
7d95549fd6db [gaim-migrate @ 8536]
Nathan Walp <nwalp@pidgin.im>
parents: 7791
diff changeset
1351
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1352 if(log->type == PURPLE_LOG_SYSTEM){
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1353 written += fprintf(data->file, "---- %s @ %s ----<br/>\n", msg_fixed, date);
8577
64f25a17f8e4 [gaim-migrate @ 9326]
Nathan Walp <nwalp@pidgin.im>
parents: 8573
diff changeset
1354 } else {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1355 if (type & PURPLE_MESSAGE_SYSTEM)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1356 written += fprintf(data->file, "<font size=\"2\">(%s)</font><b> %s</b><br/>\n", date, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1357 else if (type & PURPLE_MESSAGE_RAW)
15483
bfcce3ec6848 Patch #1600087 from Richard 'wabz' Nelson: "Don't include a buddy's name when logging error/raw messages"
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 15444
diff changeset
1358 written += fprintf(data->file, "<font size=\"2\">(%s)</font> %s<br/>\n", date, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1359 else if (type & PURPLE_MESSAGE_ERROR)
13069
37b879f161f4 [gaim-migrate @ 15431]
Richard Laager <rlaager@pidgin.im>
parents: 13068
diff changeset
1360 written += fprintf(data->file, "<font color=\"#FF0000\"><font size=\"2\">(%s)</font><b> %s</b></font><br/>\n", date, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1361 else if (type & PURPLE_MESSAGE_WHISPER)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1362 written += fprintf(data->file, "<font color=\"#6C2585\"><font size=\"2\">(%s)</font><b> %s:</b></font> %s<br/>\n",
8577
64f25a17f8e4 [gaim-migrate @ 9326]
Nathan Walp <nwalp@pidgin.im>
parents: 8573
diff changeset
1363 date, from, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1364 else if (type & PURPLE_MESSAGE_AUTO_RESP) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1365 if (type & PURPLE_MESSAGE_SEND)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1366 written += fprintf(data->file, _("<font color=\"#16569E\"><font size=\"2\">(%s)</font> <b>%s &lt;AUTO-REPLY&gt;:</b></font> %s<br/>\n"), date, from, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1367 else if (type & PURPLE_MESSAGE_RECV)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1368 written += fprintf(data->file, _("<font color=\"#A82F2F\"><font size=\"2\">(%s)</font> <b>%s &lt;AUTO-REPLY&gt;:</b></font> %s<br/>\n"), date, from, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1369 } else if (type & PURPLE_MESSAGE_RECV) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1370 if(purple_message_meify(msg_fixed, -1))
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1371 written += fprintf(data->file, "<font color=\"#062585\"><font size=\"2\">(%s)</font> <b>***%s</b></font> %s<br/>\n",
10645
f00e65bebc8b [gaim-migrate @ 12157]
Richard Laager <rlaager@pidgin.im>
parents: 10589
diff changeset
1372 date, from, msg_fixed);
8577
64f25a17f8e4 [gaim-migrate @ 9326]
Nathan Walp <nwalp@pidgin.im>
parents: 8573
diff changeset
1373 else
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1374 written += fprintf(data->file, "<font color=\"#A82F2F\"><font size=\"2\">(%s)</font> <b>%s:</b></font> %s<br/>\n",
10645
f00e65bebc8b [gaim-migrate @ 12157]
Richard Laager <rlaager@pidgin.im>
parents: 10589
diff changeset
1375 date, from, msg_fixed);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1376 } else if (type & PURPLE_MESSAGE_SEND) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1377 if(purple_message_meify(msg_fixed, -1))
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1378 written += fprintf(data->file, "<font color=\"#062585\"><font size=\"2\">(%s)</font> <b>***%s</b></font> %s<br/>\n",
10645
f00e65bebc8b [gaim-migrate @ 12157]
Richard Laager <rlaager@pidgin.im>
parents: 10589
diff changeset
1379 date, from, msg_fixed);
8577
64f25a17f8e4 [gaim-migrate @ 9326]
Nathan Walp <nwalp@pidgin.im>
parents: 8573
diff changeset
1380 else
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1381 written += fprintf(data->file, "<font color=\"#16569E\"><font size=\"2\">(%s)</font> <b>%s:</b></font> %s<br/>\n",
10645
f00e65bebc8b [gaim-migrate @ 12157]
Richard Laager <rlaager@pidgin.im>
parents: 10589
diff changeset
1382 date, from, msg_fixed);
13069
37b879f161f4 [gaim-migrate @ 15431]
Richard Laager <rlaager@pidgin.im>
parents: 13068
diff changeset
1383 } else {
19832
84b69b21672b Patch from QuLogic. Fixes #2903 ('Missing newlines in debug messages.')
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 19224
diff changeset
1384 purple_debug_error("log", "Unhandled message type.\n");
13069
37b879f161f4 [gaim-migrate @ 15431]
Richard Laager <rlaager@pidgin.im>
parents: 13068
diff changeset
1385 written += fprintf(data->file, "<font size=\"2\">(%s)</font><b> %s:</b></font> %s<br/>\n",
13520
f89ab3c41f4b [gaim-migrate @ 15895]
Björn Voigt <bjoern@cs.tu-berlin.de>
parents: 13514
diff changeset
1386 date, from, msg_fixed);
8577
64f25a17f8e4 [gaim-migrate @ 9326]
Nathan Walp <nwalp@pidgin.im>
parents: 8573
diff changeset
1387 }
7564
baab99d239d8 [gaim-migrate @ 8180]
Nathan Walp <nwalp@pidgin.im>
parents: 7556
diff changeset
1388 }
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1389 g_free(date);
7882
7d95549fd6db [gaim-migrate @ 8536]
Nathan Walp <nwalp@pidgin.im>
parents: 7791
diff changeset
1390 g_free(msg_fixed);
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1391 fflush(data->file);
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1392
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1393 return written;
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1394 }
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1395
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1396 static void html_logger_finalize(PurpleLog *log)
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1397 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1398 PurpleLogCommonLoggerData *data = log->logger_data;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1399 if (data) {
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1400 if(data->file) {
12881
d4db623e3d8c [gaim-migrate @ 15233]
Richard Laager <rlaager@pidgin.im>
parents: 12834
diff changeset
1401 fprintf(data->file, "</body></html>\n");
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1402 fclose(data->file);
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1403 }
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1404 g_free(data->path);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1405
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1406 g_slice_free(PurpleLogCommonLoggerData, data);
7463
32338ddb9a7d [gaim-migrate @ 8076]
Nathan Walp <nwalp@pidgin.im>
parents: 7462
diff changeset
1407 }
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1408 }
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1409
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1410 static GList *html_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account)
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1411 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1412 return purple_log_common_lister(type, sn, account, ".html", html_logger);
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1413 }
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1414
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1415 static GList *html_logger_list_syslog(PurpleAccount *account)
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
1416 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1417 return purple_log_common_lister(PURPLE_LOG_SYSTEM, ".system", account, ".html", html_logger);
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
1418 }
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
1419
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1420 static char *html_logger_read(PurpleLog *log, PurpleLogReadFlags *flags)
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1421 {
12958
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1422 char *read;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1423 PurpleLogCommonLoggerData *data = log->logger_data;
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1424 *flags = PURPLE_LOG_READ_NO_NEWLINE;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1425 if (!data || !data->path)
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1426 return g_strdup(_("<font color=\"red\"><b>Unable to find log path!</b></font>"));
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1427 if (g_file_get_contents(data->path, &read, NULL, NULL)) {
12958
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1428 char *minus_header = strchr(read, '\n');
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1429
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1430 if (!minus_header)
12958
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1431 return read;
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1432
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1433 minus_header = g_strdup(minus_header + 1);
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1434 g_free(read);
12958
706645a0b944 [gaim-migrate @ 15311]
Richard Laager <rlaager@pidgin.im>
parents: 12881
diff changeset
1435
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1436 return minus_header;
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1437 }
8578
694cb265241b [gaim-migrate @ 9327]
Nathan Walp <nwalp@pidgin.im>
parents: 8577
diff changeset
1438 return g_strdup_printf(_("<font color=\"red\"><b>Could not read file: %s</b></font>"), data->path);
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1439 }
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1440
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1441 static int html_logger_total_size(PurpleLogType type, const char *name, PurpleAccount *account)
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
1442 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1443 return purple_log_common_total_sizer(type, name, account, ".html");
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
1444 }
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1445
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1446
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1447 /****************************
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1448 ** PLAIN TEXT LOGGER *******
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1449 ****************************/
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
1450
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1451 static gsize txt_logger_write(PurpleLog *log,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1452 PurpleMessageFlags type,
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
1453 const char *from, time_t time, const char *message)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1454 {
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1455 char *date;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1456 PurplePlugin *plugin = purple_find_prpl(purple_account_get_protocol_id(log->account));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1457 PurpleLogCommonLoggerData *data = log->logger_data;
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1458 char *stripped = NULL;
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1459
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1460 gsize written = 0;
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1461
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
1462 if (data == NULL) {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1463 /* This log is new. We could use the loggers 'new' function, but
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1464 * creating a new file there would result in empty files in the case
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1465 * that you open a convo with someone, but don't say anything.
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1466 */
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1467 const char *prpl =
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1468 PURPLE_PLUGIN_PROTOCOL_INFO(plugin)->list_icon(log->account, NULL);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1469 purple_log_common_writer(log, ".txt");
8898
85f5615bc27e [gaim-migrate @ 9667]
Mark Doliner <markdoliner@pidgin.im>
parents: 8635
diff changeset
1470
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1471 data = log->logger_data;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1472
9763
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1473 /* if we can't write to the file, give up before we hurt ourselves */
b206758cab4b [gaim-migrate @ 10631]
Ka-Hing Cheung <khc@pidgin.im>
parents: 9677
diff changeset
1474 if(!data->file)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1475 return 0;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1476
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1477 if (log->type == PURPLE_LOG_SYSTEM)
13509
38ebac941c40 [gaim-migrate @ 15884]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13474
diff changeset
1478 written += fprintf(data->file, "System log for account %s (%s) connected at %s\n",
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1479 purple_account_get_username(log->account), prpl,
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1480 purple_date_format_full(localtime(&log->time)));
13509
38ebac941c40 [gaim-migrate @ 15884]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13474
diff changeset
1481 else
38ebac941c40 [gaim-migrate @ 15884]
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents: 13474
diff changeset
1482 written += fprintf(data->file, "Conversation with %s at %s on %s (%s)\n",
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1483 log->name, purple_date_format_full(localtime(&log->time)),
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1484 purple_account_get_username(log->account), prpl);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1485 }
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1486
7623
ea9fc2f9c46b [gaim-migrate @ 8247]
Nathan Walp <nwalp@pidgin.im>
parents: 7618
diff changeset
1487 /* if we can't write to the file, give up before we hurt ourselves */
ea9fc2f9c46b [gaim-migrate @ 8247]
Nathan Walp <nwalp@pidgin.im>
parents: 7618
diff changeset
1488 if(!data->file)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1489 return 0;
7623
ea9fc2f9c46b [gaim-migrate @ 8247]
Nathan Walp <nwalp@pidgin.im>
parents: 7618
diff changeset
1490
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1491 stripped = purple_markup_strip_html(message);
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1492 date = log_get_timestamp(log, time);
12692
249f9d844f6f [gaim-migrate @ 15035]
Douglas Thrift <douglas@douglasthrift.net>
parents: 12574
diff changeset
1493
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1494 if(log->type == PURPLE_LOG_SYSTEM){
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1495 written += fprintf(data->file, "---- %s @ %s ----\n", stripped, date);
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1496 } else {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1497 if (type & PURPLE_MESSAGE_SEND ||
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1498 type & PURPLE_MESSAGE_RECV) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1499 if (type & PURPLE_MESSAGE_AUTO_RESP) {
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1500 written += fprintf(data->file, _("(%s) %s <AUTO-REPLY>: %s\n"), date,
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1501 from, stripped);
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1502 } else {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1503 if(purple_message_meify(stripped, -1))
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1504 written += fprintf(data->file, "(%s) ***%s %s\n", date, from,
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1505 stripped);
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1506 else
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1507 written += fprintf(data->file, "(%s) %s: %s\n", date, from,
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1508 stripped);
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1509 }
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1510 } else if (type & PURPLE_MESSAGE_SYSTEM ||
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1511 type & PURPLE_MESSAGE_ERROR ||
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1512 type & PURPLE_MESSAGE_RAW)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1513 written += fprintf(data->file, "(%s) %s\n", date, stripped);
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1514 else if (type & PURPLE_MESSAGE_NO_LOG) {
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1515 /* This shouldn't happen */
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1516 g_free(stripped);
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1517 return written;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1518 } else if (type & PURPLE_MESSAGE_WHISPER)
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1519 written += fprintf(data->file, "(%s) *%s* %s", date, from, stripped);
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1520 else
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1521 written += fprintf(data->file, "(%s) %s%s %s\n", date, from ? from : "",
12737
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1522 from ? ":" : "", stripped);
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1523 }
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1524 g_free(date);
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1525 g_free(stripped);
e1300804318e [gaim-migrate @ 15082]
Richard Laager <rlaager@pidgin.im>
parents: 12692
diff changeset
1526 fflush(data->file);
13059
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1527
1d6ae30f6a6d [gaim-migrate @ 15421]
Nathan Walp <nwalp@pidgin.im>
parents: 12969
diff changeset
1528 return written;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1529 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1530
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1531 static void txt_logger_finalize(PurpleLog *log)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1532 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1533 PurpleLogCommonLoggerData *data = log->logger_data;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1534 if (data) {
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1535 if(data->file)
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1536 fclose(data->file);
14097
0c340861ab79 [gaim-migrate @ 16638]
Mark Doliner <markdoliner@pidgin.im>
parents: 14068
diff changeset
1537 g_free(data->path);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1538
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1539 g_slice_free(PurpleLogCommonLoggerData, data);
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1540 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1541 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1542
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1543 static GList *txt_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1544 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1545 return purple_log_common_lister(type, sn, account, ".txt", txt_logger);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1546 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1547
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1548 static GList *txt_logger_list_syslog(PurpleAccount *account)
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
1549 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1550 return purple_log_common_lister(PURPLE_LOG_SYSTEM, ".system", account, ".txt", txt_logger);
8573
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
1551 }
3f37bd7005c8 [gaim-migrate @ 9321]
Ka-Hing Cheung <khc@pidgin.im>
parents: 8517
diff changeset
1552
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1553 static char *txt_logger_read(PurpleLog *log, PurpleLogReadFlags *flags)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1554 {
15676
5f5dc48279f4 Unused variables
Daniel Atallah <datallah@pidgin.im>
parents: 15595
diff changeset
1555 char *read, *minus_header;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1556 PurpleLogCommonLoggerData *data = log->logger_data;
7457
ee2680e31bad [gaim-migrate @ 8070]
Nathan Walp <nwalp@pidgin.im>
parents: 7453
diff changeset
1557 *flags = 0;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1558 if (!data || !data->path)
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1559 return g_strdup(_("<font color=\"red\"><b>Unable to find log path!</b></font>"));
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1560 if (g_file_get_contents(data->path, &read, NULL, NULL)) {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1561 minus_header = strchr(read, '\n');
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1562
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1563 if (minus_header)
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1564 return process_txt_log(minus_header + 1, read);
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1565 else
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1566 return process_txt_log(read, NULL);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1567 }
8578
694cb265241b [gaim-migrate @ 9327]
Nathan Walp <nwalp@pidgin.im>
parents: 8577
diff changeset
1568 return g_strdup_printf(_("<font color=\"red\"><b>Could not read file: %s</b></font>"), data->path);
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1569 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1570
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1571 static int txt_logger_total_size(PurpleLogType type, const char *name, PurpleAccount *account)
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
1572 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1573 return purple_log_common_total_sizer(type, name, account, ".txt");
13389
27cf7d84dfd1 [gaim-migrate @ 15761]
Richard Laager <rlaager@pidgin.im>
parents: 13358
diff changeset
1574 }
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
1575
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1576
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1577 /****************
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1578 * OLD LOGGER ***
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1579 ****************/
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1580
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1581 /* The old logger doesn't write logs, only reads them. This is to include
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1582 * old logs in the log viewer transparently.
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1583 */
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1584
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1585 struct old_logger_data {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1586 PurpleStringref *pathref;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1587 int offset;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1588 int length;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1589 };
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1590
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1591 static GList *old_logger_list(PurpleLogType type, const char *sn, PurpleAccount *account)
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1592 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1593 char *logfile = g_strdup_printf("%s.log", purple_normalize(account, sn));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1594 char *pathstr = g_build_filename(purple_user_dir(), "logs", logfile, NULL);
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1595 PurpleStringref *pathref = purple_stringref_new(pathstr);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1596 struct stat st;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1597 time_t log_last_modified;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1598 FILE *index;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1599 FILE *file;
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1600 int index_fd;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1601 char *index_tmp;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1602 char buf[BUF_LONG];
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1603 struct tm tm;
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1604 char month[4];
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1605 struct old_logger_data *data = NULL;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1606 char *newlog;
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1607 int logfound = 0;
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1608 int lastoff = 0;
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1609 int newlen;
7791
71b4031cdbda [gaim-migrate @ 8437]
Nathan Walp <nwalp@pidgin.im>
parents: 7770
diff changeset
1610 time_t lasttime = 0;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1611
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1612 PurpleLog *log = NULL;
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1613 GList *list = NULL;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1614
7473
881da47ca83f [gaim-migrate @ 8086]
Mark Doliner <markdoliner@pidgin.im>
parents: 7472
diff changeset
1615 g_free(logfile);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1616
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1617 if (g_stat(purple_stringref_value(pathref), &st))
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1618 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1619 purple_stringref_unref(pathref);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1620 g_free(pathstr);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1621 return NULL;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1622 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1623 else
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1624 log_last_modified = st.st_mtime;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1625
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1626 /* Change the .log extension to .idx */
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1627 strcpy(pathstr + strlen(pathstr) - 3, "idx");
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1628
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1629 if (g_stat(pathstr, &st) == 0)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1630 {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1631 if (st.st_mtime < log_last_modified)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1632 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1633 purple_debug_warning("log", "Index \"%s\" exists, but is older than the log.\n", pathstr);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1634 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1635 else
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1636 {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1637 /* The index file exists and is at least as new as the log, so open it. */
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1638 if (!(index = g_fopen(pathstr, "rb")))
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1639 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1640 purple_debug_error("log", "Failed to open index file \"%s\" for reading: %s\n",
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1641 pathstr, strerror(errno));
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1642
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1643 /* Fall through so that we'll parse the log file. */
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1644 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1645 else
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1646 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1647 purple_debug_info("log", "Using index: %s\n", pathstr);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1648 g_free(pathstr);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1649 while (fgets(buf, BUF_LONG, index))
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1650 {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1651 unsigned long idx_time;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1652 if (sscanf(buf, "%d\t%d\t%lu", &lastoff, &newlen, &idx_time) == 3)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1653 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1654 log = purple_log_new(PURPLE_LOG_IM, sn, account, NULL, -1, NULL);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1655 log->logger = old_logger;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1656 log->time = (time_t)idx_time;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1657
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1658 /* IMPORTANT: Always set all members of struct old_logger_data */
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1659 data = g_slice_new(struct old_logger_data);
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1660
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1661 data->pathref = purple_stringref_ref(pathref);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1662 data->offset = lastoff;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1663 data->length = newlen;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1664
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1665 log->logger_data = data;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1666 list = g_list_prepend(list, log);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1667 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1668 }
13469
6c9da180e40d [gaim-migrate @ 15843]
Richard Laager <rlaager@pidgin.im>
parents: 13412
diff changeset
1669 fclose(index);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1670
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1671 return list;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1672 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1673 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1674 }
7473
881da47ca83f [gaim-migrate @ 8086]
Mark Doliner <markdoliner@pidgin.im>
parents: 7472
diff changeset
1675
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1676 if (!(file = g_fopen(purple_stringref_value(pathref), "rb"))) {
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1677 purple_debug_error("log", "Failed to open log file \"%s\" for reading: %s\n",
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1678 purple_stringref_value(pathref), strerror(errno));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1679 purple_stringref_unref(pathref);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1680 g_free(pathstr);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1681 return NULL;
7447
4876aeb16c60 [gaim-migrate @ 8058]
Mark Doliner <markdoliner@pidgin.im>
parents: 7443
diff changeset
1682 }
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1683
13473
8fe2387d215b [gaim-migrate @ 15848]
Richard Laager <rlaager@pidgin.im>
parents: 13472
diff changeset
1684 index_tmp = g_strdup_printf("%s.XXXXXX", pathstr);
8fe2387d215b [gaim-migrate @ 15848]
Richard Laager <rlaager@pidgin.im>
parents: 13472
diff changeset
1685 if ((index_fd = g_mkstemp(index_tmp)) == -1) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1686 purple_debug_error("log", "Failed to open index temp file: %s\n",
13473
8fe2387d215b [gaim-migrate @ 15848]
Richard Laager <rlaager@pidgin.im>
parents: 13472
diff changeset
1687 strerror(errno));
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1688 g_free(pathstr);
13473
8fe2387d215b [gaim-migrate @ 15848]
Richard Laager <rlaager@pidgin.im>
parents: 13472
diff changeset
1689 g_free(index_tmp);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1690 index = NULL;
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1691 } else {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1692 if ((index = fdopen(index_fd, "wb")) == NULL)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1693 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1694 purple_debug_error("log", "Failed to fdopen() index temp file: %s\n",
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1695 strerror(errno));
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1696 close(index_fd);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1697 if (index_tmp != NULL)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1698 {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1699 g_unlink(index_tmp);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1700 g_free(index_tmp);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1701 }
13412
67ef3053ef45 [gaim-migrate @ 15786]
Richard Laager <rlaager@pidgin.im>
parents: 13407
diff changeset
1702 g_free(pathstr);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1703 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1704 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1705
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1706 while (fgets(buf, BUF_LONG, file)) {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1707 if ((newlog = strstr(buf, "---- New C"))) {
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1708 int length;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1709 int offset;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1710 char convostart[32];
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1711 char *temp = strchr(buf, '@');
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1712
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1713 if (temp == NULL || strlen(temp) < 2)
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1714 continue;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1715
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1716 temp++;
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1717 length = strcspn(temp, "-");
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1718 if (length > 31) length = 31;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1719
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1720 offset = ftell(file);
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1721
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1722 if (logfound) {
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1723 newlen = offset - lastoff - length;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1724 if(strstr(buf, "----</H3><BR>")) {
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1725 newlen -=
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1726 sizeof("<HR><BR><H3 Align=Center> ---- New Conversation @ ") +
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1727 sizeof("----</H3><BR>") - 2;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1728 } else {
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1729 newlen -=
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1730 sizeof("---- New Conversation @ ") + sizeof("----") - 2;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1731 }
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1732
7461
964030541dc0 [gaim-migrate @ 8074]
Nathan Walp <nwalp@pidgin.im>
parents: 7457
diff changeset
1733 if(strchr(buf, '\r'))
7770
cb9d21d75531 [gaim-migrate @ 8415]
Kevin Stange <kstange@pidgin.im>
parents: 7764
diff changeset
1734 newlen--;
7461
964030541dc0 [gaim-migrate @ 8074]
Nathan Walp <nwalp@pidgin.im>
parents: 7457
diff changeset
1735
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1736 if (newlen != 0) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1737 log = purple_log_new(PURPLE_LOG_IM, sn, account, NULL, -1, NULL);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
1738 log->logger = old_logger;
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1739 log->time = lasttime;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1740
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1741 /* IMPORTANT: Always set all members of struct old_logger_data */
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1742 data = g_slice_new(struct old_logger_data);
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1743
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1744 data->pathref = purple_stringref_ref(pathref);
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1745 data->offset = lastoff;
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1746 data->length = newlen;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1747
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1748 log->logger_data = data;
11703
6b22ef099870 [gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents: 11698
diff changeset
1749 list = g_list_prepend(list, log);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1750
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1751 /* XXX: There is apparently Is there a proper way to print a time_t? */
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1752 if (index != NULL)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1753 fprintf(index, "%d\t%d\t%lu\n", data->offset, data->length, (unsigned long)log->time);
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1754 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1755 }
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1756
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1757 logfound = 1;
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1758 lastoff = offset;
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1759
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1760 g_snprintf(convostart, length, "%s", temp);
7676
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1761 sscanf(convostart, "%*s %s %d %d:%d:%d %d",
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1762 month, &tm.tm_mday, &tm.tm_hour, &tm.tm_min, &tm.tm_sec, &tm.tm_year);
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1763 /* Ugly hack, in case current locale is not English */
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1764 if (strcmp(month, "Jan") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1765 tm.tm_mon= 0;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1766 } else if (strcmp(month, "Feb") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1767 tm.tm_mon = 1;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1768 } else if (strcmp(month, "Mar") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1769 tm.tm_mon = 2;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1770 } else if (strcmp(month, "Apr") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1771 tm.tm_mon = 3;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1772 } else if (strcmp(month, "May") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1773 tm.tm_mon = 4;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1774 } else if (strcmp(month, "Jun") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1775 tm.tm_mon = 5;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1776 } else if (strcmp(month, "Jul") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1777 tm.tm_mon = 6;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1778 } else if (strcmp(month, "Aug") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1779 tm.tm_mon = 7;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1780 } else if (strcmp(month, "Sep") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1781 tm.tm_mon = 8;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1782 } else if (strcmp(month, "Oct") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1783 tm.tm_mon = 9;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1784 } else if (strcmp(month, "Nov") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1785 tm.tm_mon = 10;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1786 } else if (strcmp(month, "Dec") == 0) {
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1787 tm.tm_mon = 11;
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1788 }
1013e51a1d94 [gaim-migrate @ 8320]
Ambrose Li <ambrose.li@gmail.com>
parents: 7628
diff changeset
1789 tm.tm_year -= 1900;
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1790 lasttime = mktime(&tm);
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
1791 }
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
1792 }
7613
d5a283c09b1d [gaim-migrate @ 8237]
Nathan Walp <nwalp@pidgin.im>
parents: 7612
diff changeset
1793
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1794 if (logfound) {
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1795 if ((newlen = ftell(file) - lastoff) != 0) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1796 log = purple_log_new(PURPLE_LOG_IM, sn, account, NULL, -1, NULL);
11503
9f15d4c089b9 [gaim-migrate @ 13748]
Richard Laager <rlaager@pidgin.im>
parents: 11458
diff changeset
1797 log->logger = old_logger;
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1798 log->time = lasttime;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1799
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1800 /* IMPORTANT: Always set all members of struct old_logger_data */
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1801 data = g_slice_new(struct old_logger_data);
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1802
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1803 data->pathref = purple_stringref_ref(pathref);
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1804 data->offset = lastoff;
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1805 data->length = newlen;
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1806
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1807 log->logger_data = data;
11703
6b22ef099870 [gaim-migrate @ 13994]
Richard Laager <rlaager@pidgin.im>
parents: 11698
diff changeset
1808 list = g_list_prepend(list, log);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1809
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1810 /* XXX: Is there a proper way to print a time_t? */
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1811 if (index != NULL)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1812 fprintf(index, "%d\t%d\t%d\n", data->offset, data->length, (int)log->time);
7761
8b457575a0c4 [gaim-migrate @ 8406]
Ethan Blanton <elb@pidgin.im>
parents: 7752
diff changeset
1813 }
7613
d5a283c09b1d [gaim-migrate @ 8237]
Nathan Walp <nwalp@pidgin.im>
parents: 7612
diff changeset
1814 }
d5a283c09b1d [gaim-migrate @ 8237]
Nathan Walp <nwalp@pidgin.im>
parents: 7612
diff changeset
1815
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1816 purple_stringref_unref(pathref);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1817 fclose(file);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1818 if (index != NULL)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1819 {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1820 fclose(index);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1821
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1822 if (index_tmp == NULL)
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1823 {
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1824 g_free(pathstr);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1825 g_return_val_if_reached(list);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1826 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1827
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1828 if (g_rename(index_tmp, pathstr))
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1829 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1830 purple_debug_warning("log", "Failed to rename index temp file \"%s\" to \"%s\": %s\n",
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1831 index_tmp, pathstr, strerror(errno));
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1832 g_unlink(index_tmp);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1833 g_free(index_tmp);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1834 }
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1835 else
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1836 purple_debug_info("log", "Built index: %s\n", pathstr);
13407
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1837
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1838 g_free(pathstr);
8b5d4dc349b1 [gaim-migrate @ 15781]
Richard Laager <rlaager@pidgin.im>
parents: 13389
diff changeset
1839 }
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1840 return list;
4184
c8beb71e54bc [gaim-migrate @ 4415]
Christian Hammond <chipx86@chipx86.com>
parents:
diff changeset
1841 }
4359
cf899ee07d1d [gaim-migrate @ 4625]
Christian Hammond <chipx86@chipx86.com>
parents: 4227
diff changeset
1842
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1843 static int old_logger_total_size(PurpleLogType type, const char *name, PurpleAccount *account)
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1844 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1845 char *logfile = g_strdup_printf("%s.log", purple_normalize(account, name));
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1846 char *pathstr = g_build_filename(purple_user_dir(), "logs", logfile, NULL);
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1847 int size;
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1848 struct stat st;
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1849
10589
4e10236e06d4 [gaim-migrate @ 11994]
Daniel Atallah <datallah@pidgin.im>
parents: 10577
diff changeset
1850 if (g_stat(pathstr, &st))
8096
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1851 size = 0;
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1852 else
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1853 size = st.st_size;
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1854
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1855 g_free(logfile);
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1856 g_free(pathstr);
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1857
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1858 return size;
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1859 }
306a66d5171a [gaim-migrate @ 8795]
Luke Schierer <lschiere@pidgin.im>
parents: 8062
diff changeset
1860
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1861 static char * old_logger_read (PurpleLog *log, PurpleLogReadFlags *flags)
4359
cf899ee07d1d [gaim-migrate @ 4625]
Christian Hammond <chipx86@chipx86.com>
parents: 4227
diff changeset
1862 {
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1863 struct old_logger_data *data = log->logger_data;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1864 FILE *file = g_fopen(purple_stringref_value(data->pathref), "rb");
15676
5f5dc48279f4 Unused variables
Daniel Atallah <datallah@pidgin.im>
parents: 15595
diff changeset
1865 char *read = g_malloc(data->length + 1);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1866 fseek(file, data->offset, SEEK_SET);
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1867 fread(read, data->length, 1, file);
8370
ce5393bfcf57 [gaim-migrate @ 9097]
Mark Doliner <markdoliner@pidgin.im>
parents: 8111
diff changeset
1868 fclose(file);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1869 read[data->length] = '\0';
7436
39ad170582d5 [gaim-migrate @ 8041]
Nathan Walp <nwalp@pidgin.im>
parents: 7431
diff changeset
1870 *flags = 0;
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1871 if (strstr(read, "<BR>"))
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1872 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1873 *flags |= PURPLE_LOG_READ_NO_NEWLINE;
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1874 return read;
10906
1825ffb6b495 [gaim-migrate @ 12636]
Stu Tomlinson <nosnilmot@pidgin.im>
parents: 10822
diff changeset
1875 }
15594
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1876
300c61e1ff2a Fix SF Bug #1644796
Richard Laager <rlaager@pidgin.im>
parents: 15585
diff changeset
1877 return process_txt_log(read, NULL);
7431
f3eaace13491 [gaim-migrate @ 8036]
Sean Egan <seanegan@pidgin.im>
parents: 7322
diff changeset
1878 }
4359
cf899ee07d1d [gaim-migrate @ 4625]
Christian Hammond <chipx86@chipx86.com>
parents: 4227
diff changeset
1879
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1880 static int old_logger_size (PurpleLog *log)
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
1881 {
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
1882 struct old_logger_data *data = log->logger_data;
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1883 return data ? data->length : 0;
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1884 }
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1885
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1886 static void old_logger_get_log_sets(PurpleLogSetCallback cb, GHashTable *sets)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1887 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1888 char *log_path = g_build_filename(purple_user_dir(), "logs", NULL);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1889 GDir *log_dir = g_dir_open(log_path, 0, NULL);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1890 gchar *name;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1891 PurpleBlistNode *gnode, *cnode, *bnode;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1892
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1893 g_free(log_path);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1894 if (log_dir == NULL)
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
1895 return;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1896
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1897 /* Don't worry about the cast, name will be filled with a dynamically allocated data shortly. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1898 while ((name = (gchar *)g_dir_read_name(log_dir)) != NULL) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1899 size_t len;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1900 gchar *ext;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1901 PurpleLogSet *set;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1902 gboolean found = FALSE;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1903
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1904 /* Unescape the filename. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1905 name = g_strdup(purple_unescape_filename(name));
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1906
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1907 /* Get the (possibly new) length of name. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1908 len = strlen(name);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1909
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1910 if (len < 5) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1911 g_free(name);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1912 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1913 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1914
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1915 /* Make sure we're dealing with a log file. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1916 ext = &name[len - 4];
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1917 if (strcmp(ext, ".log")) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1918 g_free(name);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1919 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1920 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1921
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1922 /* IMPORTANT: Always set all members of PurpleLogSet */
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1923 set = g_slice_new(PurpleLogSet);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1924
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1925 /* Chat for .chat at the end of the name to determine the type. */
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1926 *ext = '\0';
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1927 set->type = PURPLE_LOG_IM;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1928 if (len > 9) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1929 char *tmp = &name[len - 9];
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1930 if (!strcmp(tmp, ".chat")) {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1931 set->type = PURPLE_LOG_CHAT;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1932 *tmp = '\0';
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1933 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1934 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1935
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
1936 set->name = set->normalized_name = name;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1937
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1938 /* Search the buddy list to find the account and to determine if this is a buddy. */
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1939 for (gnode = purple_get_blist()->root; !found && gnode != NULL; gnode = gnode->next)
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1940 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1941 if (!PURPLE_BLIST_NODE_IS_GROUP(gnode))
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1942 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1943
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1944 for (cnode = gnode->child; !found && cnode != NULL; cnode = cnode->next)
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1945 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1946 if (!PURPLE_BLIST_NODE_IS_CONTACT(cnode))
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1947 continue;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1948
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1949 for (bnode = cnode->child; !found && bnode != NULL; bnode = bnode->next)
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1950 {
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1951 PurpleBuddy *buddy = (PurpleBuddy *)bnode;
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1952
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1953 if (!strcmp(buddy->name, name)) {
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1954 set->account = buddy->account;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1955 set->buddy = TRUE;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1956 found = TRUE;
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1957 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1958 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1959 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1960 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1961
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1962 if (!found)
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1963 {
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1964 set->account = NULL;
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1965 set->buddy = FALSE;
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1966 }
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1967
11177
534ca3ae0bfc [gaim-migrate @ 13285]
Richard Laager <rlaager@pidgin.im>
parents: 11094
diff changeset
1968 cb(sets, set);
11025
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1969 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1970 g_dir_close(log_dir);
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1971 }
41b6449f7dff [gaim-migrate @ 12899]
Richard Laager <rlaager@pidgin.im>
parents: 10906
diff changeset
1972
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1973 static void old_logger_finalize(PurpleLog *log)
7616
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1974 {
461cf59752d8 [gaim-migrate @ 8240]
Nathan Walp <nwalp@pidgin.im>
parents: 7613
diff changeset
1975 struct old_logger_data *data = log->logger_data;
15884
4de1981757fc sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@pidgin.im>
parents: 15676
diff changeset
1976 purple_stringref_unref(data->pathref);
13624
c6577def4e2a [gaim-migrate @ 16009]
Richard Laager <rlaager@pidgin.im>
parents: 13584
diff changeset
1977 g_slice_free(struct old_logger_data, data);
7556
2154c3f5be68 [gaim-migrate @ 8170]
Sean Egan <seanegan@pidgin.im>
parents: 7555
diff changeset
1978 }

mercurial