diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-03-30 19:25:43 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-03-30 19:25:43 +0000 |
commit | abcf3d934186d02e54253a57504138b900521ef7 (patch) | |
tree | 21b22e2c1e095999a5b47031ab909318fe5ff010 /src/common | |
parent | 32cc2e590929a3679aebeeb836dcf46762a57c35 (diff) | |
download | tor-abcf3d934186d02e54253a57504138b900521ef7.tar.gz tor-abcf3d934186d02e54253a57504138b900521ef7.zip |
Make smartlists start small and grow as needed.
svn:r1394
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/util.c | 22 | ||||
-rw-r--r-- | src/common/util.h | 2 |
2 files changed, 21 insertions, 3 deletions
diff --git a/src/common/util.c b/src/common/util.c index 80299c4e38..7afc854e0f 100644 --- a/src/common/util.c +++ b/src/common/util.c @@ -117,12 +117,17 @@ void set_uint32(char *cp, uint32_t v) * _add() adds an element, _remove() removes an element if it's there, * _choose() returns a random element. */ +#define SL_DEFAULT_CAPACITY 32 smartlist_t *smartlist_create(int max_elements) { smartlist_t *sl = tor_malloc(sizeof(smartlist_t)); - sl->list = tor_malloc(sizeof(void *) * max_elements); sl->num_used = 0; sl->max = max_elements; + if (max_elements <= SL_DEFAULT_CAPACITY) + sl->capacity = max_elements; + else + sl->capacity = SL_DEFAULT_CAPACITY; + sl->list = tor_malloc(sizeof(void *) * sl->capacity); return sl; } @@ -131,11 +136,22 @@ void smartlist_free(smartlist_t *sl) { free(sl); } +void smartlist_grow_capacity(smartlist_t *sl, int n) { + if (sl->capacity < n) { + sl->capacity = n; + sl->list = tor_realloc(sl->list, sizeof(void*)*sl->capacity); + } +} + /* add element to the list, but only if there's room */ void smartlist_add(smartlist_t *sl, void *element) { - if(sl->num_used < sl->max) + if (sl->num_used < sl->max) { + if (sl->num_used >= sl->capacity) { + sl->capacity *= 2; + sl->list = tor_realloc(sl->list, sizeof(void*)*sl->capacity); + } sl->list[sl->num_used++] = element; - else + } else log_fn(LOG_WARN,"We've already got %d elements, discarding.",sl->max); } diff --git a/src/common/util.h b/src/common/util.h index f7ac07fca7..3907a0d941 100644 --- a/src/common/util.h +++ b/src/common/util.h @@ -62,10 +62,12 @@ typedef struct { void **list; int num_used; int max; + int capacity; } smartlist_t; smartlist_t *smartlist_create(int max_elements); void smartlist_free(smartlist_t *sl); +void smartlist_grow_capacity(smartlist_t *sl, int n); void smartlist_add(smartlist_t *sl, void *element); void smartlist_remove(smartlist_t *sl, void *element); int smartlist_isin(smartlist_t *sl, void *element); |