blob: 0a639ad96dde0edac0cf7285cd71599c432c3582 [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.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with GNU Zebra; see the file COPYING. If not, write to the Free
Jaroslav Škarvada2b82c1c2015-11-11 16:02:54 +010020 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
21 * Boston, MA 02110-1301, USA.
Harald Welte3fb0b6f2010-05-19 19:02:52 +020022 */
23
Sylvain Munaut12ba7782014-06-16 10:13:40 +020024#pragma once
Harald Welte3fb0b6f2010-05-19 19:02:52 +020025
26/* struct for vector */
27struct _vector {
28 unsigned int active; /* number of active slots */
29 unsigned int alloced; /* number of allocated slot */
30 void **index; /* index to data */
31};
32typedef struct _vector *vector;
33
34#define VECTOR_MIN_SIZE 1
35
36/* (Sometimes) usefull macros. This macro convert index expression to
37 array expression. */
38/* Reference slot at given index, caller must ensure slot is active */
39#define vector_slot(V,I) ((V)->index[(I)])
40/* Number of active slots.
41 * Note that this differs from vector_count() as it the count returned
42 * will include any empty slots
43 */
44#define vector_active(V) ((V)->active)
45
46/* Prototypes. */
47vector vector_init(unsigned int size);
48void vector_ensure(vector v, unsigned int num);
49int vector_empty_slot(vector v);
50int vector_set(vector v, void *val);
51int vector_set_index(vector v, unsigned int i, void *val);
52void vector_unset(vector v, unsigned int i);
53unsigned int vector_count(vector v);
54void vector_only_wrapper_free(vector v);
55void vector_only_index_free(void *index);
56void vector_free(vector v);
57vector vector_copy(vector v);
58
59void *vector_lookup(vector, unsigned int);
60void *vector_lookup_ensure(vector, unsigned int);
61
62extern void *tall_vty_vec_ctx;