[Freeswitch-svn] [commit] r6515 - freeswitch/trunk/src/mod/loggers/mod_logfile
Freeswitch SVN
mikej at freeswitch.org
Wed Dec 5 07:52:38 EST 2007
Author: mikej
Date: Wed Dec 5 07:52:37 2007
New Revision: 6515
Modified:
freeswitch/trunk/src/mod/loggers/mod_logfile/mod_logfile.c
Log:
another step towards multi-profile file logger.
Modified: freeswitch/trunk/src/mod/loggers/mod_logfile/mod_logfile.c
==============================================================================
--- freeswitch/trunk/src/mod/loggers/mod_logfile/mod_logfile.c (original)
+++ freeswitch/trunk/src/mod/loggers/mod_logfile/mod_logfile.c Wed Dec 5 07:52:37 2007
@@ -42,6 +42,9 @@
static const uint8_t STATIC_LEVELS[] = {0, 1, 2, 3, 4, 5, 6, 7, 8};
static switch_memory_pool_t *module_pool = NULL;
+static switch_hash_t *log_hash = NULL;
+static switch_hash_t *name_hash = NULL;
+static switch_hash_t *profile_hash = NULL;
static struct {
int rotate;
@@ -54,6 +57,7 @@
};
struct logfile_profile {
+ char *name;
unsigned int log_fd;
switch_size_t log_size; /* keep the log size in check for rotation */
switch_size_t roll_size; /* the size that we want to rotate the file at */
@@ -66,7 +70,25 @@
static logfile_profile_t *default_profile;
-static switch_status_t load_config(logfile_profile_t *profile, switch_xml_t xml);
+static switch_status_t load_profile(logfile_profile_t *profile, switch_xml_t xml);
+
+static void del_mapping(char *var)
+{
+ switch_core_hash_insert(log_hash, var, NULL);
+}
+
+static void add_mapping(char *var, logfile_profile_t *profile)
+{
+ char *name;
+
+ if (!(name = switch_core_hash_find(name_hash, var))) {
+ name = switch_core_strdup(module_pool, var);
+ switch_core_hash_insert(name_hash, name, name);
+ }
+
+ del_mapping(name);
+ switch_core_hash_insert(log_hash, name, (void *) profile);
+}
void process_levels(logfile_profile_t *profile, char *p)
{
@@ -244,7 +266,7 @@
return SWITCH_STATUS_SUCCESS;
}
-static switch_status_t load_config(logfile_profile_t *profile, switch_xml_t xml)
+static switch_status_t load_profile(logfile_profile_t *profile, switch_xml_t xml)
{
switch_xml_t param;
@@ -301,6 +323,19 @@
memset(&globals, 0, sizeof(globals));
switch_mutex_init(&globals.mutex, SWITCH_MUTEX_NESTED, module_pool);
+ if (log_hash) {
+ switch_core_hash_destroy(&log_hash);
+ }
+ if (name_hash) {
+ switch_core_hash_destroy(&name_hash);
+ }
+ if (profile_hash) {
+ switch_core_hash_destroy(&profile_hash);
+ }
+ switch_core_hash_init(&log_hash, module_pool);
+ switch_core_hash_init(&name_hash, module_pool);
+ switch_core_hash_init(&profile_hash, module_pool);
+
if (switch_event_bind((char *) modname, SWITCH_EVENT_TRAP, SWITCH_EVENT_SUBCLASS_ANY, event_handler, NULL) != SWITCH_STATUS_SUCCESS) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Couldn't bind!\n");
return SWITCH_STATUS_GENERR;
@@ -323,13 +358,18 @@
}
if ((profiles = switch_xml_child(cfg, "profiles"))) {
for (xprofile = switch_xml_child(profiles, "profile"); xprofile; xprofile = xprofile->next) {
+ char *name = (char *) switch_xml_attr_soft(xprofile, "name");
if (!(settings = switch_xml_child(xprofile, "settings"))) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "No Settings, check the new config!\n");
} else {
- /* TODO: handle alloc of profile for multiple profiles*/
- default_profile = switch_core_alloc(module_pool, sizeof(*default_profile));
- memset(default_profile, 0, sizeof(*default_profile));
- load_config(default_profile, settings);
+ logfile_profile_t *profile;
+ profile = switch_core_alloc(module_pool, sizeof(*default_profile));
+ memset(profile, 0, sizeof(*profile));
+ profile->name = switch_core_strdup(module_pool, switch_str_nil(name));
+ load_profile(profile, settings);
+ switch_core_hash_insert(profile_hash, profile->name, (void *) profile);
+ /* TODO: remove default_profile */
+ default_profile = profile;
}
}
}
More information about the Freeswitch-svn
mailing list