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