xref: /openbsd-src/lib/libcbor/src/cbor/arrays.h (revision 4dcc46c4d04180142eda526ce521dfb137776d05)
1da0d961cSdjm /*
2d3425be1Sdjm  * Copyright (c) 2014-2020 Pavel Kalvoda <me@pavelkalvoda.com>
3da0d961cSdjm  *
4da0d961cSdjm  * libcbor is free software; you can redistribute it and/or modify
5da0d961cSdjm  * it under the terms of the MIT license. See LICENSE for details.
6da0d961cSdjm  */
7da0d961cSdjm 
8da0d961cSdjm #ifndef LIBCBOR_ARRAYS_H
9da0d961cSdjm #define LIBCBOR_ARRAYS_H
10da0d961cSdjm 
11*4dcc46c4Sdjm #include "cbor/cbor_export.h"
12da0d961cSdjm #include "cbor/common.h"
13da0d961cSdjm 
14da0d961cSdjm #ifdef __cplusplus
15da0d961cSdjm extern "C" {
16da0d961cSdjm #endif
17da0d961cSdjm 
18da0d961cSdjm /** Get the number of members
19da0d961cSdjm  *
20da0d961cSdjm  * @param item[borrow] An array
21da0d961cSdjm  * @return The number of members
22da0d961cSdjm  */
23*4dcc46c4Sdjm _CBOR_NODISCARD
24*4dcc46c4Sdjm CBOR_EXPORT size_t cbor_array_size(const cbor_item_t* item);
25da0d961cSdjm 
26da0d961cSdjm /** Get the size of the allocated storage
27da0d961cSdjm  *
28da0d961cSdjm  * @param item[borrow] An array
29da0d961cSdjm  * @return The size of the allocated storage (number of items)
30da0d961cSdjm  */
31*4dcc46c4Sdjm _CBOR_NODISCARD
32*4dcc46c4Sdjm CBOR_EXPORT size_t cbor_array_allocated(const cbor_item_t* item);
33da0d961cSdjm 
34da0d961cSdjm /** Get item by index
35da0d961cSdjm  *
36da0d961cSdjm  * @param item[borrow] An array
37da0d961cSdjm  * @param index The index
38da0d961cSdjm  * @return **incref** The item, or `NULL` in case of boundary violation
39da0d961cSdjm  */
40*4dcc46c4Sdjm _CBOR_NODISCARD
41*4dcc46c4Sdjm CBOR_EXPORT cbor_item_t* cbor_array_get(const cbor_item_t* item, size_t index);
42da0d961cSdjm 
43da0d961cSdjm /** Set item by index
44da0d961cSdjm  *
45*4dcc46c4Sdjm  * If the index is out of bounds, the array is not modified and false is
46*4dcc46c4Sdjm  * returned. Creating arrays with holes is not possible.
47da0d961cSdjm  *
48da0d961cSdjm  * @param item[borrow] An array
49da0d961cSdjm  * @param value[incref] The item to assign
50da0d961cSdjm  * @param index The index, first item is 0.
51da0d961cSdjm  * @return true on success, false on allocation failure.
52da0d961cSdjm  */
53*4dcc46c4Sdjm _CBOR_NODISCARD
54*4dcc46c4Sdjm CBOR_EXPORT bool cbor_array_set(cbor_item_t* item, size_t index,
55*4dcc46c4Sdjm                                 cbor_item_t* value);
56da0d961cSdjm 
57da0d961cSdjm /** Replace item at an index
58da0d961cSdjm  *
59da0d961cSdjm  * The item being replace will be #cbor_decref 'ed.
60da0d961cSdjm  *
61da0d961cSdjm  * @param item[borrow] An array
62da0d961cSdjm  * @param value[incref] The item to assign
63da0d961cSdjm  * @param index The index, first item is 0.
64da0d961cSdjm  * @return true on success, false on allocation failure.
65da0d961cSdjm  */
66*4dcc46c4Sdjm _CBOR_NODISCARD
67*4dcc46c4Sdjm CBOR_EXPORT bool cbor_array_replace(cbor_item_t* item, size_t index,
68*4dcc46c4Sdjm                                     cbor_item_t* value);
69da0d961cSdjm 
70da0d961cSdjm /** Is the array definite?
71da0d961cSdjm  *
72da0d961cSdjm  * @param item[borrow] An array
73da0d961cSdjm  * @return Is the array definite?
74da0d961cSdjm  */
75*4dcc46c4Sdjm _CBOR_NODISCARD
76*4dcc46c4Sdjm CBOR_EXPORT bool cbor_array_is_definite(const cbor_item_t* item);
77da0d961cSdjm 
78da0d961cSdjm /** Is the array indefinite?
79da0d961cSdjm  *
80da0d961cSdjm  * @param item[borrow] An array
81da0d961cSdjm  * @return Is the array indefinite?
82da0d961cSdjm  */
83*4dcc46c4Sdjm _CBOR_NODISCARD
84*4dcc46c4Sdjm CBOR_EXPORT bool cbor_array_is_indefinite(const cbor_item_t* item);
85da0d961cSdjm 
86da0d961cSdjm /** Get the array contents
87da0d961cSdjm  *
889e5c2ddcSdjm  * The items may be reordered and modified as long as references remain
899e5c2ddcSdjm  * consistent.
90da0d961cSdjm  *
91da0d961cSdjm  * @param item[borrow] An array
92da0d961cSdjm  * @return #cbor_array_size items
93da0d961cSdjm  */
94*4dcc46c4Sdjm _CBOR_NODISCARD
95*4dcc46c4Sdjm CBOR_EXPORT cbor_item_t** cbor_array_handle(const cbor_item_t* item);
96da0d961cSdjm 
97da0d961cSdjm /** Create new definite array
98da0d961cSdjm  *
99da0d961cSdjm  * @param size Number of slots to preallocate
100da0d961cSdjm  * @return **new** array or `NULL` upon malloc failure
101da0d961cSdjm  */
102*4dcc46c4Sdjm _CBOR_NODISCARD
103*4dcc46c4Sdjm CBOR_EXPORT cbor_item_t* cbor_new_definite_array(size_t size);
104da0d961cSdjm 
105da0d961cSdjm /** Create new indefinite array
106da0d961cSdjm  *
107da0d961cSdjm  * @return **new** array or `NULL` upon malloc failure
108da0d961cSdjm  */
109*4dcc46c4Sdjm _CBOR_NODISCARD
110*4dcc46c4Sdjm CBOR_EXPORT cbor_item_t* cbor_new_indefinite_array(void);
111da0d961cSdjm 
112da0d961cSdjm /** Append to the end
113da0d961cSdjm  *
114*4dcc46c4Sdjm  * For indefinite items, storage may be reallocated. For definite items, only
1159e5c2ddcSdjm  * the preallocated capacity is available.
116da0d961cSdjm  *
117da0d961cSdjm  * @param array[borrow] An array
118da0d961cSdjm  * @param pushee[incref] The item to push
119da0d961cSdjm  * @return true on success, false on failure
120da0d961cSdjm  */
121*4dcc46c4Sdjm _CBOR_NODISCARD
122*4dcc46c4Sdjm CBOR_EXPORT bool cbor_array_push(cbor_item_t* array, cbor_item_t* pushee);
123da0d961cSdjm 
124da0d961cSdjm #ifdef __cplusplus
125da0d961cSdjm }
126da0d961cSdjm #endif
127da0d961cSdjm 
128da0d961cSdjm #endif  // LIBCBOR_ARRAYS_H
129