From c4d7f1c29a2b3bfed93fc322e77263c0cd3e371a Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Fri, 29 Apr 2022 14:41:41 +0200 Subject: Set default max log size to 10MB In case logrotate is on. --- src/config/preferences.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'src') diff --git a/src/config/preferences.h b/src/config/preferences.h index b663e82a..46f2669a 100644 --- a/src/config/preferences.h +++ b/src/config/preferences.h @@ -42,7 +42,7 @@ #include #define PREFS_MIN_LOG_SIZE 64 -#define PREFS_MAX_LOG_SIZE 1048580 +#define PREFS_MAX_LOG_SIZE (10 * 1024 * 1024) // represents all settings in .profrc // each enum value is mapped to a group and key in .profrc (see preferences.c) -- cgit 1.4.1-2-gfad0 From 188afc58da17f77692e44839eccd260321c7955c Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Fri, 29 Apr 2022 14:46:09 +0200 Subject: Use 3 digits for rotated logfiles profanity.log.001 -> 999. --- src/log.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/log.c b/src/log.c index 296f20b5..191f8a84 100644 --- a/src/log.c +++ b/src/log.c @@ -237,9 +237,9 @@ _rotate_log_file(void) size_t len = strlen(log_file); gchar* log_file_new = malloc(len + 4); - // find an empty name. from .log -> log.01 -> log.99 - for (int i = 1; i < 100; i++) { - g_sprintf(log_file_new, "%s.%02d", log_file, i); + // find an empty name. from .log -> log.001 -> log.999 + for (int i = 1; i < 1000; i++) { + g_sprintf(log_file_new, "%s.%03d", log_file, i); if (!g_file_test(log_file_new, G_FILE_TEST_EXISTS)) break; } -- cgit 1.4.1-2-gfad0 From 82a2b17c1febf544a81cdb4958519489960bcc81 Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Fri, 29 Apr 2022 15:11:25 +0200 Subject: Use profanity.001.log instead of profanity.log.001 for rotated logs Rotated log files will now be: `.local/share/profanity/logs/profanity.001.log` We only use logrotation if we use the default log file ending with .log. So Replacing the `.` should be fine. User supplied log files are not rotated. --- src/log.c | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) (limited to 'src') diff --git a/src/log.c b/src/log.c index 191f8a84..8108151f 100644 --- a/src/log.c +++ b/src/log.c @@ -59,9 +59,6 @@ static FILE* logp; static gchar* mainlogfile = NULL; static gboolean user_provided_log = FALSE; - -static GTimeZone* tz; -static GDateTime* dt; static log_level_t level_filter; static GHashTable* logs; @@ -150,7 +147,6 @@ void log_init(log_level_t filter, char* log_file) { level_filter = filter; - tz = g_time_zone_new_local(); if (log_file) { user_provided_log = TRUE; @@ -182,7 +178,6 @@ log_close(void) { g_free(mainlogfile); mainlogfile = NULL; - g_time_zone_unref(tz); if (logp) { fclose(logp); } @@ -192,7 +187,7 @@ void log_msg(log_level_t level, const char* const area, const char* const msg) { if (level >= level_filter && logp) { - dt = g_date_time_new_now(tz); + GDateTime* dt = g_date_time_new_now_local(); char* level_str = _log_string_from_level(level); @@ -235,17 +230,27 @@ _rotate_log_file(void) { gchar* log_file = g_strdup(mainlogfile); size_t len = strlen(log_file); - gchar* log_file_new = malloc(len + 4); + gchar* log_file_new = malloc(len + 5); + + // the mainlog file should always end in '.log', lets remove this last part + // so that we can have profanity.001.log later + if (len > 4) { + log_file[len - 4] = '\0'; + } // find an empty name. from .log -> log.001 -> log.999 for (int i = 1; i < 1000; i++) { - g_sprintf(log_file_new, "%s.%03d", log_file, i); + g_sprintf(log_file_new, "%s.%03d.log", log_file, i); if (!g_file_test(log_file_new, G_FILE_TEST_EXISTS)) break; } log_close(); + if (len > 4) { + log_file[len - 4] = '.'; + } + rename(log_file, log_file_new); log_init(log_get_filter(), NULL); -- cgit 1.4.1-2-gfad0