177 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			177 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C
		
	
	
	
| /**
 | |
|  * @file NCDValCons.h
 | |
|  * @author Ambroz Bizjak <ambrop7@gmail.com>
 | |
|  * 
 | |
|  * @section LICENSE
 | |
|  * 
 | |
|  * Redistribution and use in source and binary forms, with or without
 | |
|  * modification, are permitted provided that the following conditions are met:
 | |
|  * 1. Redistributions of source code must retain the above copyright
 | |
|  *    notice, this list of conditions and the following disclaimer.
 | |
|  * 2. Redistributions in binary form must reproduce the above copyright
 | |
|  *    notice, this list of conditions and the following disclaimer in the
 | |
|  *    documentation and/or other materials provided with the distribution.
 | |
|  * 3. Neither the name of the author nor the
 | |
|  *    names of its contributors may be used to endorse or promote products
 | |
|  *    derived from this software without specific prior written permission.
 | |
|  * 
 | |
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 | |
|  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 | |
|  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | |
|  * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
 | |
|  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 | |
|  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | |
|  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 | |
|  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | |
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 | |
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
|  */
 | |
| 
 | |
| #ifndef BADVPN_NCDVALCONS_H
 | |
| #define BADVPN_NCDVALCONS_H
 | |
| 
 | |
| #include <limits.h>
 | |
| #include <stdint.h>
 | |
| 
 | |
| #include <misc/debug.h>
 | |
| #include <ncd/NCDVal.h>
 | |
| 
 | |
