libamxc  1.10.3
C Generic Data Containers
amxc_astack.h
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** SPDX-License-Identifier: BSD-2-Clause-Patent
4 **
5 ** SPDX-FileCopyrightText: Copyright (c) 2023 SoftAtHome
6 **
7 ** Redistribution and use in source and binary forms, with or without modification,
8 ** are permitted provided that the following conditions are met:
9 **
10 ** 1. Redistributions of source code must retain the above copyright notice,
11 ** this list of conditions and the following disclaimer.
12 **
13 ** 2. Redistributions in binary form must reproduce the above copyright notice,
14 ** this list of conditions and the following disclaimer in the documentation
15 ** and/or other materials provided with the distribution.
16 **
17 ** Subject to the terms and conditions of this license, each copyright holder
18 ** and contributor hereby grants to those receiving rights under this license
19 ** a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable
20 ** (except for failure to satisfy the conditions of this license) patent license
21 ** to make, have made, use, offer to sell, sell, import, and otherwise transfer
22 ** this software, where such license applies only to those patent claims, already
23 ** acquired or hereafter acquired, licensable by such copyright holder or contributor
24 ** that are necessarily infringed by:
25 **
26 ** (a) their Contribution(s) (the licensed copyrights of copyright holders and
27 ** non-copyrightable additions of contributors, in source or binary form) alone;
28 ** or
29 **
30 ** (b) combination of their Contribution(s) with the work of authorship to which
31 ** such Contribution(s) was added by such copyright holder or contributor, if,
32 ** at the time the Contribution is added, such addition causes such combination
33 ** to be necessarily infringed. The patent license shall not apply to any other
34 ** combinations which include the Contribution.
35 **
36 ** Except as expressly stated above, no rights or licenses from any copyright
37 ** holder or contributor is granted under this license, whether expressly, by
38 ** implication, estoppel or otherwise.
39 **
40 ** DISCLAIMER
41 **
42 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
43 ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44 ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 ** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
46 ** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
48 ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
49 ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
50 ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
51 ** USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
52 **
53 ****************************************************************************/
54 
55 #if !defined(__AMXC_ASTACK_H__)
56 #define __AMXC_ASTACK_H__
57 
58 #ifdef __cplusplus
59 extern "C"
60 {
61 #endif
62 
63 #include <amxc/amxc_common.h>
64 #include <amxc/amxc_array.h>
65 
99 
106 
116 
138  return amxc_array_new(astack, 10);
139 }
140 
162  amxc_array_delete(astack, func);
163 }
164 
188 int amxc_astack_init(amxc_astack_t* const astack) {
189  return amxc_array_init(astack, 10);
190 }
191 
206  amxc_array_clean(astack, func);
207 }
208 
224  return amxc_array_append_data(astack, data);
225 }
226 
239 void* amxc_astack_pop(amxc_astack_t* const astack) {
240  return amxc_array_take_last_data(astack);
241 }
242 
255 void* amxc_astack_peek(amxc_astack_t* const astack) {
256  return amxc_array_get_last(astack);
257 }
258 
270 size_t amxc_astack_size(const amxc_astack_t* const astack) {
271  return amxc_array_size(astack);
272 }
273 
286 bool amxc_astack_is_empty(const amxc_astack_t* const astack) {
287  return amxc_array_is_empty(astack);
288 }
289 
290 #ifdef __cplusplus
291 }
292 #endif
293 
294 #endif // __AMXC_ASTACK_H__
Ambiorix array API header file.
#define AMXC_INLINE
Definition: amxc_common.h:64
amxc_array_it_t * amxc_array_get_last(const amxc_array_t *const array)
Gets the item iterator of the last used item in the array.
Definition: amxc_array.c:546
size_t amxc_array_size(const amxc_array_t *const array)
Calculates the number of used items in the array.
Definition: amxc_array.c:415
void * amxc_array_take_last_data(amxc_array_t *const array)
Takes the data pointer from the last used item in the array.
Definition: amxc_array.c:586
int amxc_array_init(amxc_array_t *const array, const size_t items)
Initializes an array.
Definition: amxc_array.c:231
bool amxc_array_is_empty(const amxc_array_t *const array)
Checks that the array is empty.
Definition: amxc_array.c:399
int8_t amxc_array_new(amxc_array_t **array, const size_t items)
Allocates an array.
Definition: amxc_array.c:179
void amxc_array_clean(amxc_array_t *const array, amxc_array_it_delete_t func)
Removes all items from the array.
Definition: amxc_array.c:261
void(* amxc_array_it_delete_t)(amxc_array_it_t *it)
Definition of the array item delete callback function.
Definition: amxc_array.h:194
amxc_array_it_t * amxc_array_append_data(amxc_array_t *const array, void *data)
Adds an item after the last used item in the array.
Definition: amxc_array.c:429
void amxc_array_delete(amxc_array_t **array, const amxc_array_it_delete_t func)
Frees the previously allocated array.
Definition: amxc_array.c:213
AMXC_INLINE void amxc_astack_clean(amxc_astack_t *const astack, amxc_astack_it_delete_t func)
Removes all items from the array stack.
Definition: amxc_astack.h:205
AMXC_INLINE bool amxc_astack_is_empty(const amxc_astack_t *const astack)
Checks that the array stack is empty.
Definition: amxc_astack.h:286
AMXC_INLINE int amxc_astack_init(amxc_astack_t *const astack)
Initializes an array stack.
Definition: amxc_astack.h:188
AMXC_INLINE void * amxc_astack_peek(amxc_astack_t *const astack)
Peek the top of the stack, without removing.
Definition: amxc_astack.h:255
AMXC_INLINE void amxc_astack_delete(amxc_astack_t **astack, amxc_astack_it_delete_t func)
Frees the previously allocated array stack.
Definition: amxc_astack.h:161
AMXC_INLINE size_t amxc_astack_size(const amxc_astack_t *const astack)
Calculate the number of items on the stack, expressed in number of items.
Definition: amxc_astack.h:270
AMXC_INLINE int amxc_astack_new(amxc_astack_t **astack)
Allocates an array stack.
Definition: amxc_astack.h:137
amxc_array_t amxc_astack_t
The array stack structure.
Definition: amxc_astack.h:98
amxc_array_it_delete_t amxc_astack_it_delete_t
Definition of the item delete function.
Definition: amxc_astack.h:115
amxc_array_it_t amxc_astack_it_t
The array stack iterator structure.
Definition: amxc_astack.h:105
AMXC_INLINE void * amxc_astack_pop(amxc_astack_t *const astack)
Removes the last added data from the stack.
Definition: amxc_astack.h:239
AMXC_INLINE amxc_astack_it_t * amxc_astack_push(amxc_astack_t *const astack, void *data)
Adds an item to the array stack.
Definition: amxc_astack.h:223
The array iterator structure.
Definition: amxc_array.h:174
The array structure.
Definition: amxc_array.h:162
char data[]