diff options
author | shennetsind <ind@henn.et> | 2013-09-29 09:32:33 -0300 |
---|---|---|
committer | shennetsind <ind@henn.et> | 2013-09-29 09:32:33 -0300 |
commit | dbd0dce80cdc7ea02391d5e096b6561f0b598259 (patch) | |
tree | 69ecb3fe59c096fd79c0a6909298e6199b299e88 /src/common/db.c | |
parent | c7af219aec5c8a5909ebfa1c7bb1fd4b5597f42a (diff) | |
parent | 5697031dce0f02a55044504077775b909a42982d (diff) | |
download | hercules-dbd0dce80cdc7ea02391d5e096b6561f0b598259.tar.gz hercules-dbd0dce80cdc7ea02391d5e096b6561f0b598259.tar.bz2 hercules-dbd0dce80cdc7ea02391d5e096b6561f0b598259.tar.xz hercules-dbd0dce80cdc7ea02391d5e096b6561f0b598259.zip |
Merge branch 'master' of https://github.com/HerculesWS/Hercules
Diffstat (limited to 'src/common/db.c')
-rw-r--r-- | src/common/db.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/src/common/db.c b/src/common/db.c index bd2bea424..b3a58e0a4 100644 --- a/src/common/db.c +++ b/src/common/db.c @@ -2730,20 +2730,26 @@ void linkdb_insert( struct linkdb_node** head, void *key, void* data) node->data = data; } -void linkdb_foreach( struct linkdb_node** head, LinkDBFunc func, ... ) -{ +void linkdb_vforeach( struct linkdb_node** head, LinkDBFunc func, va_list ap) { struct linkdb_node *node; if( head == NULL ) return; node = *head; while ( node ) { - va_list args; - va_start(args, func); - func( node->key, node->data, args ); - va_end(args); + va_list argscopy; + va_copy(argscopy, ap); + func(node->key, node->data, argscopy); + va_end(argscopy); node = node->next; } } +void linkdb_foreach( struct linkdb_node** head, LinkDBFunc func, ...) { + va_list ap; + va_start(ap, func); + linkdb_vforeach(head, func, ap); + va_end(ap); +} + void* linkdb_search( struct linkdb_node** head, void *key) { int n = 0; |