| struct NCDValCons__temp_elem {
 | |
|     NCDValSafeRef ref;
 | |
|     int next;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Value constructor; implements a mechanism for efficiently constructing
 | |
|  * NCD values into {@link NCDVal} compact representation, but without
 | |
|  * having to know the number of list or map elements in advance.
 | |
|  * For the purpose of value construction, values are representing using
 | |
|  * {@link NCDValConsVal} objects.
 | |
|  */
 | |
| typedef struct {
 | |
|     NCDValMem *mem;
 | |
|     struct NCDValCons__temp_elem *elems;
 | |
|     int elems_size;
 | |
|     int elems_capacity;
 | |
| } NCDValCons;
 | |
| 
 | |
| #define NCDVALCONS_TYPE_COMPLETE 1
 | |
| #define NCDVALCONS_TYPE_INCOMPLETE_LIST 2
 | |
| #define NCDVALCONS_TYPE_INCOMPLETE_MAP 3
 | |
| 
 | |
| /**
 | |
|  * Abstract handle which represents a value during constuction via
 | |
|  * {@link NCDValCons}. 
 | |
|  */
 | |
| typedef struct {
 | |
|     int cons_type;
 | |
|     union {
 | |
|         NCDValSafeRef complete_ref;
 | |
|         struct {
 | |
|             int elems_idx;
 | |
|             int count;
 | |
|         } incomplete;
 | |
|     } u;
 | |
| } NCDValConsVal;
 | |
| 
 | |
| #define NCDVALCONS_ERROR_MEMORY 1
 | |
| #define NCDVALCONS_ERROR_DUPLICATE_KEY 2
 | |
| #define NCDVALCONS_ERROR_DEPTH 3
 | |
| 
 | |
| /**
 | |
|  * Initializes a value constructor.
 | |
|  * 
 | |
|  * @param o value constructor to initialize
 | |
|  * @param mem memory object where values will be stored into
 | |
|  * @return 1 on success, 0 on failure
 | |
|  */
 | |
| int NCDValCons_Init (NCDValCons *o, NCDValMem *mem) WARN_UNUSED;
 | |
| 
 | |
| /**
 | |
|  * Frees the value constructor. This only means the constuctor does
 | |
|  * not exist any more; any values constructed and completed using
 | |
|  * {@link NCDValCons_Complete} remain in the memory object.
 | |
|  * 
 | |
|  * @param o value constructor to free
 | |
|  */
 | |
| void NCDValCons_Free (NCDValCons *o);
 | |
| 
 | |
| /**
 | |
|  * Creates a new string value with the given data.
 | |
|  * 
 | |
|  * @param o value constructor
 | |
|  * @param data pointer to string data. This must not point into the
 | |
|  *             memory object the value constructor is using. The data
 | |
|  *             is copied.
 | |
|  * @param len length of the string
 | |
|  * @param out on success, *out will be set to a handle representing
 | |
|  *            the new string
 | |
|  * @param out_error on failure, *out_error will be set to an error code
 | |
|  * @return 1 on success, 0 on failure
 | |
|  */
 | |
| int NCDValCons_NewString (NCDValCons *o, const uint8_t *data, size_t len, NCDValConsVal *out, int *out_error) WARN_UNUSED;
 | |
| 
 | |
| /**
 | |
|  * Creates an empty list value.
 | |
|  * 
 | |
|  * @param o value constructor
 | |
|  * @param out *out will be set to a handle representing the new list
 | |
|  */
 | |
| void NCDValCons_NewList (NCDValCons *o, NCDValConsVal *out);
 | |
| 
 | |
| /**
 | |
|  * Creates an empty map value.
 | |
|  * 
 | |
|  * @param o value constructor
 | |
|  * @param out *out will be set to a handle representing the new map
 | |
|  */
 | |
| void NCDValCons_NewMap (NCDValCons *o, NCDValConsVal *out);
 | |
| 
 | |
| /**
 | |
|  * Prepends an element to a list value.
 | |
|  * 
 | |
|  * @param o value constructor
 | |
|  * @param list pointer to the handle representing the list. On success,
 | |
|  *             the handle will be modified, and the old handle must not
 | |
|  *             be used any more.
 | |
|  * @param elem handle representing the value to be prepended. This handle
 | |
|  *             must not be used any more after being prepended to the list.
 | |
|  * @param out_error on failure, *out_error will be set to an error code
 | |
|  * @return 1 on success, 0 on failure
 | |
|  */
 | |
| int NCDValCons_ListPrepend (NCDValCons *o, NCDValConsVal *list, NCDValConsVal elem, int *out_error) WARN_UNUSED;
 | |
| 
 | |
| /**
 | |
|  * Inserts an entry into a map value.
 | |
|  * 
 | |
|  * @param o value constructor
 | |
|  * @param map pointer to the handle representing the map. On success,
 | |
|  *             the handle will be modified, and the old handle must not
 | |
|  *             be used any more.
 | |
|  * @param key handle representing the key of the entry. This handle
 | |
|  *            must not be used any more after being inserted into the map.
 | |
|  * @param value handle representing the value of the entry. This handle
 | |
|  *              must not be used any more after being inserted into the
 | |
|  *              map.
 | |
|  * @param out_error on failure, *out_error will be set to an error code
 | |
|  * @return 1 on success, 0 on failure
 | |
|  */
 | |
| int NCDValCons_MapInsert (NCDValCons *o, NCDValConsVal *map, NCDValConsVal key, NCDValConsVal value, int *out_error) WARN_UNUSED;
 | |
| 
 | |
| /**
 | |
|  * Completes a value represented by a {@link NCDValConsVal} handle,
 | |
|  * producing a {@link NCDValRef} object which refers to this value within
 | |
|  * the memory object.
 | |
|  * 
 | |
|  * @param o value constructor
 | |
|  * @param val handle representing the value to be completed. After a value
 | |
|  *            is completed, the handle must not be used any more.
 | |
|  * @param out on success, *out will be set to a {@link NCDValRef} object
 | |
|  *            referencing the completed value
 | |
|  * @param out_error on failure, *out_error will be set to an error code
 | |
|  * @return 1 on success, 0 on failure
 | |
|  */
 | |
| int NCDValCons_Complete (NCDValCons *o, NCDValConsVal val, NCDValRef *out, int *out_error) WARN_UNUSED;
 | |
| 
 | |
| #endif
 |