aboutsummaryrefslogtreecommitdiff
path: root/collections
diff options
context:
space:
mode:
Diffstat (limited to 'collections')
-rw-r--r--collections/double_ended_queue.c35
1 files changed, 21 insertions, 14 deletions
diff --git a/collections/double_ended_queue.c b/collections/double_ended_queue.c
index 25f3181..b555e3a 100644
--- a/collections/double_ended_queue.c
+++ b/collections/double_ended_queue.c
@@ -73,25 +73,32 @@ deq *root;
void deq_resize(root)
deq *root;
{
- if (root->beg != root->base) {
- memmove(root->base, root->beg, root->end - root->beg);
- root->end = root->base + deq_size(root);
- root->beg = root->base;
- } else {
- root->base = malloc(root->limit * 2 * sizeof(void*));
- assert(root->base);
+ void **tmp;
+ int size;
+ tmp = malloc(root->limit * 2 * sizeof(void*));
+ assert(root->base);
- root->base = memcpy(root->base, root->beg, root->limit * sizeof(void*));
- assert(root->base);
+ if (root->beg > root->end) {
+ /*copy beg<->limit*/
+ size = (root->base + (root->limit*sizeof(void*)) - root->beg);
+ tmp = memcpy(tmp, root->beg, size * sizeof(void*);
+ assert(tmp);
+ /*copy base<->end*/
+ tmp = memcpy(tmp + size, root->beg,
+ (root->end - root->base)* sizeof(void*));
+ assert(tmp);
+ } else {
+ size = deq_size(root);
+ tmp = memcpy(tmp, root->beg, size*sizeof(void*));
+ }
- root->end = root->base + deq_size(root);
- root->limit = root->limit * 2;
+ root->limit *= 2;
- free(root->beg);
- root->beg = root->base;
- }
+ free(root->base);
+ root->base = root->beg = tmp;
+ root->end = root->base + size;
}
void* deq_index(root, index)