summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2009-04-14 19:16:47 +0200
committerSebastien Helleu <flashcode@flashtux.org>2009-04-14 19:16:47 +0200
commit433f5e86fa6900247b7a5667adc42059a3e76545 (patch)
tree59b9c0a2f935342659451f0f38cbba832ac52a1a /src
parent0b6203ac6fdb7d3a5d51c544195231cc25ce1313 (diff)
downloadweechat-433f5e86fa6900247b7a5667adc42059a3e76545.zip
Fix bug with upgrade and irc raw buffer, save irc raw messages during upgrade
Diffstat (limited to 'src')
-rw-r--r--src/plugins/irc/irc-raw.c157
-rw-r--r--src/plugins/irc/irc-raw.h8
-rw-r--r--src/plugins/irc/irc-upgrade.c32
-rw-r--r--src/plugins/irc/irc-upgrade.h1
4 files changed, 145 insertions, 53 deletions
diff --git a/src/plugins/irc/irc-raw.c b/src/plugins/irc/irc-raw.c
index 8f6ce7029..0aa0cbf82 100644
--- a/src/plugins/irc/irc-raw.c
+++ b/src/plugins/irc/irc-raw.c
@@ -154,21 +154,69 @@ irc_raw_message_free_all ()
}
/*
- * irc_raw_message_add: add new message to list
+ * irc_raw_message_remove_old: remove old raw messages if limit has been reached
*/
void
+irc_raw_message_remove_old ()
+{
+ int max_messages;
+
+ max_messages = weechat_config_integer (irc_config_look_raw_messages);
+ while (irc_raw_messages && (irc_raw_messages_count >= max_messages))
+ {
+ irc_raw_message_free (irc_raw_messages);
+ }
+}
+
+/*
+ * irc_raw_message_add_to_list: add new message to list
+ */
+
+struct t_irc_raw_message *
+irc_raw_message_add_to_list (time_t date, const char *prefix,
+ const char *message)
+{
+ struct t_irc_raw_message *new_raw_message;
+
+ irc_raw_message_remove_old ();
+
+ new_raw_message = malloc (sizeof (*new_raw_message));
+ if (new_raw_message)
+ {
+ new_raw_message->date = date;
+ new_raw_message->prefix = strdup (prefix);
+ new_raw_message->message = strdup (message);
+
+ /* add message to list */
+ new_raw_message->prev_message = last_irc_raw_message;
+ new_raw_message->next_message = NULL;
+ if (irc_raw_messages)
+ last_irc_raw_message->next_message = new_raw_message;
+ else
+ irc_raw_messages = new_raw_message;
+ last_irc_raw_message = new_raw_message;
+
+ irc_raw_messages_count++;
+ }
+
+ return new_raw_message;
+}
+
+/*
+ * irc_raw_message_add: add new message to list
+ */
+
+struct t_irc_raw_message *
irc_raw_message_add (struct t_irc_server *server, int send, int modified,
const char *message)
{
char *buf, *buf2, prefix[256];
const unsigned char *ptr_buf;
const char *hexa = "0123456789ABCDEF";
- int pos_buf, pos_buf2, char_size, i, max_messages;
+ int pos_buf, pos_buf2, char_size, i;
struct t_irc_raw_message *new_raw_message;
- max_messages = weechat_config_integer (irc_config_look_raw_messages);
-
buf = weechat_iconv_to_internal (NULL, message);
buf2 = malloc ((strlen (buf) * 3) + 1);
if (buf2)
@@ -196,59 +244,27 @@ irc_raw_message_add (struct t_irc_server *server, int send, int modified,
}
buf2[pos_buf2] = '\0';
}
+ snprintf (prefix, sizeof (prefix), "%s%s%s%s%s",
+ (server) ? weechat_color ("chat_server") : "",
+ (server) ? server->name : "",
+ (server) ? " " : "",
+ (send) ?
+ weechat_color ("chat_prefix_quit") :
+ weechat_color ("chat_prefix_join"),
+ (send) ?
+ ((modified) ? IRC_RAW_PREFIX_SEND_MOD : IRC_RAW_PREFIX_SEND) :
+ ((modified) ? IRC_RAW_PREFIX_RECV_MOD : IRC_RAW_PREFIX_RECV));
- new_raw_message = malloc (sizeof (*new_raw_message));
- if (new_raw_message)
- {
- new_raw_message->date = time (NULL);
- snprintf (prefix, sizeof (prefix), "%s%s%s%s%s",
- (server) ? weechat_color ("chat_server") : "",
- (server) ? server->name : "",
- (server) ? " " : "",
- (send) ?
- weechat_color ("chat_prefix_quit") :
- weechat_color ("chat_prefix_join"),
- (send) ?
- ((modified) ? IRC_RAW_PREFIX_SEND_MOD : IRC_RAW_PREFIX_SEND) :
- ((modified) ? IRC_RAW_PREFIX_RECV_MOD : IRC_RAW_PREFIX_RECV));
- new_raw_message->prefix = strdup (prefix);
- new_raw_message->message = strdup ((buf2) ? buf2 : ((buf) ? buf : message));
- new_raw_message->prev_message = NULL;
- new_raw_message->next_message = NULL;
-
- while (irc_raw_messages_count >= max_messages)
- {
- irc_raw_message_free (irc_raw_messages);
- }
-
- if (max_messages > 0)
- {
- new_raw_message->prev_message = last_irc_raw_message;
- new_raw_message->next_message = NULL;
- if (irc_raw_messages)
- last_irc_raw_message->next_message = new_raw_message;
- else
- irc_raw_messages = new_raw_message;
- last_irc_raw_message = new_raw_message;
-
- irc_raw_messages_count++;
-
- if (irc_raw_buffer)
- irc_raw_message_print (new_raw_message);
- }
- else
- {
- /* don't store message, just print it if raw buffer is opened */
- if (irc_raw_buffer)
- irc_raw_message_print (new_raw_message);
- irc_raw_message_free (new_raw_message);
- }
- }
+ new_raw_message = irc_raw_message_add_to_list (time (NULL),
+ prefix,
+ (buf2) ? buf2 : ((buf) ? buf : message));
if (buf)
free (buf);
if (buf2)
free (buf2);
+
+ return new_raw_message;
}
/*
@@ -259,11 +275,48 @@ void
irc_raw_print (struct t_irc_server *server, int send, int modified,
const char *message)
{
+ struct t_irc_raw_message *new_raw_message;
+
if (!message)
return;
if (!irc_raw_buffer && (weechat_irc_plugin->debug >= 1))
irc_raw_open (0);
- irc_raw_message_add (server, send, modified, message);
+ new_raw_message = irc_raw_message_add (server, send, modified, message);
+ if (new_raw_message)
+ {
+ if (irc_raw_buffer)
+ irc_raw_message_print (new_raw_message);
+ if (weechat_config_integer (irc_config_look_raw_messages) == 0)
+ irc_raw_message_free (new_raw_message);
+ }
+}
+
+/*
+ * irc_raw_add_to_infolist: add a raw messagt in an infolist
+ * return 1 if ok, 0 if error
+ */
+
+int
+irc_raw_add_to_infolist (struct t_infolist *infolist,
+ struct t_irc_raw_message *raw_message)
+{
+ struct t_infolist_item *ptr_item;
+
+ if (!infolist || !raw_message)
+ return 0;
+
+ ptr_item = weechat_infolist_new_item (infolist);
+ if (!ptr_item)
+ return 0;
+
+ if (!weechat_infolist_new_var_time (ptr_item, "date", raw_message->date))
+ return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "prefix", raw_message->prefix))
+ return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "message", raw_message->message))
+ return 0;
+
+ return 1;
}
diff --git a/src/plugins/irc/irc-raw.h b/src/plugins/irc/irc-raw.h
index d0b6038d1..b8b4ff539 100644
--- a/src/plugins/irc/irc-raw.h
+++ b/src/plugins/irc/irc-raw.h
@@ -38,10 +38,16 @@ struct t_irc_raw_message
struct t_irc_server;
extern struct t_gui_buffer *irc_raw_buffer;
+extern int irc_raw_messages_count;
+extern struct t_irc_raw_message *irc_raw_messages, *last_irc_raw_message;
extern void irc_raw_open (int switch_to_buffer);
-extern void irc_raw_max_messages (int number);
+extern struct t_irc_raw_message *irc_raw_message_add_to_list (time_t date,
+ const char *prefix,
+ const char *message);
extern void irc_raw_print (struct t_irc_server *server, int send,
int modified, const char *message);
+extern int irc_raw_add_to_infolist (struct t_infolist *infolist,
+ struct t_irc_raw_message *raw_message);
#endif /* irc-raw.h */
diff --git a/src/plugins/irc/irc-upgrade.c b/src/plugins/irc/irc-upgrade.c
index 096f2839c..759aeafac 100644
--- a/src/plugins/irc/irc-upgrade.c
+++ b/src/plugins/irc/irc-upgrade.c
@@ -31,6 +31,7 @@
#include "irc-server.h"
#include "irc-channel.h"
#include "irc-nick.h"
+#include "irc-raw.h"
struct t_irc_server *irc_upgrade_current_server = NULL;
@@ -48,6 +49,7 @@ irc_upgrade_save_all_data (struct t_upgrade_file *upgrade_file)
struct t_irc_server *ptr_server;
struct t_irc_channel *ptr_channel;
struct t_irc_nick *ptr_nick;
+ struct t_irc_raw_message *ptr_raw_message;
int rc;
for (ptr_server = irc_servers; ptr_server;
@@ -110,6 +112,26 @@ irc_upgrade_save_all_data (struct t_upgrade_file *upgrade_file)
}
}
+ /* save raw messages */
+ for (ptr_raw_message = irc_raw_messages; ptr_raw_message;
+ ptr_raw_message = ptr_raw_message->next_message)
+ {
+ infolist = weechat_infolist_new ();
+ if (!infolist)
+ return 0;
+ if (!irc_raw_add_to_infolist (infolist, ptr_raw_message))
+ {
+ weechat_infolist_free (infolist);
+ return 0;
+ }
+ rc = weechat_upgrade_write_object (upgrade_file,
+ IRC_UPGRADE_TYPE_RAW_MESSAGE,
+ infolist);
+ weechat_infolist_free (infolist);
+ if (!rc)
+ return 0;
+ }
+
return 1;
}
@@ -156,6 +178,11 @@ irc_upgrade_set_buffer_callbacks ()
ptr_buffer = weechat_infolist_pointer (infolist, "pointer");
weechat_buffer_set_pointer (ptr_buffer, "close_callback", &irc_buffer_close_cb);
weechat_buffer_set_pointer (ptr_buffer, "input_callback", &irc_input_data_cb);
+ if (strcmp (weechat_infolist_string (infolist, "name"),
+ IRC_RAW_BUFFER_NAME) == 0)
+ {
+ irc_raw_buffer = ptr_buffer;
+ }
}
}
}
@@ -338,6 +365,11 @@ irc_upgrade_read_cb (void *data,
}
}
break;
+ case IRC_UPGRADE_TYPE_RAW_MESSAGE:
+ irc_raw_message_add_to_list (weechat_infolist_time (infolist, "date"),
+ weechat_infolist_string (infolist, "prefix"),
+ weechat_infolist_string (infolist, "message"));
+ break;
}
}
diff --git a/src/plugins/irc/irc-upgrade.h b/src/plugins/irc/irc-upgrade.h
index 304a6ee93..fbfe5ae21 100644
--- a/src/plugins/irc/irc-upgrade.h
+++ b/src/plugins/irc/irc-upgrade.h
@@ -29,6 +29,7 @@ enum t_irc_upgrade_type
IRC_UPGRADE_TYPE_SERVER = 0,
IRC_UPGRADE_TYPE_CHANNEL,
IRC_UPGRADE_TYPE_NICK,
+ IRC_UPGRADE_TYPE_RAW_MESSAGE,
};
extern int irc_upgrade_save ();