# HG changeset patch
# User Luke Schierer <lschiere@pidgin.im>
# Date 1093654590 0
# Node ID 284a84477ee93a9aa2f7b7fcd0d97ee0928247a6
# Parent  67dbf65e76cffd450cb905ae026a0f8bbc72dd99
[gaim-migrate @ 10780]
(20:58:51) datallah: "this should make windows suck less..."

i don't think that's possible. but it might make gaim on win32 suck less.

committer: Tailor Script <tailor@pidgin.im>

diff -r 67dbf65e76cf -r 284a84477ee9 src/log.c
--- a/src/log.c	Fri Aug 27 22:23:31 2004 +0000
+++ b/src/log.c	Sat Aug 28 00:56:30 2004 +0000
@@ -74,8 +74,6 @@
 void gaim_log_write(GaimLog *log, GaimMessageFlags type,
 		    const char *from, time_t time, const char *message)
 {
-	struct _gaim_logsize_user lu;
-
 	g_return_if_fail(log);
 	g_return_if_fail(log->logger);
 	g_return_if_fail(log->logger->write);
@@ -86,11 +84,16 @@
 			 gaim_prefs_get_bool("/core/logging/log_chats")) ||
 			(log->type == GAIM_LOG_SYSTEM &&
 			 gaim_prefs_get_bool("/core/logging/log_system"))) {
+		struct _gaim_logsize_user *lu;
 		(log->logger->write)(log, type, from, time, message);
-		lu.name = g_strdup(gaim_normalize(log->account, log->name));
-		lu.account = log->account;
-		g_hash_table_remove(logsize_users, &lu);
-		g_free(lu.name);
+
+		lu = g_new(struct _gaim_logsize_user, 1);
+
+		lu->name = g_strdup(gaim_normalize(log->account, log->name));
+		lu->account = log->account;
+		g_hash_table_remove(logsize_users, lu);
+		g_free(lu->name);
+		g_free(lu);
 	}
 }
 
@@ -343,14 +346,14 @@
 		/* This log is new */
 		char *ud = gaim_user_dir();
 		char *acct_name = g_strdup(gaim_normalize(log->account,
-												  gaim_account_get_username(log->account)));
+					gaim_account_get_username(log->account)));
 		char *target;
 		char *dir;
 		char *filename, *path;
 
 		if (log->type == GAIM_LOG_CHAT) {
 			target = g_strdup_printf("%s.chat", gaim_normalize(log->account,
-															   log->name));
+						log->name));
 		} else if(log->type == GAIM_LOG_SYSTEM) {
 			target = g_strdup(".system");
 		} else {
@@ -376,7 +379,7 @@
 		data->file = fopen(path, "a");
 		if (!data->file) {
 			gaim_debug(GAIM_DEBUG_ERROR, "log",
-					"Could not create log file %s\n", filename);
+					"Could not create log file %s\n", path);
 			g_free(path);
 			return;
 		}
@@ -585,6 +588,10 @@
 
 	}
 
+	/* if we can't write to the file, give up before we hurt ourselves */
+	if(!data->file)
+		return;
+
 	gaim_markup_html_to_xhtml(message, &msg_fixed, NULL);
 
 	if(log->type == GAIM_LOG_SYSTEM){