adding arraylist to LLT
This commit is contained in:
		
							parent
							
								
									7d652f9c5a
								
							
						
					
					
						commit
						716a6447f9
					
				| 
						 | 
					@ -3,7 +3,7 @@ CC = gcc
 | 
				
			||||||
SRCS = bitvector.c hashing.c socket.c timefuncs.c dblprint.c ptrhash.c \
 | 
					SRCS = bitvector.c hashing.c socket.c timefuncs.c dblprint.c ptrhash.c \
 | 
				
			||||||
	utf8.c ios.c operators.c cplxprint.c dirpath.c htable.c \
 | 
						utf8.c ios.c operators.c cplxprint.c dirpath.c htable.c \
 | 
				
			||||||
	bitvector-ops.c fp.c int2str.c dump.c random.c bswap.c memalign.c \
 | 
						bitvector-ops.c fp.c int2str.c dump.c random.c bswap.c memalign.c \
 | 
				
			||||||
	swapreverse.c lltinit.c
 | 
						swapreverse.c lltinit.c arraylist.c
 | 
				
			||||||
OBJS = $(SRCS:%.c=%.o)
 | 
					OBJS = $(SRCS:%.c=%.o)
 | 
				
			||||||
DOBJS = $(SRCS:%.c=%.do)
 | 
					DOBJS = $(SRCS:%.c=%.do)
 | 
				
			||||||
TARGET = libllt.a
 | 
					TARGET = libllt.a
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,69 @@
 | 
				
			||||||
 | 
					#include <stdlib.h>
 | 
				
			||||||
 | 
					#include <stdio.h>
 | 
				
			||||||
 | 
					#include <string.h>
 | 
				
			||||||
 | 
					#include <assert.h>
 | 
				
			||||||
 | 
					#include <limits.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "dtypes.h"
 | 
				
			||||||
 | 
					#include "arraylist.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					arraylist_t *arraylist_new(arraylist_t *a, size_t size)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    a->len = 0;
 | 
				
			||||||
 | 
					    if (size <= AL_N_INLINE) {
 | 
				
			||||||
 | 
					        a->items = &a->_space[0];
 | 
				
			||||||
 | 
					        a->max = AL_N_INLINE;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    else {
 | 
				
			||||||
 | 
					        a->items = (void**)LLT_ALLOC(size*sizeof(void*));
 | 
				
			||||||
 | 
					        a->max = size;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if (a->items == NULL) return NULL;
 | 
				
			||||||
 | 
					    return a;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void arraylist_free(arraylist_t *a)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    if (a->items != &a->_space[0])
 | 
				
			||||||
 | 
					        LLT_FREE(a->items);
 | 
				
			||||||
 | 
					    a->len = 0;
 | 
				
			||||||
 | 
					    a->max = AL_N_INLINE;
 | 
				
			||||||
 | 
					    a->items = &a->_space[0];
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void al_grow(arraylist_t *a, size_t n)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    if (a->len+n > a->max) {
 | 
				
			||||||
 | 
					        if (a->items == &a->_space[0]) {
 | 
				
			||||||
 | 
					            void **p = LLT_ALLOC((a->len+n)*sizeof(void*));
 | 
				
			||||||
 | 
					            if (p == NULL) return;
 | 
				
			||||||
 | 
					            memcpy(p, a->items, a->len*sizeof(void*));
 | 
				
			||||||
 | 
					            a->items = p;
 | 
				
			||||||
 | 
					            a->max = a->len+n;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        else {
 | 
				
			||||||
 | 
					            size_t nm = a->max*2;
 | 
				
			||||||
 | 
					            if (nm == 0) nm = 1;
 | 
				
			||||||
 | 
					            while (a->len+n > nm) nm*=2;
 | 
				
			||||||
 | 
					            void **p = LLT_REALLOC(a->items, nm);
 | 
				
			||||||
 | 
					            if (p == NULL) return;
 | 
				
			||||||
 | 
					            a->items = p;
 | 
				
			||||||
 | 
					            a->max = nm;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    a->len += n;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void arraylist_push(arraylist_t *a, void *elt)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    al_grow(a, 1);
 | 
				
			||||||
 | 
					    a->items[a->len-1] = elt;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void *arraylist_pop(arraylist_t *a)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    if (a->len == 0) return NULL;
 | 
				
			||||||
 | 
					    void *p = a->items[--a->len];
 | 
				
			||||||
 | 
					    a->items[a->len] = NULL;
 | 
				
			||||||
 | 
					    return p;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,19 @@
 | 
				
			||||||
 | 
					#ifndef __ARRAYLIST_H_
 | 
				
			||||||
 | 
					#define __ARRAYLIST_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define AL_N_INLINE 29
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef struct {
 | 
				
			||||||
 | 
					    size_t len;
 | 
				
			||||||
 | 
					    size_t max;
 | 
				
			||||||
 | 
					    void **items;
 | 
				
			||||||
 | 
					    void *_space[AL_N_INLINE];
 | 
				
			||||||
 | 
					} arraylist_t;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					arraylist_t *arraylist_new(arraylist_t *a, size_t size);
 | 
				
			||||||
 | 
					void arraylist_free(arraylist_t *a);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void arraylist_push(arraylist_t *a, void *elt);
 | 
				
			||||||
 | 
					void *arraylist_pop(arraylist_t *a);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		Loading…
	
		Reference in New Issue