diff options
| author | Aryadev Chavali <aryadev@aryadevchavali.com> | 2023-10-15 21:49:30 +0100 | 
|---|---|---|
| committer | Aryadev Chavali <aryadev@aryadevchavali.com> | 2023-10-15 21:50:31 +0100 | 
| commit | c24c1d160702f227cede324999bb5fbd15c7f312 (patch) | |
| tree | 6478cc8bfe5ec24cfe283af084c6ea191a3d87ab /src/darr.h | |
| parent | 98760ee63b6721c440c120df1a4cc638bc36eb22 (diff) | |
| download | ovm-c24c1d160702f227cede324999bb5fbd15c7f312.tar.gz ovm-c24c1d160702f227cede324999bb5fbd15c7f312.tar.bz2 ovm-c24c1d160702f227cede324999bb5fbd15c7f312.zip | |
Implemented a dynamically sized byte array
Pretty simple, want to ensure amortised constant big O so I use a
REALLOC_MULT, which can be redefined if wished.
Diffstat (limited to 'src/darr.h')
| -rw-r--r-- | src/darr.h | 35 | 
1 files changed, 35 insertions, 0 deletions
| diff --git a/src/darr.h b/src/darr.h new file mode 100644 index 0000000..e3103ea --- /dev/null +++ b/src/darr.h @@ -0,0 +1,35 @@ +/* Copyright (C) 2023 Aryadev Chavali + + * You may distribute and modify this code under the terms of the + * GPLv2 license.  You should have received a copy of the GPLv2 + * license with this file.  If not, please write to: + * aryadev@aryadevchavali.com. + + * Created: 2023-10-15 + * Author: Aryadev Chavali + * Description: Dynamically sized byte array + */ + +#ifndef DARR_H +#define DARR_H + +#include <stdlib.h> + +#include "./base.h" + +typedef struct +{ +  byte *data; +  size_t used, available; +} darr_t; + +#define DARR_DEFAULT_SIZE 8 +#define DARR_REALLOC_MULT 1.5 + +void darr_init(darr_t *, size_t); +void darr_ensure_capacity(darr_t *, size_t); +void darr_append_byte(darr_t *, byte); +void darr_append_bytes(darr_t *, byte *, size_t); +byte darr_at(darr_t *, size_t); + +#endif | 
