Skip to content
Snippets Groups Projects
Commit 65e52f3b authored by Kevin P. Fleming's avatar Kevin P. Fleming
Browse files

clean up find_engine()

issue a warning when a config file mapping is found but the desired driver is not available (inspired by bug #4628)


git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@6032 65c4cc65-6c06-0410-ace0-fbb531ad65f3
parent 750e8abd
No related branches found
No related tags found
No related merge requests found
...@@ -852,32 +852,30 @@ int ast_config_engine_deregister(struct ast_config_engine *del) ...@@ -852,32 +852,30 @@ int ast_config_engine_deregister(struct ast_config_engine *del)
static struct ast_config_engine *find_engine(const char *filename, char *database, int dbsiz, char *table, int tabsiz) static struct ast_config_engine *find_engine(const char *filename, char *database, int dbsiz, char *table, int tabsiz)
{ {
struct ast_config_engine *eng, *ret=NULL; struct ast_config_engine *eng, *ret = NULL;
struct ast_config_map *map; struct ast_config_map *map;
ast_mutex_lock(&config_lock); ast_mutex_lock(&config_lock);
map = config_maps; for (map = config_maps; map; map = map->next) {
while (map) {
if (!strcasecmp(filename, map->name)) { if (!strcasecmp(filename, map->name)) {
strncpy(database, map->database, dbsiz-1); ast_copy_string(database, map->database, dbsiz);
if (map->table) ast_copy_string(table, map->table ? map->table : filename, tabsiz);
strncpy(table, map->table, tabsiz-1);
else
strncpy(table, filename, tabsiz-1);
break; break;
} }
map = map->next;
} }
if (map) { if (map) {
for (eng = config_engine_list; eng; eng = eng->next) { for (eng = config_engine_list; !ret && eng; eng = eng->next) {
if (!strcmp(eng->name, map->driver)) { if (!strcasecmp(eng->name, map->driver))
ret = eng; ret = eng;
break;
}
} }
} }
ast_mutex_unlock(&config_lock); ast_mutex_unlock(&config_lock);
/* if we found a mapping, but the engine is not available, then issue a warning */
if (map && !ret)
ast_log(LOG_WARNING, "Mapping for '%s' found to engine '%s', but the engine is not available\n", map->name, map->driver);
return ret; return ret;
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment