1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-12-04 14:46:46 -05:00

refactor logfile-name creation

Signed-off-by: Steffen Jaeckel <jaeckel-floss@eyet-services.de>
This commit is contained in:
Steffen Jaeckel 2022-03-13 12:04:11 +01:00
parent 705b6f7806
commit 43e5f15e66

View File

@ -90,9 +90,7 @@ static struct dated_chat_log* _create_log(const char* const other, const char* c
static struct dated_chat_log* _create_groupchat_log(const char* const room, const char* const login); static struct dated_chat_log* _create_groupchat_log(const char* const room, const char* const login);
static void _free_chat_log(struct dated_chat_log* dated_log); static void _free_chat_log(struct dated_chat_log* dated_log);
static gboolean _key_equals(void* key1, void* key2); static gboolean _key_equals(void* key1, void* key2);
static char* _get_log_filename(const char* const other, const char* const login, GDateTime* dt, gboolean create); static char* _get_log_filename(const char* const other, const char* const login, GDateTime* dt, gboolean is_room);
static char* _get_groupchat_log_filename(const char* const room, const char* const login, GDateTime* dt,
gboolean create);
static void _rotate_log_file(void); static void _rotate_log_file(void);
static char* _log_string_from_level(log_level_t level); static char* _log_string_from_level(log_level_t level);
static void _chat_log_chat(const char* const login, const char* const other, const gchar* const msg, static void _chat_log_chat(const char* const login, const char* const other, const gchar* const msg,
@ -612,7 +610,7 @@ static struct dated_chat_log*
_create_log(const char* const other, const char* const login) _create_log(const char* const other, const char* const login)
{ {
GDateTime* now = g_date_time_new_now_local(); GDateTime* now = g_date_time_new_now_local();
char* filename = _get_log_filename(other, login, now, TRUE); char* filename = _get_log_filename(other, login, now, FALSE);
struct dated_chat_log* new_log = malloc(sizeof(struct dated_chat_log)); struct dated_chat_log* new_log = malloc(sizeof(struct dated_chat_log));
new_log->filename = strdup(filename); new_log->filename = strdup(filename);
@ -627,7 +625,7 @@ static struct dated_chat_log*
_create_groupchat_log(const char* const room, const char* const login) _create_groupchat_log(const char* const room, const char* const login)
{ {
GDateTime* now = g_date_time_new_now_local(); GDateTime* now = g_date_time_new_now_local();
char* filename = _get_groupchat_log_filename(room, login, now, TRUE); char* filename = _get_log_filename(room, login, now, TRUE);
struct dated_chat_log* new_log = malloc(sizeof(struct dated_chat_log)); struct dated_chat_log* new_log = malloc(sizeof(struct dated_chat_log));
new_log->filename = strdup(filename); new_log->filename = strdup(filename);
@ -677,70 +675,16 @@ _key_equals(void* key1, void* key2)
} }
static char* static char*
_get_log_filename(const char* const other, const char* const login, GDateTime* dt, gboolean create) _get_log_filename(const char* const other, const char* const login, GDateTime* dt, gboolean is_room)
{ {
char* chatlogs_dir = files_get_data_path(DIR_CHATLOGS); gchar* chatlogs_dir = files_file_in_account_data_path(DIR_CHATLOGS, login, is_room ? "rooms" : NULL);
GString* log_file = g_string_new(chatlogs_dir); gchar* logfile_name = g_date_time_format(dt, "%Y_%m_%d.log");
free(chatlogs_dir); gchar* logfile_path = files_file_in_account_data_path(chatlogs_dir, other, logfile_name);
gchar* login_dir = str_replace(login, "@", "_at_"); g_free(logfile_name);
g_string_append_printf(log_file, "/%s", login_dir); g_free(chatlogs_dir);
if (create) {
create_dir(log_file->str);
}
free(login_dir);
gchar* other_file = str_replace(other, "@", "_at_"); return logfile_path;
g_string_append_printf(log_file, "/%s", other_file);
if (create) {
create_dir(log_file->str);
}
free(other_file);
gchar* date = g_date_time_format(dt, "/%Y_%m_%d.log");
g_string_append(log_file, date);
g_free(date);
char* result = strdup(log_file->str);
g_string_free(log_file, TRUE);
return result;
}
static char*
_get_groupchat_log_filename(const char* const room, const char* const login, GDateTime* dt, gboolean create)
{
char* chatlogs_dir = files_get_data_path(DIR_CHATLOGS);
GString* log_file = g_string_new(chatlogs_dir);
free(chatlogs_dir);
gchar* login_dir = str_replace(login, "@", "_at_");
g_string_append_printf(log_file, "/%s", login_dir);
if (create) {
create_dir(log_file->str);
}
free(login_dir);
g_string_append(log_file, "/rooms");
if (create) {
create_dir(log_file->str);
}
gchar* room_file = str_replace(room, "@", "_at_");
g_string_append_printf(log_file, "/%s", room_file);
if (create) {
create_dir(log_file->str);
}
free(room_file);
gchar* date = g_date_time_format(dt, "/%Y_%m_%d.log");
g_string_append(log_file, date);
g_free(date);
char* result = strdup(log_file->str);
g_string_free(log_file, TRUE);
return result;
} }
static char* static char*