2 * Copyright (C) 2000-2014 Free Software Foundation, Inc.
4 * This file is part of LIBTASN1.
6 * The LIBTASN1 library is free software; you can redistribute it
7 * and/or modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
25 /***************************************/
26 /* Functions used by ASN.1 parser */
27 /***************************************/
28 asn1_node _asn1_add_static_node (unsigned int type);
31 _asn1_set_value (asn1_node node, const void *value, unsigned int len);
33 asn1_node _asn1_set_value_m (asn1_node node, void *value, unsigned int len);
36 _asn1_set_value_lv (asn1_node node, const void *value, unsigned int len);
39 _asn1_append_value (asn1_node node, const void *value, unsigned int len);
41 asn1_node _asn1_set_name (asn1_node node, const char *name);
43 asn1_node _asn1_cpy_name (asn1_node dst, asn1_node src);
45 asn1_node _asn1_set_right (asn1_node node, asn1_node right);
47 asn1_node _asn1_get_last_right (asn1_node node);
49 void _asn1_remove_node (asn1_node node, unsigned int flags);
51 void _asn1_delete_list (void);
53 void _asn1_delete_list_and_nodes (void);
55 #define LTOSTR_MAX_SIZE 20
56 char *_asn1_ltostr (long v, char *str);
58 asn1_node _asn1_find_up (asn1_node node);
60 int _asn1_change_integer_value (asn1_node node);
62 int _asn1_expand_object_id (asn1_node node);
64 int _asn1_type_set_config (asn1_node node);
66 int _asn1_check_identifier (asn1_node node);
68 int _asn1_set_default_tag (asn1_node node);
70 /******************************************************************/
71 /* Function : _asn1_get_right */
72 /* Description: returns the element pointed by the RIGHT field of */
73 /* a NODE_ASN element. */
75 /* node: NODE_ASN element pointer. */
76 /* Return: field RIGHT of NODE. */
77 /******************************************************************/
78 inline static asn1_node
79 _asn1_get_right (asn1_node node)
86 /******************************************************************/
87 /* Function : _asn1_set_down */
88 /* Description: sets the field DOWN in a NODE_ASN element. */
90 /* node: element pointer. */
91 /* down: pointer to a NODE_ASN element that you want be pointed */
93 /* Return: pointer to *NODE. */
94 /******************************************************************/
95 inline static asn1_node
96 _asn1_set_down (asn1_node node, asn1_node down)
106 /******************************************************************/
107 /* Function : _asn1_get_down */
108 /* Description: returns the element pointed by the DOWN field of */
109 /* a NODE_ASN element. */
111 /* node: NODE_ASN element pointer. */
112 /* Return: field DOWN of NODE. */
113 /******************************************************************/
114 inline static asn1_node
115 _asn1_get_down (asn1_node node)
122 /******************************************************************/
123 /* Function : _asn1_get_name */
124 /* Description: returns the name of a NODE_ASN element. */
126 /* node: NODE_ASN element pointer. */
127 /* Return: a null terminated string. */
128 /******************************************************************/
130 _asn1_get_name (asn1_node node)
137 /******************************************************************/
138 /* Function : _asn1_mod_type */
139 /* Description: change the field TYPE of an NODE_ASN element. */
140 /* The new value is the old one | (bitwise or) the */
141 /* paramener VALUE. */
143 /* node: NODE_ASN element pointer. */
144 /* value: the integer value that must be or-ed with the current */
145 /* value of field TYPE. */
146 /* Return: NODE pointer. */
147 /******************************************************************/
148 inline static asn1_node
149 _asn1_mod_type (asn1_node node, unsigned int value)