blob: ac524bc371080513500ee49996ebadba8189e48b [file] [log] [blame]
Neels Hofmeyr17518fe2017-06-20 04:35:06 +02001/*! \file vector.h
2 * Generic vector interface header. */
Harald Welte3fb0b6f2010-05-19 19:02:52 +02003/*
Harald Welte3fb0b6f2010-05-19 19:02:52 +02004 * Copyright (C) 1997, 98 Kunihiro Ishiguro
5 *
6 * This file is part of GNU Zebra.
7 *
8 * GNU Zebra is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the
10 * Free Software Foundation; either version 2, or (at your option) any
11 * later version.
12 *
13 * GNU Zebra is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
Harald Welte3fb0b6f2010-05-19 19:02:52 +020017 */
18
Sylvain Munaut12ba7782014-06-16 10:13:40 +020019#pragma once
Harald Welte3fb0b6f2010-05-19 19:02:52 +020020
21/* struct for vector */
22struct _vector {
23 unsigned int active; /* number of active slots */
24 unsigned int alloced; /* number of allocated slot */
25 void **index; /* index to data */
26};
27typedef struct _vector *vector;
28
29#define VECTOR_MIN_SIZE 1
30
31/* (Sometimes) usefull macros. This macro convert index expression to
32 array expression. */
33/* Reference slot at given index, caller must ensure slot is active */
34#define vector_slot(V,I) ((V)->index[(I)])
35/* Number of active slots.
36 * Note that this differs from vector_count() as it the count returned
37 * will include any empty slots
38 */
39#define vector_active(V) ((V)->active)
40
41/* Prototypes. */
42vector vector_init(unsigned int size);
43void vector_ensure(vector v, unsigned int num);
44int vector_empty_slot(vector v);
45int vector_set(vector v, void *val);
46int vector_set_index(vector v, unsigned int i, void *val);
47void vector_unset(vector v, unsigned int i);
48unsigned int vector_count(vector v);
49void vector_only_wrapper_free(vector v);
50void vector_only_index_free(void *index);
51void vector_free(vector v);
52vector vector_copy(vector v);
53
54void *vector_lookup(vector, unsigned int);
55void *vector_lookup_ensure(vector, unsigned int);
56
57extern void *tall_vty_vec_ctx;