2005-02-20 14:27:00 +00:00
|
|
|
#ifndef ARRAY_H
|
|
|
|
#define ARRAY_H
|
2016-03-19 15:14:35 +00:00
|
|
|
#include "first.h"
|
2009-10-11 14:31:42 +00:00
|
|
|
|
2005-02-20 14:27:00 +00:00
|
|
|
#include "buffer.h"
|
|
|
|
|
2018-09-23 02:12:51 +00:00
|
|
|
struct data_unset; /* declaration */
|
|
|
|
|
|
|
|
struct data_methods {
|
|
|
|
struct data_unset *(*copy)(const struct data_unset *src); \
|
|
|
|
void (*free)(struct data_unset *p); \
|
|
|
|
int (*insert_dup)(struct data_unset *dst, struct data_unset *src); \
|
|
|
|
void (*print)(const struct data_unset *p, int depth);
|
|
|
|
};
|
|
|
|
|
2019-10-23 01:16:03 +00:00
|
|
|
typedef enum { TYPE_STRING, TYPE_ARRAY, TYPE_INTEGER, TYPE_CONFIG, TYPE_OTHER } data_type_t;
|
2005-02-20 14:27:00 +00:00
|
|
|
#define DATA_UNSET \
|
2019-10-13 07:37:59 +00:00
|
|
|
buffer key; \
|
|
|
|
const struct data_methods *fn; /* function table */ \
|
|
|
|
data_type_t type
|
2005-02-20 14:27:00 +00:00
|
|
|
|
|
|
|
typedef struct data_unset {
|
|
|
|
DATA_UNSET;
|
|
|
|
} data_unset;
|
|
|
|
|
|
|
|
typedef struct {
|
2019-10-16 02:45:30 +00:00
|
|
|
data_unset **data;
|
|
|
|
data_unset **sorted;
|
2019-10-14 05:44:06 +00:00
|
|
|
|
2019-10-02 05:54:15 +00:00
|
|
|
uint32_t used; /* <= INT32_MAX */
|
|
|
|
uint32_t size;
|
2005-02-20 14:27:00 +00:00
|
|
|
} array;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
DATA_UNSET;
|
2020-09-11 21:25:43 +00:00
|
|
|
int ext; /*(fits in space due to alignment in 64-bit; extends 32-bit)*/
|
2019-10-13 08:59:57 +00:00
|
|
|
buffer value;
|
2005-02-20 14:27:00 +00:00
|
|
|
} data_string;
|
|
|
|
|
|
|
|
data_string *data_string_init(void);
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
DATA_UNSET;
|
2006-10-04 13:26:23 +00:00
|
|
|
|
2019-10-13 21:06:05 +00:00
|
|
|
array value;
|
2005-02-20 14:27:00 +00:00
|
|
|
} data_array;
|
|
|
|
|
|
|
|
data_array *data_array_init(void);
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
DATA_UNSET;
|
2006-10-04 13:26:23 +00:00
|
|
|
|
2005-02-20 14:27:00 +00:00
|
|
|
int value;
|
|
|
|
} data_integer;
|
|
|
|
|
|
|
|
data_integer *data_integer_init(void);
|
|
|
|
|
2019-10-09 03:31:34 +00:00
|
|
|
__attribute_returns_nonnull__
|
2019-11-22 05:57:48 +00:00
|
|
|
array *array_init(uint32_t n);
|
2019-10-02 06:16:08 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
2019-10-13 21:06:05 +00:00
|
|
|
void array_copy_array(array *dst, const array *src);
|
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
void array_free_data(array *a);
|
2019-10-02 06:16:08 +00:00
|
|
|
|
2005-02-20 14:27:00 +00:00
|
|
|
void array_free(array *a);
|
2019-10-02 06:16:08 +00:00
|
|
|
|
2019-10-02 05:54:15 +00:00
|
|
|
__attribute_hot__
|
2018-10-23 00:28:53 +00:00
|
|
|
void array_reset_data_strings(array *a);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
2016-03-15 18:26:57 +00:00
|
|
|
void array_insert_unique(array *a, data_unset *entry);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
2016-03-15 18:26:57 +00:00
|
|
|
data_unset *array_pop(array *a); /* only works on "simple" lists with autogenerated keys */
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
__attribute_pure__
|
|
|
|
int array_is_vlist(const array *a);
|
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
__attribute_pure__
|
|
|
|
int array_is_kvany(const array *a);
|
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
__attribute_pure__
|
|
|
|
int array_is_kvarray(const array *a);
|
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
__attribute_pure__
|
|
|
|
int array_is_kvstring(const array *a);
|
|
|
|
|
2020-09-11 21:25:43 +00:00
|
|
|
__attribute_pure__
|
|
|
|
data_unset *array_get_element_klen_ext(const array *a, int ext, const char *key, uint32_t klen);
|
|
|
|
|
2019-10-02 05:54:15 +00:00
|
|
|
__attribute_pure__
|
2020-09-11 18:22:34 +00:00
|
|
|
data_unset *array_get_element_klen(const array *a, const char *key, uint32_t klen);
|
2019-10-10 03:24:25 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
__attribute_pure__
|
2020-09-11 18:22:34 +00:00
|
|
|
data_unset *array_get_data_unset(const array *a, const char *key, uint32_t klen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
2020-09-11 18:22:34 +00:00
|
|
|
data_unset *array_extract_element_klen(array *a, const char *key, uint32_t klen); /* removes found entry from array */
|
2019-10-02 05:54:15 +00:00
|
|
|
|
2019-10-09 03:31:34 +00:00
|
|
|
__attribute_returns_nonnull__
|
2020-09-11 18:22:34 +00:00
|
|
|
int * array_get_int_ptr(array *a, const char *k, uint32_t klen);
|
2020-09-11 21:25:43 +00:00
|
|
|
|
|
|
|
__attribute_returns_nonnull__
|
|
|
|
buffer * array_get_buf_ptr_ext(array *a, int ext, const char *k, uint32_t klen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
2019-10-09 03:31:34 +00:00
|
|
|
__attribute_returns_nonnull__
|
2020-09-11 18:22:34 +00:00
|
|
|
buffer * array_get_buf_ptr(array *a, const char *k, uint32_t klen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
2020-09-11 18:22:34 +00:00
|
|
|
void array_insert_value(array *a, const char *v, uint32_t vlen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
2020-09-11 18:22:34 +00:00
|
|
|
static inline void array_set_key_value(array * const a, const char * const k, const uint32_t klen, const char * const v, const uint32_t vlen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
2020-09-11 18:22:34 +00:00
|
|
|
static inline void array_set_key_value(array * const a, const char * const k, const uint32_t klen, const char * const v, const uint32_t vlen) {
|
2019-10-02 05:54:15 +00:00
|
|
|
buffer_copy_string_len(array_get_buf_ptr(a, k, klen), v, vlen);
|
|
|
|
}
|
|
|
|
|
|
|
|
__attribute_cold__
|
2016-03-15 18:26:57 +00:00
|
|
|
void array_replace(array *a, data_unset *entry);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_cold__
|
|
|
|
int array_print(const array *a, int depth);
|
|
|
|
|
|
|
|
__attribute_cold__
|
2005-08-08 10:16:53 +00:00
|
|
|
void array_print_indent(int depth);
|
2005-02-20 14:27:00 +00:00
|
|
|
|
2019-10-02 05:54:15 +00:00
|
|
|
__attribute_cold__
|
|
|
|
__attribute_pure__
|
2020-09-11 18:22:34 +00:00
|
|
|
uint32_t array_get_max_key_length(const array *a);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2020-09-11 18:22:34 +00:00
|
|
|
data_unset * array_match_key_prefix_klen (const array * const a, const char * const s, const uint32_t slen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2020-09-11 18:22:34 +00:00
|
|
|
data_unset * array_match_key_prefix_nc_klen (const array * const a, const char * const s, const uint32_t slen);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
data_unset * array_match_key_prefix (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
data_unset * array_match_key_prefix_nc (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
const buffer * array_match_value_prefix (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
const buffer * array_match_value_prefix_nc (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
data_unset * array_match_key_suffix (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
data_unset * array_match_key_suffix_nc (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
const buffer * array_match_value_suffix (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
const buffer * array_match_value_suffix_nc (const array * const a, const buffer * const b);
|
2019-10-02 05:54:15 +00:00
|
|
|
|
|
|
|
__attribute_pure__
|
2018-09-16 17:27:18 +00:00
|
|
|
data_unset * array_match_path_or_ext (const array * const a, const buffer * const b);
|
|
|
|
|
2005-02-20 14:27:00 +00:00
|
|
|
#endif
|