diff options
author | Tilghman Lesher <tilghman@meg.abyt.es> | 2005-12-23 22:47:26 +0000 |
---|---|---|
committer | Tilghman Lesher <tilghman@meg.abyt.es> | 2005-12-23 22:47:26 +0000 |
commit | c66748df1c5eaba16f9ff5fbba75918ffcfa3405 (patch) | |
tree | bb909c48643680f66b6a7b87b3d4ff02816ef7ff /pbx.c | |
parent | 5323442db4dfa9dd3dc891fe5b9d6ea32497dd94 (diff) |
Alphabetize the functions list
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@7615 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'pbx.c')
-rw-r--r-- | pbx.c | 28 |
1 files changed, 26 insertions, 2 deletions
@@ -1275,6 +1275,9 @@ int ast_custom_function_unregister(struct ast_custom_function *acf) int ast_custom_function_register(struct ast_custom_function *acf) { + struct ast_custom_function *cur, *last = NULL; + int found = 0; + if (!acf) return -1; @@ -1290,8 +1293,29 @@ int ast_custom_function_register(struct ast_custom_function *acf) return -1; } - acf->next = acf_root; - acf_root = acf; + for (cur = acf_root; cur; cur = cur->next) { + if (strcmp(acf->name, cur->name) < 0) { + found = 1; + if (last) { + acf->next = cur; + last->next = acf; + } else { + acf->next = acf_root; + acf_root = acf; + } + break; + } + last = cur; + } + + /* Wasn't before anything else, put it at the end */ + if (!found) { + if (last) + last->next = acf; + else + acf_root = acf; + acf->next = NULL; + } ast_mutex_unlock(&acflock); |