summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2004-03-30 19:25:43 +0000
committerNick Mathewson <nickm@torproject.org>2004-03-30 19:25:43 +0000
commitabcf3d934186d02e54253a57504138b900521ef7 (patch)
tree21b22e2c1e095999a5b47031ab909318fe5ff010 /src/common
parent32cc2e590929a3679aebeeb836dcf46762a57c35 (diff)
downloadtor-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.c22
-rw-r--r--src/common/util.h2
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);