yumapro  24.10-8
YumaPro SDK
Loading...
Searching...
No Matches
obj.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2008 - 2012, Andy Bierman, All Rights Reserved.
3 * Copyright (c) 2012 - 2024, YumaWorks, Inc., All Rights Reserved.
4 *
5 * Unless required by applicable law or agreed to in writing,
6 * software distributed under the License is distributed on an
7 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
8 * KIND, either express or implied. See the License for the
9 * specific language governing permissions and limitations
10 * under the License.
11 */
12#ifndef _H_obj
13#define _H_obj
14
15/* FILE: obj.h
16*********************************************************************
17* *
18* P U R P O S E *
19* *
20*********************************************************************/
21
27/*********************************************************************
28* *
29* C H A N G E H I S T O R Y *
30* *
31*********************************************************************
32
33date init comment
34----------------------------------------------------------------------
3509-dec-07 abb Begun
3621jul08 abb start obj-based rewrite
37
38*/
39
40#include <xmlstring.h>
41#include <xmlregexp.h>
42
43#include "log.h"
44#include "grp.h"
45#include "ncxconst.h"
46#include "ncxtypes.h"
47#include "status.h"
48#include "tk.h"
49#include "rpc.h"
50#include "typ.h"
51#include "xmlns.h"
52#include "xml_util.h"
53
54#ifdef __cplusplus
55extern "C" {
56#endif
57
58/********************************************************************
59* *
60* C O N S T A N T S *
61* *
62*********************************************************************/
63
64/* object pointer inside obj_key_t struct */
65#define OBJ_KEYOBJ(KO) (KO)->keyobj
66
67/* default vaule for config statement */
68#define OBJ_DEF_CONFIG TRUE
69
70/* default vaule for mandatory statement */
71#define OBJ_DEF_MANDATORY FALSE
72
73/* number of static xpath backptrs to have in each object node */
74/*** CHANGED FROM 4 to 2 23oct19 ***/
75#define OBJ_NUM_XPATH_BACKPTRS 2
76
77/* each object can have a SIL callback priority 1..255 */
78#define OBJ_DEF_SIL_PRIORITY 255
79#define OBJ_MIN_SIL_PRIORITY 1
80#define OBJ_MAX_SIL_PRIORITY 255
81
82
83/********* flags field in obj_template_t *************/
84
85/* object is cloned from a grouping, for a uses statement */
86#define OBJ_FL_CLONE bit0
87
88/* def is a CLI text block */
89#define OBJ_FL_CLI_TEXT_BLOCK bit1
90
91/* clone source
92 * == 0 : cloned object from uses
93 * == 1 : cloned object from augment
94 */
95#define OBJ_FL_AUGCLONE bit2
96
97/* object is marked for deletion -- dynamic flag */
98#define OBJ_FL_DELETED bit3
99
100/* object is dirty in the candidate datastore; used by server only */
101#define OBJ_FL_CDIRTY bit4
102
103/* object is a top-level definition within a module or submodule */
104#define OBJ_FL_TOP bit5
105
106/* object was entered with a 'kw name;' format and is
107 * considered empty by the yangdump program
108 */
109#define OBJ_FL_EMPTY bit6
110
111/* object has been visited by the yangdiff program */
112#define OBJ_FL_SEEN bit7
113
114/* bit7 is reused in the server since the 'seen' bit only
115 * applies to the yangdiff-pro program
116 * object is dirty in the running datastore; used by server only
117 */
118#define OBJ_FL_RDIRTY bit7
119
120/* object marked as changed by the yangdiff program */
121#define OBJ_FL_DIFF bit8
122
123/* object is marked as ncx:hidden */
124#define OBJ_FL_HIDDEN bit9
125
126/* object is marked as ncx:root */
127#define OBJ_FL_ROOT bit10
128
129/* object is marked as a password */
130#define OBJ_FL_PASSWD bit11
131
132/* object is marked as a CLI-only node */
133#define OBJ_FL_CLI bit12
134
135/* object is marked as an XSD list data type */
136#define OBJ_FL_XSDLIST bit13
137
138/* OBJ_TYP_LEAF object is being uses as a key */
139#define OBJ_FL_KEY bit14
140
141/* object is marked as abstract: not CLI or config data */
142#define OBJ_FL_ABSTRACT bit15
143
144/* object is marked as config set so OBJ_FL_CONFIG is valid */
145#define OBJ_FL_CONFSET bit16
146
147/* object config value */
148#define OBJ_FL_CONFIG bit17
149
150/* object is marked as mandatory set so OBJ_FL_MANDATORY is valid */
151#define OBJ_FL_MANDSET bit18
152
153/* object mandatory value */
154#define OBJ_FL_MANDATORY bit19
155
156/* object used in a unique-stmt within a list */
157#define OBJ_FL_UNIQUE bit20
158
159/* object data type is an XPath string */
160#define OBJ_FL_XPATH bit21
161
162/* object data type is a QName string */
163#define OBJ_FL_QNAME bit22
164
165/* object data type is a schema-instance string */
166#define OBJ_FL_SCHEMAINST bit23
167
168/* object is tagged ncx:secure */
169#define OBJ_FL_SECURE bit24
170
171/* object is tagged ncx:very-secure */
172#define OBJ_FL_VERY_SECURE bit25
173
174/* object is tagged ncx:default-parm-equals-ok */
175#define OBJ_FL_CLI_EQUALS_OK bit26
176
177/* object is tagged ncx:sil-delete-children-first */
178#define OBJ_FL_SIL_DELETE_CHILDREN_FIRST bit27
179
180/* object is tagged as ncx:user-write with no create access */
181#define OBJ_FL_BLOCK_CREATE bit28
182
183/* object is tagged as ncx:user-write with no update access */
184#define OBJ_FL_BLOCK_UPDATE bit29
185
186/* object is tagged as ncx:user-write with no delete access */
187#define OBJ_FL_BLOCK_DELETE bit30
188
189/* object is tagged as ywx:rpc-root operation container */
190#define OBJ_FL_RPC_ROOT bit31
191
192
193/********* xflags field in obj_template_t *************/
194
195/* object is a default NP-container */
196#define OBJ_FL_DEF_NPCON bit0
197
198/* object has been checked for enabled;
199 * this flag needs to be cleared if dynamic
200 * features are used and the feature becomes disabled!!!
201 */
202#define OBJ_FL_ENABLED_CHK bit1
203
204/* indicates that the object is enabled, which just means
205 * any if-features statements for this object are true
206 */
207#define OBJ_FL_ENABLED bit2
208
209/* indicates that this visible object has a visible sibling
210 * object with the same local-name but from another module
211 */
212#define OBJ_FL_DUP_LOCAL bit3
213
214/* indicates that this object is an RPC operation that is
215 * not allowed to be called concurrently by multiple sessions
216 * at once
217 */
218#define OBJ_FL_EXCLUSIVE_RPC bit4
219
220/* indicates that this object is has the sil-force-replay
221 * flag set
222 */
223#define OBJ_FL_SIL_FORCE_REPLAY bit5
224
225/* indicates that this object is has the sil-force-replay
226 * flag set for a replace operation
227 */
228#define OBJ_FL_SIL_FORCE_REPLACE_REPLAY bit6
229
230/* indicates that this object is an anyxml object that is
231 * really a ywx:datapath node. The object path-expr will
232 * be sent in XML instances of the object.
233 * (Like object Location header)
234 */
235#define OBJ_FL_DATAPATH bit7
236
237/* indicates that is object has get2 callbacks registered
238 * either for 1 or more submodules. This flag is
239 * set and cleared dynamically so do not cache the value
240 */
241#define OBJ_FL_REMOTE_GET2 bit8
242
243/* indicates the 'units' field has been replaced with
244 * a malloced string via deviations, could be a clone
245*/
246#define OBJ_FL_FREE_UNITS bit9
247
248/* indicates the 'typdef' field has been replaced with
249 * a malloced struct via deviations, could be a clone
250*/
251#define OBJ_FL_FREE_TYPDEF bit10
252
253
254/* indicates the object uses the edit2 callback mode */
255#define OBJ_FL_EDIT2_MODE bit11
256
257/* indicates that leafref validation has been disabled for the
258 * object. The leafref will be treated as if it had a
259 * require-instance false; sub-statement
260 */
261#define OBJ_FL_SKIP_LEAFREF bit12
262
263/* indicates that the object yang_hash field contains
264 * the YANG HASH value for the node; hash can be zero
265 * so set this flag to make sure obj->yang_hash field is set
266 */
267#define OBJ_FL_YANG_HASH bit13
268
269/* indicates that the object yang_hash field contains
270 * the rehashed value for the node because of a clash
271 */
272#define OBJ_FL_YANG_REHASH bit14
273
274/* indicates that the cbset (callback set) is malloced
275 * and a simple m__free(cbset) is needed to clean up
276 */
277#define OBJ_FL_CBSET_MALLOCED bit15
278
279/* indicates the object is 1 of the ncx generic templates */
280#define OBJ_FL_GENERIC bit16
281
282/* indicates the object has defaults has been checked */
283/* NOT USED */
284#define OBJ_FL_DEF_DONE bit17
285
286/* indicates the object has defaults (valid if bit17 set) */
287/* NOT USED */
288#define OBJ_FL_DEF bit18
289
290/* indicates the object is an RPC that is OK for library mode */
291#define OBJ_FL_LIBMODE bit19
292
293/* indicates the object contains a smiv2 object identifier */
294#define OBJ_FL_SMIV2_OID bit20
295
296/* indicates object is tagged ywx:no-nvstore */
297#define OBJ_FL_NO_NVSTORE bit21
298
299/* object is tagged ncx:no-sil-delete-children-first */
300#define OBJ_FL_NO_SIL_DELETE_CHILDREN_FIRST bit22
301
302/* object is tagged as a source node in a yangmap nodemap */
303#define OBJ_FL_YANGMAP_SOURCE bit23
304
305/* object is tagged as a target node in a yangmap nodemap */
306#define OBJ_FL_YANGMAP_TARGET bit24
307
308/* object is tagged as a child node in a yangmap nodemap */
309#define OBJ_FL_YANGMAP_CHILD bit25
310
311/* object is tagged as a keymap node in a yangmap nodemap */
312#define OBJ_FL_YANGMAP_KEY bit26
313
314/* indicates that DUP_LOCAL test has been done */
315#define OBJ_FL_DUP_LOCAL_DONE bit27
316
317/* This bit is set in the agt_val_silcall to indicate that the
318 * Transaction Hook is already setup for the object and that
319 * any consecutive attempts to assign the hook to this object
320 * should be skipped
321 */
322#define OBJ_FL_TRANS_HOOK_SET bit29
323
324/* This bit is set to indicate that the sil-test-get-when
325 * override flag is set for the object which is expected
326 * to be an operational data node
327 */
328#define OBJ_FL_GET_WHEN_SET bit30
329
330/* This bit is set to indicate the value of the
331 * override flag and is only used if OBJ_FL_GET_WHEN_SET
332 * bit is set to 1
333 */
334#define OBJ_FL_GET_WHEN bit31
335
336
337/********* xflags2 field in obj_template_t *************/
338 /* xflags2 is a continuation of xflags bits */
339
340/* This bit is set to indicate that the sil-aio-get2
341 * All in One extension flag is set for the object.
342 */
343#define OBJ_FL_AIO_GET2 bit0
344
345/* This flag indicates that this object has All in One children
346 * But itself it does not have this extension setup.
347 * Will be set only if the current object is GET2 object with
348 * GET2 flags setup.
349 *
350 * GET2 object but not All in One object, but a parent of AIO
351 */
352#define OBJ_FL_AIO_PARENT bit1
353
354/* This bit is set to indicate that the sil-aio-get2
355 * All in One extension flag is set for the object and has XML
356 * parameter setup.
357 */
358#define OBJ_FL_AIO_GET2_XML bit2
359
360/* This bit is set to indicate that the sil-aio-get2
361 * All in One extension flag is set for the object and has JSON
362 * parameter setup.
363 */
364#define OBJ_FL_AIO_GET2_JSON bit3
365
366/* This bit is set to check whether the object has Set Default
367 * Hook callback and should invoke it in order to set custom
368 * system default value BUT only if there is no any YANG defaults.
369 */
370#define OBJ_FL_DEF_HOOK bit4
371
372/* This bit indicates that the leaf or leaf-list is really
373 * an openconfig-hashed-value string not a plain string
374 * and not an ncx:password
375 */
376#define OBJ_FL_OC_HASHED_VALUE bit5
377
378/* This bit is set to indicate that the object is NOT OK for nolock-get
379 * Use on config=false nodes that it is not safe to GET in the
380 * PTHREADS build without a rdlock on running
381 */
382#define OBJ_FL_BAN_NOLOCK_GET bit6
383
384/* This bit is set to indicate that the object has Mount Point
385 * TBD: Why is this needed since the rootcb will be set only
386 * if the object is a mount point?
387 */
388#define OBJ_FL_MOUNT_POINT bit7
389
390/* This bit is set if there is a descendant that is a mount point
391 * This is needed so delete or replace operations on the MP or
392 * its ancestor will force SIL and SIL-SA callbacks to be invoked
393 * instead of skipping them.
394 */
395#define OBJ_FL_DESC_MOUNT_POINT bit8
396
397
398/* indicates the object uses the edit3 callback mode */
399#define OBJ_FL_EDIT3_MODE bit9
400
401
402/* This bit is set if the object has the ywx:hidden-from-cli extension
403 * This is only checked by yp-shell and yangcli-pro.
404 * It is ignored by the server.
405 * This is bit9 in 23.10 release train!
406 */
407#define OBJ_FL_HIDDEN_FROM_CLI bit10
408
409
410/* This bit is set if the object has the ywx:confirm-data extension
411 * This is only checked by yp-shell and yangcli-pro.
412 * It is ignored by the server.
413 */
414#define OBJ_FL_CONFIRM_DATA bit11
415
416
417/* indicates the object uses the edit1 callback mode */
418#define OBJ_FL_EDIT1_MODE bit12
419
420
421/********* uflags field in obj_template_t *************/
422
423/* This field represents the user flags and no system bits
424 * are defined for this field. It is used by yang_obj_cb
425 * callback functions to set user-specific flags
426 */
427
428/********* silflags field in obj_template_t *************/
429
430/* This bit is set in agt_rpc to indicate the RPC is
431 * currently being invoked; If another session attempts
432 * to invoke the RPC while busy, and the obj_is_exclusive_rpc
433 * the RPC request will be rejected by the server
434 */
435#define OBJ_FL_SIL_BUSY bit0
436
437#define OBJ_TYPE(OBJ) (OBJ)->objtype
438
439#define OBJ_INDEX(OBJ) (OBJ)->index
440
441/* mark the object as a top object since the yang_obj does
442 * not catch top-level uses from a grouping as a top object
443 */
444#define OBJ_SET_TOP(OBJ) (OBJ)->flags |= OBJ_FL_TOP
445
446#define OBJ_SET_SIL_BUSY(OBJ) (OBJ)->silflags |= OBJ_FL_SIL_BUSY
447
448#define OBJ_CLEAR_SIL_BUSY(OBJ) (OBJ)->silflags &= ~OBJ_FL_SIL_BUSY
449
450#define OBJ_IS_SIL_BUSY(OBJ) ((OBJ)->silflags & OBJ_FL_SIL_BUSY)
451
452#define OBJ_GET_CBSET(OBJ) (OBJ)->cbset
453
454
455/* Get2 support */
456#define OBJ_SET_REMOTE_GET2(OBJ) (OBJ)->xflags |= OBJ_FL_REMOTE_GET2
457
458#define OBJ_CLEAR_REMOTE_GET2(OBJ) (OBJ)->xflags &= ~OBJ_FL_REMOTE_GET2
459
460#define OBJ_HAS_REMOTE_GET2(OBJ) ((OBJ)->xflags & OBJ_FL_REMOTE_GET2)
461
462#define OBJ_SET_GET2CB(OBJ, CB) (OBJ)->get2cb = CB
463
464#define OBJ_GET_GET2CB(OBJ) (getcb_fn2_t)(OBJ)->get2cb
465
466#define OBJ_SET_EDIT2_MODE(OBJ) (OBJ)->xflags |= OBJ_FL_EDIT2_MODE
467#define OBJ_IS_EDIT2_MODE(OBJ) ((OBJ)->xflags & OBJ_FL_EDIT2_MODE)
468#define OBJ_CLEAR_EDIT2_MODE(OBJ) (OBJ)->xflags &= ~OBJ_FL_EDIT2_MODE
469
470
471/* XPath tuning */
472#define OBJ_SET_SKIP_LEAFREF(OBJ) (OBJ)->xflags |= OBJ_FL_SKIP_LEAFREF
473
474#define OBJ_IS_SKIP_LEAFREF(OBJ) ((OBJ)->xflags & OBJ_FL_SKIP_LEAFREF)
475
476
477
478/* Object YANG Hash */
479#define OBJ_SET_YANG_HASH(OBJ) (OBJ)->xflags |= OBJ_FL_YANG_HASH
480
481#define OBJ_IS_YANG_HASH(OBJ) ((OBJ)->xflags & OBJ_FL_YANG_HASH)
482
483
484/* Object Rehash */
485#define OBJ_SET_YANG_REHASH(OBJ) (OBJ)->xflags |= OBJ_FL_YANG_REHASH
486
487#define OBJ_IS_YANG_REHASH(OBJ) ((OBJ)->xflags & OBJ_FL_YANG_REHASH)
488
489
490/* CBSET Malloced */
491#define OBJ_SET_CBSET_MALLOCED(OBJ) (OBJ)->xflags |= OBJ_FL_CBSET_MALLOCED
492
493#define OBJ_IS_CBSET_MALLOCED(OBJ) ((OBJ)->xflags & OBJ_FL_CBSET_MALLOCED)
494
495#define OBJ_CLEAR_CBSET_MALLOCED(OBJ) (OBJ)->xflags &= ~OBJ_FL_CBSET_MALLOCED
496
497/* Object is generic */
498#define OBJ_SET_GENERIC(OBJ) (OBJ)->xflags |= OBJ_FL_GENERIC
499
500#define OBJ_IS_GENERIC(OBJ) ((OBJ)->xflags & OBJ_FL_GENERIC)
501
502
503/* Object or children have a default value */
504/* NOT USED */
505#define OBJ_SET_DEF_DONE(OBJ) (OBJ)->xflags |= OBJ_FL_DEF_DONE
506
507/* NOT USED */
508#define OBJ_IS_DEF_DONE(OBJ) ((OBJ)->xflags & OBJ_FL_DEF_DONE)
509
510/* NOT USED */
511#define OBJ_SET_DEF(OBJ) (OBJ)->xflags |= OBJ_FL_DEF
512
513/* NOT USED */
514#define OBJ_IS_DEF(OBJ) ((OBJ)->xflags & OBJ_FL_DEF)
515
516/* Object is an RPC that is allowed in library mode */
517#define OBJ_SET_LIBMODE(OBJ) (OBJ)->xflags |= OBJ_FL_LIBMODE
518
519#define OBJ_IS_LIBMODE(OBJ) ((OBJ)->xflags & OBJ_FL_LIBMODE)
520
521#define OBJ_USER_FLAGS(OBJ) (OBJ)->uflags
522
523/* get the object pointer in an obj_key_t */
524#define OBJ_KEY_OBJ(K) (K)->keyobj
525
526/* get the current edit transaction id;
527 * -- changed on each transaction this object is tested
528 */
529#define OBJ_EDIT_TXID(OBJ) (OBJ)->edit_txid
530
531#define OBJ_EXTR_MUST_TXID(OBJ) (OBJ)->must_txid
532#define OBJ_EXTR_WHEN_TXID(OBJ) (OBJ)->when_txid
533#define OBJ_EXTR_LEAFREF_TXID(OBJ) (OBJ)->leafref_txid
534#define OBJ_EXTR_DEF_TXID(OBJ) (OBJ)->def_txid
535
536
537/* Object is flagged no-nvstore */
538#define OBJ_SET_NO_NVSTORE(OBJ) (OBJ)->xflags |= OBJ_FL_NO_NVSTORE
539
540#define OBJ_IS_NO_NVSTORE(OBJ) ((OBJ)->xflags & OBJ_FL_NO_NVSTORE)
541
542
543/* Object is flagged yangmap-source */
544#define OBJ_SET_YANGMAP_SOURCE(OBJ) \
545 (OBJ)->xflags |= OBJ_FL_YANGMAP_SOURCE
546
547#define OBJ_IS_YANGMAP_SOURCE(OBJ) \
548 ((OBJ)->xflags & OBJ_FL_YANGMAP_SOURCE)
549
550
551/* Object is flagged yangmap-target */
552#define OBJ_SET_YANGMAP_TARGET(OBJ) \
553 (OBJ)->xflags |= OBJ_FL_YANGMAP_TARGET
554
555#define OBJ_IS_YANGMAP_TARGET(OBJ) \
556 ((OBJ)->xflags & OBJ_FL_YANGMAP_TARGET)
557
558/* Object is flagged yangmap-childmap */
559#define OBJ_SET_YANGMAP_CHILD(OBJ) \
560 (OBJ)->xflags |= OBJ_FL_YANGMAP_CHILD
561
562#define OBJ_IS_YANGMAP_CHILD(OBJ) \
563 ((OBJ)->xflags & OBJ_FL_YANGMAP_CHILD)
564
565/* Object is flagged yangmap-keymap */
566#define OBJ_SET_YANGMAP_KEY(OBJ) \
567 (OBJ)->xflags |= OBJ_FL_YANGMAP_KEY
568
569#define OBJ_IS_YANGMAP_KEY(OBJ) \
570 ((OBJ)->xflags & OBJ_FL_YANGMAP_KEY)
571
572/* if OBJ_IS_YANGMAP_SOURCE : yangmap_cb == nodemap_t
573 * if OBJ_IS_YANGMAP_TARGET : yangmap_cb == nodemap_t
574 * if OBJ_IS_YANGMAP_CHILD : yangmap_cb == childmap_t
575 * if OBJ_IS_YANGMAP_KEY : yangmap_cb == keymap_t
576 */
577#define OBJ_YANGMAP_CB(OBJ) (OBJ)->yangmap_cb
578
579/* Object DUP_LOCAL test has been done */
580#define OBJ_SET_DUP_LOCAL_DONE(OBJ) \
581 (OBJ)->xflags |= OBJ_FL_DUP_LOCAL_DONE
582
583#define OBJ_IS_DUP_LOCAL_DONE(OBJ) \
584 ((OBJ)->xflags & OBJ_FL_DUP_LOCAL_DONE)
585
586
587#define OBJ_RPC_SUPPORTED(OBJ) (OBJ)->def.rpc->supported
588
589
590/* Trans Hook assignment bits */
591#define OBJ_SET_TRANS_HOOK_SET(OBJ) (OBJ)->xflags |= OBJ_FL_TRANS_HOOK_SET
592#define OBJ_IS_TRANS_HOOK_SET(OBJ) ((OBJ)->xflags & OBJ_FL_TRANS_HOOK_SET)
593#define OBJ_CLEAR_TRANS_HOOK_SET(OBJ) (OBJ)->xflags &= ~OBJ_FL_TRANS_HOOK_SET
594
595
596/* All in One assignment bits */
597#define OBJ_SET_AIO_GET2(OBJ) (OBJ)->xflags2 |= OBJ_FL_AIO_GET2
598#define OBJ_IS_AIO_GET2(OBJ) ((OBJ)->xflags2 & OBJ_FL_AIO_GET2)
599#define OBJ_CLEAR_AIO_GET2(OBJ) (OBJ)->xflags2 &= ~ OBJ_FL_AIO_GET2
600
601/* GET2 object but not All in One object, but a parent of AIO */
602#define OBJ_SET_AIO_PARENT(OBJ) (OBJ)->xflags2 |= OBJ_FL_AIO_PARENT
603#define OBJ_IS_AIO_PARENT(OBJ) ((OBJ)->xflags2 & OBJ_FL_AIO_PARENT)
604#define OBJ_CLEAR_AIO_PARENT(OBJ) (OBJ)->xflags2 &= ~ OBJ_FL_AIO_PARENT
605
606/* AIO with XML/JSON support flags*/
607#define OBJ_SET_AIO_GET2_XML(OBJ) (OBJ)->xflags2 |= OBJ_FL_AIO_GET2_XML
608#define OBJ_IS_AIO_GET2_XML(OBJ) ((OBJ)->xflags2 & OBJ_FL_AIO_GET2_XML)
609
610#define OBJ_SET_AIO_GET2_JSON(OBJ) (OBJ)->xflags2 |= OBJ_FL_AIO_GET2_JSON
611#define OBJ_IS_AIO_GET2_JSON(OBJ) ((OBJ)->xflags2 & OBJ_FL_AIO_GET2_JSON)
612
613/* Dynamic Default Hook assignment bits */
614#define OBJ_SET_DEF_HOOK(OBJ) (OBJ)->xflags2 |= OBJ_FL_DEF_HOOK
615#define OBJ_IS_DEF_HOOK(OBJ) ((OBJ)->xflags2 & OBJ_FL_DEF_HOOK)
616#define OBJ_CLEAR_DEF_HOOK(OBJ) (OBJ)->xflags2 &= ~OBJ_FL_DEF_HOOK
617#define OBJ_GET_DEF_HOOK_CB(OBJ) (ncx_def_hook_cbfn_t)(OBJ)->def_hook_cb
618
619/* openconfig-hashed-value bit */
620#define OBJ_SET_OC_HASHED_VALUE(OBJ) (OBJ)->xflags2 |= OBJ_FL_OC_HASHED_VALUE
621#define OBJ_IS_OC_HASHED_VALUE(OBJ) ((OBJ)->xflags2 & OBJ_FL_OC_HASHED_VALUE)
622
623/* Static Ban Nock GET assignment bits */
624#define OBJ_SET_BAN_NOLOCK_GET(OBJ) (OBJ)->xflags2 |= OBJ_FL_BAN_NOLOCK_GET
625#define OBJ_IS_BAN_NOLOCK_GET(OBJ) ((OBJ)->xflags2 & OBJ_FL_BAN_NOLOCK_GET)
626
627/* Mount Point bit */
628#define OBJ_SET_MOUNT_POINT(OBJ) (OBJ)->xflags2 |= OBJ_FL_MOUNT_POINT
629#define OBJ_IS_MOUNT_POINT(OBJ) ((OBJ)->xflags2 & OBJ_FL_MOUNT_POINT)
630
631/* Mount Point Support Utility functions */
632#define OBJ_SET_ROOTCB(OBJ, ROOTCB) (OBJ)->rootcb = ROOTCB
633#define OBJ_GET_ROOTCB(OBJ) (OBJ)->rootcb
634
635/* Mount Point Descendant bit */
636#define OBJ_SET_DESC_MOUNT_POINT(OBJ) (OBJ)->xflags2 |= OBJ_FL_DESC_MOUNT_POINT
637#define OBJ_IS_DESC_MOUNT_POINT(OBJ) ((OBJ)->xflags2 & OBJ_FL_DESC_MOUNT_POINT)
638
640#define OBJ_BOOL_EVAL_CB(OBJ) (OBJ)->bool_eval_cb
641
643#define OBJ_SET_EDIT3_MODE(OBJ) (OBJ)->xflags2 |= OBJ_FL_EDIT3_MODE
644#define OBJ_IS_EDIT3_MODE(OBJ) ((OBJ)->xflags2 & OBJ_FL_EDIT3_MODE)
645#define OBJ_CLEAR_EDIT3_MODE(OBJ) (OBJ)->xflags2 &= ~OBJ_FL_EDIT3_MODE
646
648#define OBJ_SET_HIDDEN_FROM_CLI(OBJ) (OBJ)->xflags2 |= OBJ_FL_HIDDEN_FROM_CLI
649#define OBJ_IS_HIDDEN_FROM_CLI(OBJ) ((OBJ)->xflags2 & OBJ_FL_HIDDEN_FROM_CLI)
650
652#define OBJ_SET_CONFIRM_DATA(OBJ) (OBJ)->xflags2 |= OBJ_FL_CONFIRM_DATA
653#define OBJ_IS_CONFIRM_DATA(OBJ) ((OBJ)->xflags2 & OBJ_FL_CONFIRM_DATA)
654
656#define OBJ_SET_EDIT1_MODE(OBJ) (OBJ)->xflags2 |= OBJ_FL_EDIT1_MODE
657#define OBJ_IS_EDIT1_MODE(OBJ) ((OBJ)->xflags2 & OBJ_FL_EDIT1_MODE)
658#define OBJ_CLEAR_EDIT1_MODE(OBJ) (OBJ)->xflags2 &= ~OBJ_FL_EDIT1_MODE
659
660
661/********************************************************************
662* *
663* T Y P E S *
664* *
665*********************************************************************/
666
667// Header Only
690typedef enum obj_type_t_ {
695
701
704
707
710
716
732
740
751
760
761
777
780
788
789
790#define OBJ_TYP_LAST OBJ_TYP_ACTION
791
797typedef uint16 obj_index_t;
798
799
801typedef enum obj_augtype_t_ {
808
809
811typedef struct obj_key_t_ {
812 dlq_hdr_t qhdr;
813 struct obj_template_t_ *keyobj;
814 boolean seen;
815} YPACK obj_key_t;
816
817
819typedef struct obj_defval_tk_t_ {
820 dlq_hdr_t qhdr;
821 xmlChar *def;
823} YPACK obj_defval_tk_t;
824
825
827typedef struct obj_unique_comp_t_ {
828 dlq_hdr_t qhdr;
829 struct obj_template_t_ *unobj;
830 xmlChar *xpath;
831 boolean isduplicate;
832} YPACK obj_unique_comp_t;
833
834
836typedef struct obj_unique_t_ {
837 dlq_hdr_t qhdr;
838 xmlChar *xpath;
839 dlq_hdr_t compQ;
840 boolean seen;
841 boolean isconfig;
843} YPACK obj_unique_t;
844
845
847typedef struct obj_container_t_ {
849 xmlChar *name;
850
852 xmlChar *descr;
853
855 xmlChar *ref;
856
858 xmlChar *presence;
859 dlq_hdr_t *typedefQ;
860 dlq_hdr_t *groupingQ;
861 dlq_hdr_t *datadefQ;
863 dlq_hdr_t mustQ;
864 struct obj_template_t_ *defaultparm;
865 obj_index_t last_index;
866} YPACK obj_container_t;
867
868
870typedef struct obj_leaf_t_ {
872 xmlChar *name;
873
875 xmlChar *units;
876
878 xmlChar *defval;
879
881 xmlChar *descr;
882
884 xmlChar *ref;
885
888
891
893 uint16 keynum;
894
895 dlq_hdr_t mustQ;
898 dlq_hdr_t leafrefQ;
905 dlq_hdr_t uniqrefQ;
908 struct obj_template_t_ *leafrefobj;
909
910} YPACK obj_leaf_t;
911
912
914typedef struct obj_leaflist_t_ {
916 xmlChar *name;
917
919 xmlChar *units;
920
922 xmlChar *descr;
923
925 xmlChar *ref;
926
929
931 boolean defset;
932 boolean ordersys;
933 boolean minset;
934 uint32 minelems;
935 boolean maxset;
936 uint32 maxelems;
938 dlq_hdr_t mustQ;
939 dlq_hdr_t leafrefQ;
940 dlq_hdr_t defvalQ;
943 struct obj_template_t_ *leafrefobj;
944
946} YPACK obj_leaflist_t;
947
948
950typedef struct obj_list_t_ {
952 xmlChar *name;
953
955 xmlChar *keystr;
956
958 xmlChar *descr;
959
961 xmlChar *ref;
962 dlq_hdr_t *typedefQ;
963 dlq_hdr_t *groupingQ;
964 dlq_hdr_t *datadefQ;
965 dlq_hdr_t keyQ;
966 dlq_hdr_t uniqueQ;
967 boolean ordersys;
968 boolean minset;
969 uint32 minelems;
970 boolean maxset;
971 uint32 maxelems;
973 dlq_hdr_t mustQ;
977
980
982} YPACK obj_list_t;
983
984
986typedef struct obj_choice_t_ {
987 xmlChar *name;
988 xmlChar *defval;
991 xmlChar *descr;
992
994 xmlChar *ref;
995 dlq_hdr_t *caseQ;
996 boolean caseQclone;
998} YPACK obj_choice_t;
999
1000
1002typedef struct obj_case_t_ {
1003 xmlChar *name;
1006 xmlChar *descr;
1007
1009 xmlChar *ref;
1010
1011 dlq_hdr_t *datadefQ;
1015 boolean nameclone;
1017} YPACK obj_case_t;
1018
1019
1021typedef struct obj_uses_t_ {
1022 xmlChar *prefix;
1023 xmlChar *name;
1026 xmlChar *descr;
1027
1029 xmlChar *ref;
1031 dlq_hdr_t *datadefQ;
1033 boolean expand_done;
1034 boolean refine_done;
1035} YPACK obj_uses_t;
1036
1037
1039typedef struct obj_refine_t_ {
1041 xmlChar *target;
1042
1044 struct obj_template_t_ *targobj;
1045
1047 xmlChar *descr;
1048
1056
1058 xmlChar *ref;
1059
1062
1064 xmlChar *presence;
1065
1068
1069 dlq_hdr_t defval_tkQ;
1073
1076 uint32 minelems;
1078 uint32 maxelems;
1080 dlq_hdr_t mustQ;
1081} YPACK obj_refine_t;
1082
1083
1085typedef struct obj_rpcio_t_ {
1086 xmlChar *name;
1087 dlq_hdr_t *typedefQ;
1088 dlq_hdr_t *groupingQ;
1089 dlq_hdr_t datadefQ;
1090 dlq_hdr_t mustQ;
1095 boolean is_input;
1096
1100 struct obj_template_t_ *defaultparm;
1101} YPACK obj_rpcio_t;
1102
1103
1105typedef struct obj_rpc_t_ {
1107 xmlChar *name;
1108
1110 xmlChar *descr;
1111
1113 xmlChar *ref;
1114
1116 dlq_hdr_t *typedefQ;
1117 dlq_hdr_t *groupingQ;
1118 dlq_hdr_t datadefQ;
1119 boolean is_action;
1123 boolean supported;
1124} YPACK obj_rpc_t;
1125
1126
1128typedef struct obj_augment_t_ {
1130 xmlChar *target;
1131
1133 xmlChar *descr;
1134
1136 xmlChar *ref;
1137
1139 struct obj_template_t_ *targobj;
1140
1144 dlq_hdr_t datadefQ;
1145 uint16 depth;
1146} YPACK obj_augment_t;
1147
1148
1150typedef struct obj_notif_t_ {
1152 xmlChar *name;
1153
1155 xmlChar *descr;
1156
1158 xmlChar *ref;
1160 dlq_hdr_t *typedefQ;
1161 dlq_hdr_t *groupingQ;
1162 dlq_hdr_t datadefQ;
1163 dlq_hdr_t mustQ;
1166 boolean in_data;
1167} YPACK obj_notif_t;
1168
1169
1171typedef struct obj_iffeature_ptr_t_ {
1172 dlq_hdr_t qhdr;
1174} YPACK obj_iffeature_ptr_t;
1175
1176
1178typedef struct obj_errmsg_filter_t_ {
1179 dlq_hdr_t qhdr;
1180 xmlChar *matchstr;
1181 boolean is_errortag;
1182} YPACK obj_errmsg_filter_t;
1183
1184
1186typedef struct obj_errmsg_parm_t_ {
1187 dlq_hdr_t qhdr;
1188 xmlChar *path;
1191 uint32 len;
1192
1194 xmlChar *valstr;
1195} YPACK obj_errmsg_parm_t;
1196
1197
1199typedef struct obj_errmsg_t_ {
1200 dlq_hdr_t qhdr;
1201 xmlChar *basestr;
1202 xmlChar *langstr;
1203 dlq_hdr_t parmQ;
1204 dlq_hdr_t filterQ;
1205} YPACK obj_errmsg_t;
1206
1207
1209typedef unsigned long oid_t;
1210
1217typedef struct obj_oid_t_ {
1218 uint8 cnt;
1220} YPACK obj_oid_t;
1221
1222
1224typedef uint8 obj_testflags_t;
1225
1226
1231typedef struct obj_template_t_ {
1232 dlq_hdr_t qhdr;
1235 uint32 yang_hash;
1237 uint32 flags;
1238 uint32 xflags;
1239 uint32 xflags2;
1241 uint32 uflags;
1242 uint8 silflags;
1254 struct obj_template_t_ *parent;
1255 struct obj_template_t_ *usesobj;
1256 struct obj_template_t_ *augobj;
1258 struct xpath_pcb_t_ *when;
1259 dlq_hdr_t metadataQ;
1260 dlq_hdr_t appinfoQ;
1261 dlq_hdr_t iffeatureQ;
1267
1269 dlq_hdr_t *dataruleQ;
1270
1278 void *cbset;
1279
1281 void *get2cb;
1282
1290 struct ncx_module_t_ *mod;
1291
1294
1296 struct xpath_pcb_t_ *xpath_backptr[OBJ_NUM_XPATH_BACKPTRS];
1297
1299 dlq_hdr_t xpath_backptrQ; // backptr to xpath_pcb_t
1300
1306
1308 dlq_hdr_t *errmsgQ; // Q of obj_errmsg_t
1309
1315
1318
1321
1324
1327
1330
1332 union def_ {
1333 obj_container_t *container;
1334 obj_leaf_t *leaf;
1335 obj_leaflist_t *leaflist;
1336 obj_list_t *list;
1337 obj_choice_t *choic;
1338 obj_case_t *cas;
1339 obj_uses_t *uses;
1340 obj_refine_t *refine;
1341 obj_augment_t *augment;
1342 obj_rpc_t *rpc;
1343 obj_rpcio_t *rpcio;
1344 obj_notif_t *notif;
1345 } def;
1346
1351
1352
1358 void *bool_eval_cb; // xpath_bool_eval_fn_t
1359
1362
1368
1371
1372} YPACK obj_template_t;
1373
1374
1376typedef struct obj_metadata_t_ {
1377 dlq_hdr_t qhdr;
1378 struct obj_template_t_ *parent;
1379 xmlChar *name;
1383 boolean typdef_copy;
1384} YPACK obj_metadata_t;
1385
1386
1388typedef enum obj_deviate_arg_t_ {
1395
1396
1398typedef struct obj_deviate_t_ {
1399 dlq_hdr_t qhdr;
1408
1410 boolean empty;
1411
1414
1417
1420
1423
1425 xmlChar *units;
1426
1429
1431 dlq_hdr_t defval_tkQ;
1432
1434 boolean config;
1435
1438
1440 boolean mandatory;
1441
1444
1446 uint32 minelems;
1450 uint32 maxelems;
1452 dlq_hdr_t mustQ;
1453 dlq_hdr_t uniqueQ;
1454 dlq_hdr_t appinfoQ;
1455} YPACK obj_deviate_t;
1456
1457
1459typedef struct obj_deviation_t_ {
1460 dlq_hdr_t qhdr;
1461 xmlChar *target;
1462 xmlChar *targmodname;
1466 xmlChar *descr;
1467
1469 xmlChar *ref;
1470
1473 xmlChar *devmodname;
1474 boolean empty;
1475 boolean annotation;
1477 dlq_hdr_t deviateQ;
1478 dlq_hdr_t appinfoQ;
1479} YPACK obj_deviation_t;
1480
1481
1492typedef boolean
1494 void *cookie1,
1495 void *cookie2,
1496 boolean nonconfig_warn);
1497
1498
1499#define OBJ_SET_TESTFLAGS(OBJ, FL) (OBJ)->testflags = FL
1500
1501#define OBJ_GET_TESTFLAGS(OBJ) (OBJ)->testflags
1502
1503#define OBJ_SET_DESC_TESTFLAGS(OBJ, FL) (OBJ)->desc_testflags = FL
1504
1505#define OBJ_GET_DESC_TESTFLAGS(OBJ) (OBJ)->desc_testflags
1506
1507#define OBJ_UPDATE_DESC_TESTFLAGS(OBJ, FL) (OBJ)->desc_testflags |= FL
1508
1511/********************************************************************
1512* *
1513* F U N C T I O N S *
1514* *
1515*********************************************************************/
1516
1533extern obj_template_t *
1534 obj_new_template (obj_type_t objtype);
1535
1536
1546extern void
1548
1549
1562extern obj_template_t *
1563 obj_find_template (dlq_hdr_t *que,
1564 const xmlChar *modname,
1565 const xmlChar *objname);
1566
1567
1579extern obj_template_t *
1580 obj_find_schema_template ( dlq_hdr_t *que,
1581 const xmlChar *modname,
1582 const xmlChar *objname );
1583
1584
1596extern const obj_template_t *
1597 obj_find_template_con (dlq_hdr_t *que,
1598 const xmlChar *modname,
1599 const xmlChar *objname);
1600
1601
1613extern obj_template_t *
1614 obj_find_template_test (dlq_hdr_t *que,
1615 const xmlChar *modname,
1616 const xmlChar *objname);
1617
1618
1632extern obj_template_t *
1634 const xmlChar *modname,
1635 const xmlChar *objname);
1636
1637
1653extern obj_template_t *
1655 const xmlChar *modname,
1656 const xmlChar *objname);
1657
1658
1680extern obj_template_t *
1682 const xmlChar *modname,
1683 const xmlChar *objname,
1684 ncx_name_match_t match_names,
1685 boolean alt_names,
1686 boolean dataonly,
1687 status_t *retres);
1688
1689
1703extern obj_template_t *
1705 const xmlChar *modname,
1706 const xmlChar *objname);
1707
1708
1725extern obj_template_t *
1727 const xmlChar *modname,
1728 const xmlChar *objname);
1729
1730
1747extern obj_template_t *
1749 const xmlChar *modname,
1750 const xmlChar *objname);
1751
1752
1769extern obj_template_t *
1771 const xmlChar *modname,
1772 const xmlChar *objname);
1773
1774
1789extern obj_template_t *
1791 xmlns_id_t nsid,
1792 const xmlChar *objname);
1793
1794
1819extern obj_template_t *
1821 const xmlChar *modname,
1822 const xmlChar *objname,
1823 ncx_name_match_t match_names,
1824 boolean alt_names,
1825 boolean dataonly,
1826 status_t *retres);
1827
1828
1839extern obj_template_t *
1841 const xmlChar *modname,
1842 const xmlChar *objname,
1843 uint32 objnamelen);
1844
1845
1867extern obj_template_t *
1869 const xmlChar *modname,
1870 const xmlChar *objname,
1871 uint32 objnamelen,
1872 uint32 *matchcount);
1873
1874
1885extern obj_template_t *
1887
1888
1899extern obj_template_t *
1901
1902
1913extern obj_template_t *
1915
1916
1931extern obj_template_t *
1933
1934
1945extern obj_template_t *
1947
1948
1959extern obj_template_t *
1961
1962
1973extern obj_template_t *
1975
1976
1987extern obj_template_t *
1989
1990
2005extern obj_template_t *
2007
2008
2019extern obj_template_t *
2021
2022
2033extern obj_template_t *
2035
2036
2047extern obj_template_t *
2049
2050
2062extern obj_template_t *
2064
2065
2077extern obj_template_t *
2079
2080
2097extern obj_template_t *
2099 boolean stopnext);
2100
2101
2137extern boolean
2139 obj_walker_fn_t walkerfn,
2140 void *cookie1,
2141 void *cookie2,
2142 obj_template_t *startnode,
2143 const xmlChar *modname,
2144 const xmlChar *childname,
2145 boolean configonly,
2146 boolean textmode,
2147 boolean useroot);
2148
2149
2189extern boolean
2191 obj_walker_fn_t walkerfn,
2192 void *cookie1,
2193 void *cookie2,
2194 obj_template_t *startnode,
2195 const xmlChar *modname,
2196 const xmlChar *name,
2197 boolean configonly,
2198 boolean textmode,
2199 boolean useroot,
2200 boolean orself,
2201 boolean *fncalled);
2202
2203
2243extern boolean
2245 obj_walker_fn_t walkerfn,
2246 void *cookie1,
2247 void *cookie2,
2248 obj_template_t *startnode,
2249 const xmlChar *modname,
2250 const xmlChar *name,
2251 boolean configonly,
2252 boolean textmode,
2253 boolean useroot,
2254 boolean orself,
2255 boolean *fncalled);
2256
2257
2300extern boolean
2302 obj_walker_fn_t walkerfn,
2303 void *cookie1,
2304 void *cookie2,
2305 obj_template_t *startnode,
2306 const xmlChar *modname,
2307 const xmlChar *name,
2308 boolean configonly,
2309 boolean dblslash,
2310 boolean textmode,
2311 boolean useroot,
2312 ncx_xpath_axis_t axis,
2313 boolean *fncalled);
2314
2315
2324extern obj_case_t *
2326 const xmlChar *modname,
2327 const xmlChar *casname);
2328
2329
2330
2341extern obj_template_t *
2343 const xmlChar *name);
2344
2345
2351extern void
2352 obj_clean_datadefQ (dlq_hdr_t *que);
2353
2354
2362extern typ_template_t *
2364 const xmlChar *typname);
2365
2366
2373extern typ_template_t *
2375
2376
2384extern grp_template_t *
2386 const xmlChar *grpname);
2387
2394extern grp_template_t *
2396
2397
2413extern status_t
2414 obj_set_named_type (void *pcb, // yang_pcb_t
2415 tk_chain_t *tkc,
2416 ncx_module_t *mod,
2417 const xmlChar *typname,
2418 typ_def_t *typdef,
2419 obj_template_t *parent,
2420 grp_template_t *grp);
2421
2422
2445extern obj_template_t *
2447 obj_template_t *srcobj,
2448 dlq_hdr_t *mobjQ);
2449
2450
2464extern status_t
2466 obj_template_t *mobj);
2467
2468
2469
2494extern obj_template_t *
2496 obj_template_t *srcobj,
2497 dlq_hdr_t *mobjQ,
2498 boolean sm_clone);
2499
2500
2525extern obj_template_t *
2527 obj_template_t *srcobj,
2528 dlq_hdr_t *mobjQ);
2529
2530
2531/******************** obj_unique_t ********************/
2532
2533
2539extern obj_unique_t *
2540 obj_new_unique (void);
2541
2542
2548extern void
2550
2551
2557extern void
2559
2560
2566extern void
2568
2569
2575extern obj_unique_comp_t *
2576 obj_new_unique_comp (void);
2577
2578
2584extern void
2586
2587
2596extern obj_unique_t *
2597 obj_find_unique (dlq_hdr_t *que,
2598 const xmlChar *xpath);
2599
2600
2607extern obj_unique_t *
2609
2610
2617extern obj_unique_t *
2619
2620
2627extern obj_unique_comp_t *
2629
2630
2637extern obj_unique_comp_t *
2639
2640
2646extern obj_key_t *
2647 obj_new_key (void);
2648
2649
2655extern void
2656 obj_free_key (obj_key_t *key);
2657
2658
2666extern obj_key_t *
2667 obj_find_key (dlq_hdr_t *que,
2668 const xmlChar *keycompname);
2669
2670
2679extern obj_key_t *
2680 obj_find_key2 (dlq_hdr_t *que,
2681 obj_template_t *keyobj);
2682
2683
2690extern obj_key_t *
2692
2693
2700extern obj_key_t *
2702
2703
2710extern const obj_key_t *
2711 obj_first_ckey (const obj_template_t *obj);
2712
2713
2720extern obj_key_t *
2721 obj_next_key (obj_key_t *objkey);
2722
2723
2730extern obj_key_t *
2731 obj_prev_key (obj_key_t *objkey);
2732
2733
2740extern const obj_key_t *
2741 obj_next_ckey (const obj_key_t *objkey);
2742
2743
2750extern uint32
2751 obj_key_count (const obj_template_t *obj);
2752
2753
2761extern uint32
2763
2764
2778extern void
2780 void *cookie1,
2781 void *cookie2,
2782 obj_walker_fn_t walkerfn);
2783
2784
2791extern boolean
2792 obj_any_rpcs (const dlq_hdr_t *datadefQ);
2793
2794
2801extern boolean
2802 obj_any_notifs (const dlq_hdr_t *datadefQ);
2803
2804
2810extern obj_deviate_t *
2811 obj_new_deviate (void);
2812
2813
2819extern void
2821
2822
2829extern const xmlChar *
2831
2832
2838extern obj_deviation_t *
2839 obj_new_deviation (void);
2840
2841
2847extern void
2849
2850
2856extern void
2857 obj_clean_deviationQ (dlq_hdr_t *deviationQ);
2858
2859
2868extern status_t
2870 xmlChar **buff);
2871
2872
2882extern status_t
2883 obj_gen_object_id_prefix (const obj_template_t *obj, xmlChar **buff);
2884
2885
2886
2897extern status_t
2899 xmlChar **buff);
2900
2901
2912extern status_t
2914 const obj_template_t *obj,
2915 xmlChar **buff);
2916
2917
2930extern status_t
2932 xmlChar **buff);
2933
2934
2944 xmlChar **buff);
2945
2946
2957 const obj_template_t *stopobj,
2958 xmlChar **buff);
2959
2960
2973extern status_t
2975 const obj_template_t *obj,
2976 xmlChar **buff);
2977
2978
2994extern status_t
2996 xmlChar *buff,
2997 uint32 bufflen,
2998 uint32 *reallen);
2999
3000
3014extern status_t
3016 xmlChar *buff,
3017 uint32 bufflen,
3018 uint32 *reallen);
3019
3020
3021
3022
3032extern status_t
3034 xmlChar **buff);
3035
3036
3047extern status_t
3049 xmlChar **buff);
3050
3051
3058extern const xmlChar *
3059 obj_get_name (const obj_template_t *obj);
3060
3061
3069extern status_t
3071 const xmlChar *objname);
3072
3073
3086extern boolean
3087 obj_has_name (const obj_template_t *obj);
3088
3089
3098extern boolean
3100
3101
3108extern ncx_status_t
3109 obj_get_status (const obj_template_t *obj);
3110
3111
3118extern const xmlChar *
3120
3121
3131extern const xmlChar *
3133
3134
3142extern const xmlChar *
3144
3145
3153extern const xmlChar *
3155
3156
3163extern const void *
3165
3166
3173extern const xmlChar *
3174 obj_get_reference (const obj_template_t *obj);
3175
3176
3184extern const void *
3186
3187
3188#define obj_is_config obj_get_config_flag_deep
3189
3190
3200extern boolean
3202
3203
3217extern boolean
3219 boolean *setflag);
3220
3221
3229extern ncx_access_t
3231
3232
3239extern dlq_hdr_t *
3241
3242
3249extern dlq_hdr_t *
3250 obj_get_mustQ (const obj_template_t *obj);
3251
3252
3259extern dlq_hdr_t *
3260 obj_get_leafrefQ (const obj_template_t *obj);
3261
3262
3272extern const xmlChar *
3273 obj_get_typestr (const obj_template_t *obj);
3274
3275
3282extern dlq_hdr_t *
3284
3285
3292extern const dlq_hdr_t *
3293 obj_get_cdatadefQ (const obj_template_t *obj);
3294
3295
3306extern const xmlChar *
3307 obj_get_default (const obj_template_t *obj);
3308
3309
3318extern const xmlChar *
3320 ncx_backptr_t **thisdef);
3321
3322
3335extern const xmlChar *
3337 ncx_backptr_t *lastdef,
3338 ncx_backptr_t **thisdef);
3339
3340
3347extern obj_template_t *
3349
3350
3360extern boolean
3362
3363
3373extern boolean
3375
3376
3385extern uint32
3386 obj_get_level (const obj_template_t *obj);
3387
3388
3404extern uint32
3405 obj_get_level_mp (const obj_template_t *obj);
3406
3407
3417extern uint32
3419
3420
3430extern boolean
3431 obj_has_typedefs (const obj_template_t *obj);
3432
3433
3441extern typ_def_t *
3443
3444
3452extern typ_def_t *
3454
3455
3463extern const typ_def_t *
3464 obj_get_ctypdef (const obj_template_t *obj);
3465
3466
3473extern ncx_btype_t
3474 obj_get_basetype (const obj_template_t *obj);
3475
3476
3483extern const xmlChar *
3485
3486
3493extern const xmlChar *
3495
3496
3503extern const xmlChar *
3504 obj_get_mod_name (const obj_template_t *obj);
3505
3506
3513extern ncx_module_t *
3515
3516
3523extern boolean
3525
3526
3534extern ncx_module_t *
3536
3537
3544extern const xmlChar *
3546
3547
3554extern const xmlChar *
3555 obj_get_type_name (const obj_template_t *obj);
3556
3557
3564extern xmlns_id_t
3565 obj_get_nsid (const obj_template_t *obj);
3566
3567
3574extern ncx_sid_t
3575 obj_get_yang_sid (const obj_template_t *obj);
3576
3577
3584extern uint32
3586
3593extern ncx_iqual_t
3595
3596
3604extern ncx_iqual_t
3606 boolean required);
3607
3608
3617extern boolean
3619 uint32 *minelems);
3620
3621
3630extern boolean
3632 uint32 *maxelems);
3633
3634
3641extern const xmlChar *
3643
3644
3651extern obj_template_t *
3653
3654
3662extern const obj_template_t *
3663 obj_get_cparent (const obj_template_t *obj);
3664
3665
3673extern obj_template_t *
3675
3676
3686extern const obj_template_t *
3688
3689
3697extern obj_template_t *
3699
3700
3701
3708extern const xmlChar *
3710
3711
3719extern void *
3721
3722
3749extern status_t
3751 obj_template_t *chobj,
3752 const xml_node_t *curnode,
3753 boolean xmlorder,
3754 dlq_hdr_t *force_modQ,
3755 obj_template_t **rettop,
3756 obj_template_t **retobj);
3757
3758
3765extern uint32
3767
3768
3776extern obj_template_t *
3778
3779
3794extern boolean
3796
3797
3812extern boolean
3814 boolean *ingrp);
3815
3816
3824extern uint8
3826
3827
3835extern const ncx_iffeature_t *
3837
3838
3846extern const ncx_iffeature_t *
3847 obj_get_next_iffeature (const ncx_iffeature_t *iffeature);
3848
3849
3856extern boolean
3857 obj_is_anyxml (const obj_template_t *obj);
3858
3859
3866extern boolean
3867 obj_is_anydata (const obj_template_t *obj);
3868
3869
3877extern boolean
3878 obj_is_any (const obj_template_t *obj);
3879
3880
3887extern boolean
3888 obj_is_leaf (const obj_template_t *obj);
3889
3890
3897extern boolean
3898 obj_is_leaf_list (const obj_template_t *obj);
3899
3900
3907extern boolean
3908 obj_is_list (const obj_template_t *obj);
3909
3910
3917extern boolean obj_in_list (const obj_template_t *obj);
3918
3919
3926extern boolean
3927 obj_is_container (const obj_template_t *obj);
3928
3929
3936extern boolean
3937 obj_is_choice (const obj_template_t *obj);
3938
3939
3946extern boolean
3947 obj_is_case (const obj_template_t *obj);
3948
3949
3956extern boolean
3957 obj_is_uses (const obj_template_t *obj);
3958
3959
3966extern boolean
3967 obj_is_leafy (const obj_template_t *obj);
3968
3969
3976extern boolean obj_is_terminal (const obj_template_t *obj);
3977
3978
3986extern boolean
3988
3989
4000extern boolean
4002 boolean config_only);
4003
4004
4013extern boolean
4015
4016
4025extern boolean
4026 obj_is_cloned (const obj_template_t *obj);
4027
4028
4037extern boolean
4038 obj_is_augclone (const obj_template_t *obj);
4039
4040
4048extern boolean
4049 obj_is_augment (const obj_template_t *obj);
4050
4051
4059extern boolean obj_in_augment (const obj_template_t *obj);
4060
4061
4069extern boolean
4070 obj_is_refine (const obj_template_t *obj);
4071
4072
4081extern boolean
4082 obj_is_data (const obj_template_t *obj);
4083
4084
4094extern boolean
4095 obj_is_data_db (const obj_template_t *obj);
4096
4097
4105extern boolean
4106 obj_is_data_node (const obj_template_t *obj);
4107
4108
4116extern boolean
4117 obj_in_rpc (const obj_template_t *obj);
4118
4119
4126extern boolean
4127 obj_in_rpc_reply (const obj_template_t *obj);
4128
4129
4136extern boolean
4137 obj_in_notif (const obj_template_t *obj);
4138
4139
4146extern boolean
4147 obj_is_rpc (const obj_template_t *obj);
4148
4149
4156extern boolean
4157 obj_is_sm_rpc (const obj_template_t *obj);
4158
4159
4166extern boolean obj_is_rpcio (const obj_template_t *obj);
4167
4168
4175extern boolean obj_is_rpcio_input (const obj_template_t *obj);
4176
4177
4184extern boolean
4185 obj_is_action (const obj_template_t *obj);
4186
4187
4194extern boolean obj_in_action (const obj_template_t *obj);
4195
4196
4203extern boolean
4204 obj_is_notif (const obj_template_t *obj);
4205
4206
4213extern boolean
4214 obj_is_sm_notif (const obj_template_t *obj);
4215
4216
4229extern boolean
4230 obj_is_empty (const obj_template_t *obj);
4231
4232
4240extern boolean
4241 obj_is_match (const obj_template_t *obj1,
4242 const obj_template_t *obj2);
4243
4244
4251extern boolean
4252 obj_is_hidden (const obj_template_t *obj);
4253
4254
4261extern boolean
4263
4264
4271extern boolean
4272 obj_is_root (const obj_template_t *obj);
4273
4274
4280extern void
4282
4283
4290extern boolean
4291 obj_is_rpc_root (const obj_template_t *obj);
4292
4293
4300extern boolean
4301 obj_is_password (const obj_template_t *obj);
4302
4303
4310extern boolean
4311 obj_is_xsdlist (const obj_template_t *obj);
4312
4313
4320extern boolean
4321 obj_is_cli (const obj_template_t *obj);
4322
4323
4332extern boolean obj_is_dirty (const obj_template_t *obj,
4333 ncx_cfg_t cfgid);
4334
4335
4342extern boolean
4343 obj_is_key (const obj_template_t *obj);
4344
4345
4352extern boolean
4353 obj_is_abstract (const obj_template_t *obj);
4354
4355
4363extern boolean obj_in_abstract (const obj_template_t *obj);
4364
4365
4372extern boolean
4373 obj_is_deleted (const obj_template_t *obj);
4374
4375
4384extern boolean
4385 obj_is_deleted_ex (const obj_template_t *obj);
4386
4387
4394extern boolean
4396
4397
4405extern boolean
4407
4408
4415extern boolean
4416 obj_is_secure (const obj_template_t *obj);
4417
4418
4426extern boolean
4428
4429
4437extern boolean
4439
4440
4448extern boolean
4450
4451
4459extern boolean
4461
4462
4471extern boolean
4473
4474
4481extern boolean
4483
4484
4494extern boolean
4496
4497
4505extern boolean
4507
4508
4517extern boolean
4518 obj_is_top (const obj_template_t *obj);
4519
4528extern boolean
4529 obj_in_top_choice (const obj_template_t *obj);
4530
4531
4538extern boolean
4539 obj_is_datapath (const obj_template_t *obj);
4540
4541
4553extern boolean
4555
4556
4564extern boolean
4566
4567
4576extern boolean
4578
4579
4587extern boolean obj_has_ro_descendants (obj_template_t *obj);
4588
4589
4597extern boolean obj_has_rw_children (obj_template_t *obj);
4598
4599
4609extern boolean obj_has_rw_children_ex (obj_template_t *obj,
4610 boolean term_only);
4611
4612
4619extern boolean
4621
4622
4629extern boolean
4631
4632
4641extern boolean
4643
4644
4650extern obj_metadata_t *
4651 obj_new_metadata (void);
4652
4653
4663extern void
4665
4666
4674extern status_t
4676 obj_template_t *obj);
4677
4678
4686extern obj_metadata_t *
4688 const xmlChar *name);
4689
4690
4697extern obj_metadata_t *
4699
4700
4707extern obj_metadata_t *
4708 obj_next_metadata (const obj_metadata_t *meta);
4709
4710
4721extern void
4723
4724
4731extern void
4733
4734
4742extern uint32
4744
4745
4755extern void
4757 dlq_hdr_t *datadefQ,
4758 uint32 startindent,
4759 uint32 indent);
4760
4761
4768extern const xmlChar *
4770
4771
4777extern void
4778 obj_delete_obsolete (dlq_hdr_t *objQ);
4779
4780
4787extern const xmlChar *
4788 obj_get_altname (const obj_template_t *obj);
4789
4790
4798extern obj_template_t *
4800
4801
4809extern obj_template_t *
4811
4812
4820extern const xmlChar *
4822
4823
4830extern boolean
4832
4833
4840extern boolean
4842
4843
4851extern boolean
4853
4854
4862extern boolean
4864
4865
4873extern boolean
4875
4876
4885extern boolean
4887
4888
4895extern void
4897
4898
4907extern boolean
4909
4910
4919extern boolean
4921
4922
4931extern boolean
4933
4934
4941extern obj_iffeature_ptr_t *
4943
4944
4950extern void obj_free_iffeature_ptr (obj_iffeature_ptr_t *iffptr);
4951
4952
4959extern obj_iffeature_ptr_t *
4961
4962
4969extern obj_iffeature_ptr_t *
4971
4972
4979extern ncx_backptr_t *
4981
4982
4989extern ncx_backptr_t *
4991
4992
5000extern boolean
5002 struct xpath_pcb_t_ *xpath);
5003
5004
5012extern struct xpath_pcb_t_ *
5014 struct xpath_pcb_t_ *xpath);
5015
5016
5023extern struct xpath_pcb_t_ *
5025
5026
5027
5038extern status_t
5040 struct xpath_pcb_t_ *xpath);
5041
5042
5052extern void
5054 struct xpath_pcb_t_ *xpath);
5055
5056
5065extern status_t
5067
5068
5077extern void
5079 ncx_cfg_t cfg_id,
5080 boolean flag);
5081
5082
5098extern boolean
5100
5101
5122extern boolean
5124
5125
5133extern boolean
5135
5136
5149extern void
5151 ncx_module_t *mod);
5152
5153
5160extern void
5162
5163
5172extern boolean
5174
5175
5182extern void
5184 uint16 keynum);
5185
5186
5193extern uint16
5195
5196
5204extern boolean
5206
5207
5214extern boolean
5216
5217
5224extern boolean
5226
5227
5234extern void
5236
5237
5244extern boolean obj_notif_enabled (const obj_template_t *obj);
5245
5246
5253extern boolean obj_notif_log_drops (const obj_template_t *obj);
5254
5255
5262extern void obj_set_notif_enabled (obj_template_t *obj,
5263 boolean enabled);
5264
5265
5272extern void obj_set_notif_log_drops (const obj_template_t *obj,
5273 boolean enabled);
5274
5275
5283extern boolean
5284 obj_unload_active (const obj_template_t *obj);
5285
5286
5293extern boolean
5294 obj_is_obsolete (const obj_template_t *obj);
5295
5296
5304extern boolean
5306
5307
5314extern void
5316 uint8 prio);
5317
5318
5325extern uint8
5327
5328
5336extern boolean
5338
5339
5348
5349
5357extern boolean
5359
5360
5367extern boolean
5368 obj_is_crypt_hash (const obj_template_t *obj);
5369
5370
5381extern void
5383
5384
5390extern obj_defval_tk_t *
5391 obj_new_defval_tk (void);
5392
5393
5399extern void
5401
5402
5409extern dlq_hdr_t *
5411
5412
5419extern obj_defval_tk_t *
5420 obj_first_defval_tk (const obj_refine_t *ref);
5421
5422
5429extern obj_defval_tk_t *
5430 obj_next_defval_tk (const obj_defval_tk_t *defval_tk);
5431
5432#define obj_next_dev_defval_tk(D) obj_next_defval_tk(D)
5433
5434
5441extern obj_defval_tk_t *
5443
5444
5451extern boolean
5453
5454
5461extern void
5463 const xmlChar *defval);
5464
5465
5473extern boolean
5475 const xmlChar *find_defval);
5476
5477
5484extern void
5486
5487
5492extern void
5493 obj_enter_xpath_mode (void);
5494
5495
5500extern void
5501 obj_exit_xpath_mode (void);
5502
5503
5511extern obj_key_t *
5513 const xmlChar *keyname);
5514
5515
5522extern ncx_yang_version_t
5524
5525
5535extern boolean
5537
5538
5544extern void
5546
5547
5556extern boolean
5558
5559
5565extern void
5567
5568
5574extern void
5576
5577
5578
5579#if defined(WITH_SNMP) && defined(WITH_RESTCONF)
5586extern const xmlChar *
5588
5589
5600extern obj_oid_t *
5602 boolean *malloced);
5603
5604#endif // WITH_SNMP and WITH_RESTCONF
5605
5606
5615 dlq_hdr_t *keystackQ);
5616
5617
5623extern void obj_dump_keystackQ (dlq_hdr_t *keystackQ);
5624
5625
5632extern void obj_clr_enable_chk (obj_template_t *obj);
5633
5634
5642extern status_t
5644 void *rule);
5645
5646
5653extern void
5655 const void *rule);
5656
5657
5665extern boolean
5667 void *rule);
5668
5669
5679extern status_t
5681 const xmlChar *basestr,
5682 obj_errmsg_t **ret_errmsg);
5683
5684
5692extern status_t
5694 const xmlChar *parmstr);
5695
5696
5705extern status_t
5707 const xmlChar *parmstr,
5708 boolean is_errortag);
5709
5710
5726extern boolean
5728
5729
5737extern boolean
5738 obj_is_singular (const obj_template_t *obj);
5739
5740
5750extern boolean
5752
5753
5760extern boolean
5761 obj_ok_for_nolock (const obj_template_t *obj);
5762
5763
5770extern boolean
5772
5773
5780extern boolean
5782
5783
5790extern boolean obj_get_xpath_oper_ok (const obj_template_t *obj);
5791
5792
5798extern void obj_set_xpath_oper_ok (obj_template_t *obj);
5799
5800
5808extern boolean
5810
5811
5822extern boolean
5824
5825
5832extern obj_template_t *
5834
5835
5842extern boolean
5844
5845
5852extern ncx_module_t *
5854
5855
5863extern obj_template_t *
5865
5866
5877extern boolean
5878 obj_is_ancestor (const obj_template_t *ancestor,
5879 const obj_template_t *obj);
5880
5881
5887extern void
5889
5890
5901extern boolean
5903
5904
5911extern obj_template_t *
5913
5914
5915
5926extern boolean
5928
5929
5930
5941extern boolean
5943
5944
5956extern boolean
5958
5959
5960
5968extern ncx_sm_rootcb_t *
5970
5971
5972
5979extern status_t
5981
5982
5983/*
5984* @brief Object Compare
5985*
5986* @param obj1 object to check
5987* @param obj2 object to check
5988*
5989* @return TRUE if objects match
5990*/
5991extern boolean
5992 obj_match_sm_objs (obj_template_t *obj1,
5993 obj_template_t *obj2);
5994
6003extern boolean
6005
6006
6019extern status_t
6021 const xmlChar *prefix,
6022 const xmlChar *name,
6023 const xmlChar **retval);
6024
6025
6033extern status_t
6035 obj_template_t *listobj);
6036
6037
6045extern obj_template_t *
6047
6048
6057extern obj_template_t *
6059 obj_template_t *curbackptr);
6060
6061
6071extern boolean
6073
6074
6075
6083extern void
6085 ncx_sort_type_t typ);
6086
6087
6095extern ncx_sort_type_t
6096 obj_get_sort_type (const obj_template_t *obj);
6097
6104extern boolean
6106
6107
6116extern grp_template_t *
6118
6119
6128extern obj_template_t *
6130
6131
6140extern obj_template_t *
6142
6143
6157extern boolean
6159
6160
6164#ifdef __cplusplus
6165} /* end extern 'C' */
6166#endif
6167
6168#endif /* _H_obj */
log_debug_t
The debug level enumerations used in util/log.c.
Definition: log.h:348
status_t
global error return code
Definition: status_enum.h:210
uint16 xmlns_id_t
integer handle for registered namespaces
Definition: xmlns.h:89
ncx_leafref_class_t
Classification for the types of leafref path statements wrt/ how they can be cached.
Definition: ncxtypes.h:1571
ncx_status_t
enumeration for different YANG data-def status values
Definition: ncxtypes.h:583
ncx_sort_type_t
the sort type enumeration used for system-ordered list aand leaf-list objects
Definition: ncxtypes.h:1801
uint32 ncx_sid_t
Standard YANG SID is a 63-bit integer defined as uint64.
Definition: ncxtypes.h:756
ncx_yang_version_t
enumeration for different YANG language versions
Definition: ncxtypes.h:1013
ncx_cfg_t
hardwire the 3 standard configs
Definition: ncxtypes.h:548
uint64 ncx_transaction_id_t
transaction is scoped to single session write operation on a config
Definition: ncxtypes.h:728
ncx_iqual_t
The instance qualifier types are borrowed from ABNF and RelaxNG.
Definition: ncxtypes.h:460
ncx_btype_t
enumeration of the built-in NCX types These types cannot be overridden and cannot be imported
Definition: ncxtypes.h:213
ncx_access_t
NCX Access Control 'max-access' enumeration values Note that access control is applied to the session...
Definition: ncxtypes.h:182
ncx_name_match_t
Node name match modes.
Definition: ncxtypes.h:695
ncx_xpath_axis_t
XPath expression axis types.
Definition: ncxtypes.h:662
obj_metadata_t * obj_find_metadata(const obj_template_t *obj, const xmlChar *name)
Find the object metadata definition in the object.
Definition: obj.c:17240
uint32 obj_get_child_count(const obj_template_t *obj)
Get the number of child nodes the object has.
Definition: obj.c:14692
void obj_set_abstract(obj_template_t *obj)
Set the abstract flag for the yang-data node.
Definition: obj.c:20063
obj_key_t * obj_last_key(obj_template_t *obj)
Get the last key record.
Definition: obj.c:11056
const dlq_hdr_t * obj_get_cdatadefQ(const obj_template_t *obj)
Get a const pointer to the datadefQ (or caseQ) if this object has one.
Definition: obj.c:13165
boolean obj_is_notif(const obj_template_t *obj)
Check if the object is a notification.
Definition: obj.c:15970
boolean obj_is_external_augment(obj_template_t *obj)
Check if an object is an external augment.
Definition: obj.c:18129
boolean obj_has_rw_children(obj_template_t *obj)
Check if there are any accessible read-write child nodes within the object.
Definition: obj.c:17023
const xmlChar * obj_get_description(const obj_template_t *obj)
Get the description field for this obj.
Definition: obj.c:12470
boolean obj_has_name(const obj_template_t *obj)
Check if the specified object type has a name.
Definition: obj.c:12330
obj_template_t * obj_clone_template_case(ncx_module_t *mod, obj_template_t *srcobj, dlq_hdr_t *mobjQ)
Clone an obj_template_t but make sure it is wrapped in a OBJ_TYP_CASE layer.
Definition: obj.c:10562
const xmlChar * obj_get_next_default(const obj_template_t *obj, ncx_backptr_t *lastdef, ncx_backptr_t **thisdef)
Get the next default value for the specified object.
Definition: obj.c:13345
boolean obj_is_mp_key(obj_template_t *child)
Check if the parent of this object is a Mount Pount object AND THIS OBJECT IS A KEY LEAF IN THE MP LI...
Definition: obj.c:21138
obj_key_t * obj_new_key(void)
Alloc and Init a obj_key_t struct.
Definition: obj.c:10910
boolean obj_is_top(const obj_template_t *obj)
Check if the object is top-level object within the YANG module that defines it.
Definition: obj.c:16816
boolean obj_is_case(const obj_template_t *obj)
Check if object is a YANG case.
Definition: obj.c:15238
boolean obj_is_hidden(const obj_template_t *obj)
Check if object is marked as a hidden object.
Definition: obj.c:16057
boolean obj_get_max_elements(obj_template_t *obj, uint32 *maxelems)
Get the max-elements clause for this object, if any.
Definition: obj.c:14348
obj_template_t * obj_find_template_test(dlq_hdr_t *que, const xmlChar *modname, const xmlChar *objname)
Find an object with the specified name Test version; do not set 'used' flag.
Definition: obj.c:6621
uint32 obj_get_yang_sid_tree(const obj_template_t *obj)
Get the YANG SID Tree ID for this object.
Definition: obj.c:14170
boolean obj_is_cli(const obj_template_t *obj)
Check if object is marked as a CLI object.
Definition: obj.c:16178
obj_template_t * obj_clone_template_sm(ncx_module_t *mod, obj_template_t *srcobj, dlq_hdr_t *mobjQ, boolean sm_clone)
Clone an obj_template_t Copy the pointers from the srcobj into the new obj.
boolean obj_is_match(const obj_template_t *obj1, const obj_template_t *obj2)
Check if one object is a match in identity with another one.
Definition: obj.c:16032
obj_template_t * obj_find_child_choice_case(obj_template_t *obj, const xmlChar *modname, const xmlChar *objname)
Find a child object with the specified Qname.
Definition: obj.c:7130
boolean obj_in_top_choice(const obj_template_t *obj)
Check if the object is in top-level choice the YANG module that defines it.
Definition: obj.c:16834
boolean obj_is_rpcio(const obj_template_t *obj)
Check if the object is an RPC IO node.
Definition: obj.c:15868
boolean obj_get_leaf_list_defset(const obj_template_t *obj)
Get the defset flag for a leaf-list.
Definition: obj.c:19844
obj_unique_t * obj_first_unique(obj_template_t *listobj)
Get the first unique-stmt for a list.
Definition: obj.c:10812
boolean obj_get_config_flag_check(const obj_template_t *obj, boolean *ingrp)
get config flag during YANG module checking
Definition: obj.c:14876
const void * obj_get_reference_addr(const obj_template_t *obj)
Get the reference field for this obj.
Definition: obj.c:12757
status_t obj_gen_object_id_code(ncx_module_t *mod, const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node for C code usage.
Definition: obj.c:11916
boolean obj_in_augment(const obj_template_t *obj)
Check if object is an augment or inside an augment CHECK ENTIRE TREE UP TO ROOT.
Definition: obj.c:15536
ncx_module_t * obj_get_mod(obj_template_t *obj)
Get the module pointer for this object.
Definition: obj.c:13965
boolean obj_is_confirm_data(const obj_template_t *obj)
Check if object is marked as a confirm-data object for CLI.
Definition: obj.c:21798
void obj_delete_all_defvals(obj_template_t *obj)
Delete all the original defaults for a leaf-list default for deviate replace default foo.
Definition: obj.c:19931
boolean obj_npcon_has_defaults_slow(obj_template_t *obj)
Check if the specified NP container has defaults within it Must be a config object!...
Definition: obj.c:13476
obj_iffeature_ptr_t * obj_new_iffeature_ptr(ncx_iffeature_t *iff)
Malloc and initialize a new obj_iffeature_ptr_t struct.
Definition: obj.c:18360
ncx_backptr_t * obj_first_inherit_when_ptr(obj_template_t *obj)
Get first xpath pointer struct.
Definition: obj.c:18438
const xmlChar * obj_get_oid_string(obj_template_t *obj)
Get object OID sting value.
Definition: obj.c:20088
typ_def_t * obj_get_typdef(obj_template_t *obj)
Get the typdef for the leaf or leaf-list.
Definition: obj.c:13730
grp_template_t * obj_first_grouping(obj_template_t *obj)
Get the first local grouping if any.
Definition: obj.c:9869
void obj_delete_obsolete(dlq_hdr_t *objQ)
Delete any obsolete child nodes within the specified object subtree.
Definition: obj.c:17987
boolean obj_is_password(const obj_template_t *obj)
Check if object is marked as a password object.
Definition: obj.c:16143
boolean obj_get_top_config_flag(const obj_template_t *obj)
Get the config flag for the top-level object.
Definition: obj.c:20589
obj_case_t * obj_find_case(obj_choice_t *choic, const xmlChar *modname, const xmlChar *casname)
Find a specified case arm by name.
Definition: obj.c:9503
void obj_free_defval_tk(obj_defval_tk_t *def)
Delete an object default tk record;.
Definition: obj.c:19750
boolean obj_find_defval(obj_template_t *obj, const xmlChar *find_defval)
Find a default.
Definition: obj.c:19898
obj_template_t * obj_first_unique_backptr(obj_template_t *leafobj)
Get the first unique backptr for a leaf object.
Definition: obj.c:21624
const xmlChar * obj_get_deviate_arg(obj_deviate_arg_t devarg)
Get the deviate-arg string from its enumeration.
Definition: obj.c:11422
boolean obj_unload_active(const obj_template_t *obj)
Check if the module commit tests are disabled because a module unload is in progress.
Definition: obj.c:19397
void * obj_get_presence_string_field(const obj_template_t *obj)
Get the address ot the presence-stmt value, if any.
Definition: obj.c:14616
boolean obj_is_container(const obj_template_t *obj)
Check if object is a YANG container.
Definition: obj.c:15192
obj_key_t * obj_find_key(dlq_hdr_t *que, const xmlChar *keycompname)
Find a specific key component by key leaf identifier name.
Definition: obj.c:10958
ncx_sm_rootcb_t * obj_find_ancestor_rootcb(obj_template_t *obj)
Find an ancestor node or self that has a rootcb.
Definition: obj.c:21286
boolean obj_is_top_aio_get2(obj_template_t *obj)
Check if this object is a really top level holder of extension sil-aio-get2.
Definition: obj.c:20788
obj_unique_comp_t * obj_new_unique_comp(void)
Alloc and Init a obj_unique_comp_t struct.
Definition: obj.c:10727
boolean obj_is_list(const obj_template_t *obj)
Check if object is a YANG list.
Definition: obj.c:15130
const xmlChar * obj_get_augment_target(obj_template_t *obj)
Get the target path string for an augments object.
Definition: obj.c:18108
boolean obj_is_in_aio_get2(obj_template_t *obj)
Check if this object is a child of a node with sil-aio-get2 extension setup or if this object itself ...
Definition: obj.c:20741
boolean obj_is_anydata(const obj_template_t *obj)
Check if object is an anydata.
Definition: obj.c:15052
const xmlChar * obj_get_altname(const obj_template_t *obj)
Get the alt-name for this object, if any.
Definition: obj.c:18030
uint32 obj_key_count_to_root(obj_template_t *obj)
Check ancestor-or-self nodes until root reached Find all lists; Count the number of keys.
Definition: obj.c:11214
obj_template_t * obj_next_child_deep(obj_template_t *obj)
Get the next child object if the specified object has any children.
Definition: obj.c:8567
const xmlChar * obj_get_default(const obj_template_t *obj)
Get the default value for the specified object.
Definition: obj.c:13248
status_t obj_set_mp_flags(obj_template_t *obj)
set the Schema Mount flags and create a rootcb if needed
Definition: obj.c:21320
boolean obj_is_p_container(const obj_template_t *obj)
Check if the object is an Presence-container.
Definition: obj.c:16507
status_t obj_refine_template(obj_template_t *srcobj, obj_template_t *mobj)
Refine Template - Late refine support.
Definition: obj.c:10433
status_t obj_add_errmsg_filter(obj_errmsg_t *errmsg, const xmlChar *parmstr, boolean is_errortag)
Add an errmsg filter for the object.
ncx_sort_type_t obj_get_sort_type(const obj_template_t *obj)
Get the sort type for the object.
Definition: obj.c:21766
boolean obj_is_mandatory_when_ex(obj_template_t *obj, boolean config_only)
Figure out if the obj is YANG mandatory or not Check the when-stmts, not just mandatory-stmt.
Definition: obj.c:15392
void obj_free_metadata(obj_metadata_t *meta)
Scrub the memory in a obj_metadata_t by freeing all the sub-fields and then freeing the entire struct...
Definition: obj.c:17175
obj_template_t * obj_first_terminal_child_nokey(obj_template_t *obj)
Get the first child object if the specified object has any children; MUST BE A TERMINAL NODE!...
Definition: obj.c:7919
status_t obj_copy_object_id_mod(const obj_template_t *obj, xmlChar *buff, uint32 bufflen, uint32 *reallen)
Generate the object ID for an object node and copy to the buffer copy an object ID to a buffer; Use m...
Definition: obj.c:12013
status_t obj_assign_xpath_backptr(obj_template_t *obj, struct xpath_pcb_t_ *xpath)
Set an xpath-expr backptr.
Definition: obj.c:18601
dlq_hdr_t * obj_get_defvalQ(obj_template_t *obj)
Get the leaf-list default Q.
Definition: obj.c:19768
const xmlChar * obj_get_type_name(const obj_template_t *obj)
Get the typename for an object.
Definition: obj.c:14098
void obj_ban_nolock_get(obj_template_t *obj)
Ban nolock-get for the object.
Definition: obj.c:21091
void obj_free_key(obj_key_t *key)
Free a obj_key_t struct.
Definition: obj.c:10933
const xmlChar * obj_get_first_default(const obj_template_t *obj, ncx_backptr_t **thisdef)
Get the first default value for the specified object.
Definition: obj.c:13294
status_t obj_gen_object_id_error(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node for errors.
Definition: obj.c:11799
boolean obj_is_enabled(obj_template_t *obj)
Check any if-feature statement that may cause the specified object to be invisible.
Definition: obj.c:16530
const void * obj_get_description_addr(const obj_template_t *obj)
Get the address of the description field for this obj.
Definition: obj.c:12643
obj_template_t * obj_first_child(obj_template_t *obj)
Get the first child object if the specified object has any children.
Definition: obj.c:7816
status_t obj_get_appinfo(obj_template_t *obj, const xmlChar *prefix, const xmlChar *name, const xmlChar **retval)
Get the first (or only) instance of the specified appinfo.
Definition: obj.c:21539
status_t obj_gen_object_id_prefix(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node Use the prefix in every node.
Definition: obj.c:11571
obj_template_t * obj_find_template(dlq_hdr_t *que, const xmlChar *modname, const xmlChar *objname)
Find an object with the specified name.
Definition: obj.c:6509
const obj_template_t * obj_get_cparent(const obj_template_t *obj)
Get the parent of the current object CONST POINTER VERSION.
Definition: obj.c:14457
const ncx_iffeature_t * obj_get_first_iffeature(const obj_template_t *obj)
Get the first if-feature clause (if any) for the specified object.
Definition: obj.c:14992
void obj_init_unique(obj_unique_t *un)
Init a obj_unique_t struct.
Definition: obj.c:10654
boolean obj_is_supported(obj_template_t *obj)
Check an RPC node to check if it is supported or not It could be disabled at run-time without removin...
Definition: obj.c:19044
status_t obj_gen_aughook_id(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the augment hook element name for the specified object.
Definition: obj.c:12116
void obj_dump_child_list(log_debug_t lvl, dlq_hdr_t *datadefQ, uint32 startindent, uint32 indent)
Dump the object names in a datadefQ – just child level uses log_write_level() for writing ....
Definition: obj.c:17886
obj_template_t * obj_get_real_parent_aug(obj_template_t *obj)
Get the parent of the current object; skip OBJ_TYP_AUGMENT and return the actual parent.
Definition: obj.c:21026
status_t obj_add_errmsg_parm(obj_errmsg_t *errmsg, const xmlChar *parmstr)
Add an errmsg parameter for the object.
void obj_traverse_keys(obj_template_t *obj, void *cookie1, void *cookie2, obj_walker_fn_t walkerfn)
Traverse the list keys with a callback function.
Definition: obj.c:11251
obj_template_t * obj_find_child_fast(obj_template_t *obj, xmlns_id_t nsid, const xmlChar *objname)
Find a child object with the specified Qname.
Definition: obj.c:7211
boolean obj_is_data(const obj_template_t *obj)
Check if the object is defined within data or within a notification or RPC instead.
Definition: obj.c:15582
obj_key_t * obj_next_key(obj_key_t *objkey)
Get the next key record.
Definition: obj.c:11112
boolean obj_is_sil_delete_children_first(const obj_template_t *obj)
Check if object is marked as ncx:sil-delete-children-first.
Definition: obj.c:18214
void obj_clean_datadefQ(dlq_hdr_t *que)
Clean and free all the obj_template_t structs in the specified Q.
Definition: obj.c:9581
typ_def_t * obj_get_base_typdef(obj_template_t *obj)
Get the base typdef for the leaf or leaf-list.
Definition: obj.c:13770
boolean obj_is_xsdlist(const obj_template_t *obj)
Check if object is marked as an XSD list.
Definition: obj.c:16162
void obj_clean_unique(obj_unique_t *un)
Clean a obj_unique_t struct.
Definition: obj.c:10697
boolean obj_edit2_mode_allowed(obj_template_t *obj)
Check if the current object is EDIT2/3 allowed.
Definition: obj.c:21885
obj_key_t * obj_prev_key(obj_key_t *objkey)
Get the previous key record.
Definition: obj.c:11138
boolean obj_in_action(const obj_template_t *obj)
Check if the object is within or is an action method.
Definition: obj.c:15925
void obj_dump_keystackQ(dlq_hdr_t *keystackQ)
Dump a keystackQ with backptrs to obj_template_t for key leafs.
Definition: obj.c:20329
boolean obj_is_single_instance(obj_template_t *obj)
Check if the object is a single instance of if it allows multiple instances; check all of the ancesto...
Definition: obj.c:16731
boolean obj_is_no_sil_delete_children_first(const obj_template_t *obj)
Check if object is marked as ypx:no-sil-delete-children-first OR AN ANCESTOR IS MARKED.
Definition: obj.c:18232
boolean obj_ok_for_nolock(const obj_template_t *obj)
check an object OK for nolock
Definition: obj.c:20621
boolean obj_has_typedefs(const obj_template_t *obj)
Check if the object has any nested typedefs in it.
Definition: obj.c:13649
void obj_add_child(obj_template_t *child, obj_template_t *parent)
Add a child object to the specified complex node.
Definition: obj.c:18258
void obj_set_sil_force_replace_replay(obj_template_t *obj)
Set the object OBJ_FL_SIL_FORCE_REPLAY bit Set the object OBJ_FL_SIL_FORCE_REPLACE_REPLAY bit.
Definition: obj.c:19289
boolean obj_in_rpc(const obj_template_t *obj)
Check if the object is in an rpc/input section.
Definition: obj.c:15712
boolean obj_has_ro_children(obj_template_t *obj)
Check if there are any accessible read-only child nodes within the object.
Definition: obj.c:16958
boolean obj_is_dirty(const obj_template_t *obj, ncx_cfg_t cfgid)
Check if object is marked as dirty (edited) for datastore validation purposes.
Definition: obj.c:16202
boolean obj_is_block_user_delete(const obj_template_t *obj)
Check if object is marked as ncx:user-write with delete access disabled.
Definition: obj.c:18338
boolean obj_is_ancestor(const obj_template_t *ancestor, const obj_template_t *obj)
Check if an object is the ancestor of another.
Definition: obj.c:21057
boolean obj_is_rpcio_input(const obj_template_t *obj)
Check if the object is an RPC IO node.
Definition: obj.c:15885
const xmlChar * obj_get_alt_description(const obj_template_t *obj)
obj_get_alt_description (DEPRECATED)
Definition: obj.c:12529
status_t obj_gen_object_id_datapath(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node Use the prefix in every node.
Definition: obj.c:11616
obj_template_t * obj_next_child_augok(obj_template_t *obj)
Get the next child object if the specified object has any children; return augment,...
Definition: obj.c:8355
void obj_set_xpath_oper_ok(obj_template_t *obj)
Set the object XPath oper OK flag.
Definition: obj.c:20978
obj_template_t * obj_first_child_deep(obj_template_t *obj)
Get the first child object if the specified object has any children.
Definition: obj.c:8486
boolean obj_find_all_pfaxis(ncx_module_t *exprmod, obj_walker_fn_t walkerfn, void *cookie1, void *cookie2, obj_template_t *startnode, const xmlChar *modname, const xmlChar *name, boolean configonly, boolean dblslash, boolean textmode, boolean useroot, ncx_xpath_axis_t axis, boolean *fncalled)
Find all occurances of the specified preceding or following node(s).
Definition: obj.c:9317
boolean obj_is_datapath(const obj_template_t *obj)
Check if object is marked as a ywx:datapath object.
Definition: obj.c:16859
obj_defval_tk_t * obj_new_defval_tk(void)
Create a new object default tk record;.
Definition: obj.c:19733
boolean obj_has_when_stmts(obj_template_t *obj)
Check if any when-stmts apply to this object Does not check if they are true, just any when-stmts pre...
Definition: obj.c:17100
void obj_free_unique_comp(obj_unique_comp_t *unc)
Free a obj_unique_comp_t struct.
Definition: obj.c:10750
void obj_delete_mod_children(obj_template_t *obj, ncx_module_t *mod)
Check the childQ for the specified object and remove all the objects from the specified module.
Definition: obj.c:19075
boolean obj_is_crypt_hash(const obj_template_t *obj)
Check if the object is a leaf of type crypt-hash.
Definition: obj.c:19674
boolean obj_rpc_has_input(obj_template_t *obj)
Check if the RPC object has any real input children.
Definition: obj.c:17076
boolean obj_is_refine(const obj_template_t *obj)
Figure out if the obj is a refinement object, within a uses-stmt.
Definition: obj.c:15565
boolean obj_is_abstract(const obj_template_t *obj)
Check if object is being used as an object identifier or error-info.
Definition: obj.c:16257
boolean obj_has_get2cb(obj_template_t *obj)
Check if current object has GET2 callback registered.
Definition: obj.c:20494
boolean obj_match_datarule(obj_template_t *obj, void *rule)
Check if the data-rule back-ptr applies to this node.
Definition: obj.c:20435
const xmlChar * obj_get_mod_prefix(const obj_template_t *obj)
Get the module prefix for this object.
Definition: obj.c:13874
ncx_iqual_t obj_get_iqualval(obj_template_t *obj)
Get the instance qualifier for this object.
Definition: obj.c:14192
obj_iffeature_ptr_t * obj_first_iffeature_ptr(obj_template_t *obj)
Get first if-feature pointer.
Definition: obj.c:18396
boolean obj_in_submodule(obj_template_t *obj)
Check if the object is defined in a submodule.
Definition: obj.c:14003
boolean obj_is_deleted_ex(const obj_template_t *obj)
Check if object has been deleted by a deviate not-supported Or if its parent was deleted by deviation...
Definition: obj.c:16338
boolean obj_is_external_data_augment(obj_template_t *obj)
Check if an object is an external augment of a data node.
Definition: obj.c:18154
obj_template_t * obj_first_child_augok(obj_template_t *obj)
Get the first child object if the specified object has any children.
Definition: obj.c:8289
uint32 obj_get_real_level(const obj_template_t *obj)
Get the nest level for the specified object Top-level is '1' Does not count groupings as a level Does...
Definition: obj.c:13614
boolean obj_get_min_elements(obj_template_t *obj, uint32 *minelems)
Get the min-elements clause for this object, if any.
Definition: obj.c:14306
boolean obj_is_rpc_root(const obj_template_t *obj)
Check if object is marked as an RPC root object.
Definition: obj.c:16126
obj_template_t * obj_clone_template(ncx_module_t *mod, obj_template_t *srcobj, dlq_hdr_t *mobjQ)
Clone an obj_template_t Copy the pointers from the srcobj into the new obj.
Definition: obj.c:10088
status_t obj_set_named_type(void *pcb, tk_chain_t *tkc, ncx_module_t *mod, const xmlChar *typname, typ_def_t *typdef, obj_template_t *parent, grp_template_t *grp)
Resolve type test Called during phase 2 of module parsing.
Definition: obj.c:9942
grp_template_t * obj_get_uses_grp(obj_template_t *usesobj)
Get the grp template from the uses object pointer.
Definition: obj.c:21815
obj_template_t * obj_match_child_str(obj_template_t *obj, const xmlChar *modname, const xmlChar *objname, uint32 objnamelen, uint32 *matchcount)
Match a child object with the specified Qname Find first command that matches all N chars of objname.
Definition: obj.c:7708
boolean obj_any_notifs(const dlq_hdr_t *datadefQ)
Check if there are any notifications in the datadefQ.
Definition: obj.c:11336
boolean obj_rpc_has_output(obj_template_t *obj)
Check if the RPC object has any real output children.
Definition: obj.c:17087
status_t obj_add_metadata(obj_metadata_t *meta, obj_template_t *obj)
Add the filled out object metadata definition to the object.
Definition: obj.c:17205
void obj_free_deviate(obj_deviate_t *deviate)
Clean and free an object deviate statement.
Definition: obj.c:11391
status_t obj_add_errmsg(obj_template_t *obj, const xmlChar *basestr, obj_errmsg_t **ret_errmsg)
Create a new obj_errmsg struct for the object.
const xmlChar * obj_get_mod_xmlprefix(const obj_template_t *obj)
Get the module prefix for this object.
Definition: obj.c:13905
boolean obj_is_augclone(const obj_template_t *obj)
Figure out if the obj is a cloned object, inserted via an augment statement.
Definition: obj.c:15497
const xmlChar * obj_get_info_description(const obj_template_t *obj)
Get the info description field for this obj Check if a 'info' appinfo node is present.
Definition: obj.c:12610
obj_unique_comp_t * obj_next_unique_comp(obj_unique_comp_t *uncomp)
Get the next unique-stmt component for a list.
Definition: obj.c:10889
xmlns_id_t obj_get_nsid(const obj_template_t *obj)
Get the namespace ID for this object.
Definition: obj.c:14129
obj_key_t * obj_first_key(obj_template_t *obj)
Get the first key record.
Definition: obj.c:11028
ncx_access_t obj_get_max_access(const obj_template_t *obj)
Get the NCX max-access enum for an obj_template_t Return the explicit value or the inherited value.
Definition: obj.c:12881
status_t obj_gen_object_id_unique(const obj_template_t *obj, const obj_template_t *stopobj, xmlChar **buff)
Malloc and Generate the object ID for a unique-stmt test.
Definition: obj.c:11859
obj_template_t * obj_get_choice_parent(obj_template_t *obj)
Get the OBJ_TYP_CHOICE parent of the current object; skip OBJ_TYP_CASE.
Definition: obj.c:14554
obj_template_t * obj_get_leafref_targobj(obj_template_t *obj)
Get the target object for a leafref leaf or leaf-list.
Definition: obj.c:18058
obj_metadata_t * obj_new_metadata(void)
Malloc and initialize the fields in a an obj_metadata_t.
Definition: obj.c:17144
boolean obj_find_all_children(ncx_module_t *exprmod, obj_walker_fn_t walkerfn, void *cookie1, void *cookie2, obj_template_t *startnode, const xmlChar *modname, const xmlChar *childname, boolean configonly, boolean textmode, boolean useroot)
Find all occurances of the specified node(s) within the children of the current node.
Definition: obj.c:8726
typ_template_t * obj_find_type(obj_template_t *obj, const xmlChar *typname)
Check if a typ_template_t in the obj typedefQ hierarchy.
Definition: obj.c:9607
boolean obj_is_rpc(const obj_template_t *obj)
Check if the object is an RPC method.
Definition: obj.c:15828
void obj_flag_xpath_backptrs_dirty(obj_template_t *obj, ncx_cfg_t cfg_id, boolean flag)
Check all the xpath backptr records for this object and set them to dirty or clean,...
Definition: obj.c:18812
boolean obj_is_xpath_string(const obj_template_t *obj)
Check if object is an XPath string.
Definition: obj.c:16374
obj_unique_t * obj_find_unique(dlq_hdr_t *que, const xmlChar *xpath)
Find a specific unique-stmt.
Definition: obj.c:10778
void obj_force_disabled(obj_template_t *obj)
Force an object to be disabled.
Definition: obj.c:20226
obj_template_t * obj_next_child(obj_template_t *obj)
Get the next child object if the specified object has any children.
Definition: obj.c:8095
boolean obj_is_block_user_update(const obj_template_t *obj)
Check if object is marked as ncx:user-write with update access disabled.
Definition: obj.c:18313
obj_key_t * obj_get_key_by_name(obj_template_t *obj, const xmlChar *keyname)
Check the specified list to see if the string is a list key.
Definition: obj.c:19982
boolean obj_is_anyxml(const obj_template_t *obj)
Check if object is an anyxml.
Definition: obj.c:15036
boolean obj_is_terminal(const obj_template_t *obj)
Check if object is a proper leaf or leaflist or anyxml.
Definition: obj.c:15295
void obj_force_root(obj_template_t *obj)
Set the object as an anydata type of root.
Definition: obj.c:16109
status_t obj_gen_object_id_sid(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node for SID path usage.
Definition: obj.c:12045
typ_template_t * obj_first_typedef(obj_template_t *obj)
Get the first local typedef for this object, if any.
Definition: obj.c:9706
obj_template_t * obj_new_rpcio(obj_template_t *rpcobj, const xmlChar *name)
Malloc and initialize the fields in a an obj_rpcio_t.
Definition: obj.c:9548
void obj_set_notif_enabled(obj_template_t *obj, boolean enabled)
Set the notification object enabled flag.
Definition: obj.c:19344
uint8 obj_get_sil_priority(obj_template_t *obj)
Get the SIL priority field.
Definition: obj.c:19523
boolean obj_is_sil_force_replace_replay(const obj_template_t *obj)
Check if this object has the OBJ_FL_SIL_FORCE_REPLACE_REPLAY bit set.
Definition: obj.c:19268
status_t obj_set_name(obj_template_t *obj, const xmlChar *objname)
Set the name field for this obj.
Definition: obj.c:12238
const xmlChar * obj_get_presence_string(const obj_template_t *obj)
Get the present-stmt value, if any.
Definition: obj.c:14587
void obj_clean_deviationQ(dlq_hdr_t *deviationQ)
Clean and free an Q of object deviation statements.
Definition: obj.c:11504
obj_template_t * obj_find_template_top_lrcheck(ncx_module_t *mod, const xmlChar *modname, const xmlChar *objname)
Check if an obj_template_t in the mod->datadefQ or any of the include files visible to this module (L...
Definition: obj.c:6837
obj_key_t * obj_find_key2(dlq_hdr_t *que, obj_template_t *keyobj)
Find a specific key component, check for a specific node in case deep keys are supported,...
Definition: obj.c:10994
boolean obj_ok_for_cli(obj_template_t *obj)
Figure out if the obj is OK for current CLI implementation.
Definition: obj.c:16878
boolean obj_in_list(const obj_template_t *obj)
Check if object is nested within a list.
Definition: obj.c:15146
obj_template_t * obj_get_default_case(obj_template_t *obj)
Get the default case for the specified OBJ_TYP_CHOICE object.
Definition: obj.c:13388
boolean obj_find_all_ancestors(ncx_module_t *exprmod, obj_walker_fn_t walkerfn, void *cookie1, void *cookie2, obj_template_t *startnode, const xmlChar *modname, const xmlChar *name, boolean configonly, boolean textmode, boolean useroot, boolean orself, boolean *fncalled)
Find all occurances of the specified node(s) within the ancestors of the current node.
Definition: obj.c:8946
ncx_iqual_t obj_get_iqualval_ex(obj_template_t *obj, boolean required)
Get the instance qualifier for this object.
Definition: obj.c:14220
boolean obj_get_config_flag(const obj_template_t *obj)
Get the config flag for an obj_template_t Return the explicit value or the inherited value Also retur...
Definition: obj.c:12818
boolean obj_is_obsolete(const obj_template_t *obj)
Check if the object has obsolete status.
Definition: obj.c:19420
status_t obj_get_child_node(obj_template_t *obj, obj_template_t *chobj, const xml_node_t *curnode, boolean xmlorder, dlq_hdr_t *force_modQ, obj_template_t **rettop, obj_template_t **retobj)
Get the correct child node for the specified parent and current XML node.
Definition: obj.c:14654
void obj_number_data_object(obj_template_t *obj)
Number the object tree; initial setup.
Definition: obj.c:19711
boolean obj_is_key(const obj_template_t *obj)
Check if object is being used as a key leaf within a list.
Definition: obj.c:16240
status_t obj_add_unique_backptr(obj_template_t *leafobj, obj_template_t *listobj)
Add a unique backptr to the leaf.
Definition: obj.c:21581
void obj_clear_xpath_backptr(obj_template_t *obj, struct xpath_pcb_t_ *xpath)
Clear an xpath-expr backptr.
Definition: obj.c:18687
boolean obj_get_config_flag_deep(const obj_template_t *obj)
get config flag during augment expand
Definition: obj.c:14788
const xmlChar * obj_get_mod_version(const obj_template_t *obj)
Get the module version for this object.
Definition: obj.c:14074
boolean obj_has_xpath_stmts(obj_template_t *obj)
Check if any must or when stmts in node or all children.
Definition: obj.c:21495
uint32 obj_get_level(const obj_template_t *obj)
Get the nest level for the specified object Top-level is '1' Does not count groupings as a level.
Definition: obj.c:13536
obj_template_t * obj_first_terminal_child(obj_template_t *obj)
Get the first child object if the specified object has any children; MUST BE A TERMINAL NODE!...
Definition: obj.c:7881
boolean obj_is_system_ordered(const obj_template_t *obj)
Check if the object is system or user-ordered.
Definition: obj.c:16458
ncx_yang_version_t obj_get_langver(obj_template_t *obj)
Get the YANG version for this object.
Definition: obj.c:20012
boolean obj_is_cli_text_block(const obj_template_t *obj)
Check if object is marked as ywx:cli-text-block.
Definition: obj.c:18197
boolean obj_is_sm_rpc(const obj_template_t *obj)
Check if the object is a schema mounted RPC method.
Definition: obj.c:15845
obj_oid_t * obj_get_oid_struct(obj_template_t *obj, boolean *malloced)
Get malloced object OID structure that contains OID string and OID count.
Definition: obj.c:20146
status_t obj_copy_object_id(const obj_template_t *obj, xmlChar *buff, uint32 bufflen, uint32 *reallen)
Generate the object ID for an object node and copy to the buffer copy an object ID to a buffer.
Definition: obj.c:11976
void obj_set_notif_log_drops(const obj_template_t *obj, boolean enabled)
Set the event drops enabled flag for the notification object.
Definition: obj.c:19370
obj_template_t * obj_get_parent_choice(obj_template_t *obj)
Get the choice parent of the current object;.
Definition: obj.c:21107
ncx_backptr_t * obj_next_inherit_when_ptr(ncx_backptr_t *ptr)
Get the next xpath pointer struct.
Definition: obj.c:18459
boolean obj_is_data_node(const obj_template_t *obj)
Check if the object is a real node type.
Definition: obj.c:15663
boolean obj_is_mp_parent(obj_template_t *child)
Check if the parent of this object is a Mount Pount object.
Definition: obj.c:21224
obj_template_t * obj_find_child_str(obj_template_t *obj, const xmlChar *modname, const xmlChar *objname, uint32 objnamelen)
Find a child object with the specified Qname.
Definition: obj.c:7591
boolean obj_is_sm_notif(const obj_template_t *obj)
Check if the object is a schema-mounted notification.
Definition: obj.c:15987
boolean obj_is_data_db(const obj_template_t *obj)
Check if the object is some sort of data Constrained to only check the config DB objects,...
Definition: obj.c:15618
boolean obj_is_short_case(obj_template_t *obj)
Check if the object is a short case statement.
Definition: obj.c:16763
obj_template_t * obj_get_augment_obj(obj_template_t *obj)
Get the augobj template from the object pointer.
Definition: obj.c:21858
obj_template_t * obj_find_template_all(ncx_module_t *mod, const xmlChar *modname, const xmlChar *objname)
Check if an obj_template_t in the mod->datadefQ or any of the include files used within the entire ma...
Definition: obj.c:6882
boolean obj_is_mounted(obj_template_t *child)
Check if mounted object.
Definition: obj.c:21172
boolean obj_is_abstract_ex(const obj_template_t *obj)
DUPLICATE FUNCTION OF obj_in_abstract()
Definition: obj.c:20044
boolean obj_any_rpcs(const dlq_hdr_t *datadefQ)
Check if there are any RPC methods in the datadefQ.
Definition: obj.c:11303
obj_template_t * obj_find_template_top_ex(ncx_module_t *mod, const xmlChar *modname, const xmlChar *objname, ncx_name_match_t match_names, boolean alt_names, boolean dataonly, status_t *retres)
Check if an obj_template_t in the mod->datadefQ or any of the include files visible to this module.
Definition: obj.c:6709
boolean obj_maybe_target_template(obj_template_t *obj)
Check a data node and its descendants match the template for NETCONF configuration sources Allow extr...
Definition: obj.c:18982
ncx_status_t obj_get_status(const obj_template_t *obj)
Get the status field for this obj.
Definition: obj.c:12411
boolean obj_is_leaf_list(const obj_template_t *obj)
Check if object is a proper leaf-list.
Definition: obj.c:15114
obj_template_t * obj_get_augment_targobj(obj_template_t *obj)
Get the target object for an augments object.
Definition: obj.c:18086
obj_template_t * obj_find_child_ex(obj_template_t *obj, const xmlChar *modname, const xmlChar *objname, ncx_name_match_t match_names, boolean alt_names, boolean dataonly, status_t *retres)
Find a child object with the specified Qname extended match modes.
Definition: obj.c:7306
obj_template_t * obj_get_default_parm(obj_template_t *obj)
Get the ncx:default-parm object for this object Only supported for OBJ_TYP_CONTAINER and OBJ_TYP_RPCI...
Definition: obj.c:14721
obj_iffeature_ptr_t * obj_next_iffeature_ptr(obj_iffeature_ptr_t *iffptr)
Get the next if-feature pointer.
Definition: obj.c:18417
obj_metadata_t * obj_next_metadata(const obj_metadata_t *meta)
Get the next object metadata definition in the object.
Definition: obj.c:17303
status_t obj_fill_keystackQ(obj_template_t *obj, dlq_hdr_t *keystackQ)
Fill a keystackQ with backptrs to obj_template_t for key leafs.
Definition: obj.c:20288
struct xpath_pcb_t_ * obj_next_xpath_backptr(obj_template_t *obj, struct xpath_pcb_t_ *xpath)
Get the next XPath backptr.
Definition: obj.c:18542
ncx_leafref_class_t obj_get_leafref_class(obj_template_t *obj)
Get the leafref class for a leafref object.
Definition: obj.c:19634
obj_defval_tk_t * obj_first_defval_tk(const obj_refine_t *ref)
Get the first defval_tk entry.
Definition: obj.c:19787
void obj_set_sil_priority(obj_template_t *obj, uint8 prio)
Set the SIL priority field.
Definition: obj.c:19495
void obj_clear_datarule(obj_template_t *obj, const void *rule)
Clear the datarule back-ptr for this node.
Definition: obj.c:20399
uint32 obj_get_level_mp(const obj_template_t *obj)
Get the nest level for the specified object Top-level is '1' Does not count groupings as a level.
Definition: obj.c:13578
obj_template_t * obj_find_child_lrcheck(obj_template_t *obj, const xmlChar *modname, const xmlChar *objname)
Find a child object with the specified Qname LeafRef Check VERSION.
Definition: obj.c:7042
obj_template_t * obj_new_template(obj_type_t objtype)
Malloc and initialize the fields in a an object template.
Definition: obj.c:6219
boolean obj_is_any(const obj_template_t *obj)
Get the config flag for the top-level object Check the specified object all the way to root.
Definition: obj.c:15075
boolean obj_in_notif(const obj_template_t *obj)
Check if the object is in a notification.
Definition: obj.c:15794
obj_template_t * obj_next_terminal_child_nokey_nochoice(obj_template_t *obj)
Get the next child object if the specified object has any children.
Definition: obj.c:8254
boolean obj_find_xpath_backptr(obj_template_t *obj, struct xpath_pcb_t_ *xpath)
Find an xpath-expr backptr.
Definition: obj.c:18484
void obj_enter_xpath_mode(void)
Enter xpath mode and start ignoring obj_is_enabled.
Definition: obj.c:19954
void obj_free_template(obj_template_t *obj)
Scrub the memory in a obj_template_t by freeing all the sub-fields and then freeing the entire struct...
Definition: obj.c:6357
status_t obj_gen_object_id_oid(ncx_module_t *mod, const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node Used for canonical ID string comparison to gener...
Definition: obj.c:11697
boolean obj_is_mandatory(obj_template_t *obj)
Figure out if the obj is YANG mandatory or not.
Definition: obj.c:15315
boolean obj_has_children(obj_template_t *obj)
Check if there are any accessible nodes within the object.
Definition: obj.c:16936
boolean obj_is_schema_instance_string(const obj_template_t *obj)
Check if object is a schema-instance string.
Definition: obj.c:16403
ncx_sid_t obj_get_yang_sid(const obj_template_t *obj)
Get the YANG SID for this object.
Definition: obj.c:14154
obj_deviation_t * obj_new_deviation(void)
Malloc and initialize the fields in a an object deviation statement.
Definition: obj.c:11452
uint16 obj_get_key_num(obj_template_t *obj)
Get the key number for the object.
Definition: obj.c:19191
boolean obj_in_abstract(const obj_template_t *obj)
Check if object is being used as an object identifier or error-info CHECK ENTIRE TREE UP TO ROOT.
Definition: obj.c:16275
void obj_free_iffeature_ptr(obj_iffeature_ptr_t *iffptr)
Free an obj_iffeature_ptr_t struct.
Definition: obj.c:18380
const xmlChar * obj_get_reference(const obj_template_t *obj)
Get the reference field for this obj.
Definition: obj.c:12700
void obj_force_hidden(obj_template_t *obj)
Force an object to be hidden.
Definition: obj.c:20243
obj_template_t * obj_next_unique_backptr(obj_template_t *leafobj, obj_template_t *curbackptr)
Get the next unique backptr for a leaf object.
Definition: obj.c:21654
boolean obj_delete_all_supported(obj_template_t *obj)
Check if the object supports a direct delete-all or remove-all operation.
Definition: obj.c:19659
obj_unique_comp_t * obj_first_unique_comp(obj_unique_t *un)
Get the first identifier in a unique-stmt for a list.
Definition: obj.c:10865
obj_template_t * obj_get_uses_obj(obj_template_t *obj)
Get the usesobj template from the object pointer.
Definition: obj.c:21840
void obj_set_key_leaf(obj_template_t *obj, uint16 keynum)
Set the key data for the object.
Definition: obj.c:19167
boolean obj_is_deleted(const obj_template_t *obj)
Check if object has been deleted by a deviate not-supported.
Definition: obj.c:16312
obj_template_t * obj_find_child(obj_template_t *obj, const xmlChar *modname, const xmlChar *objname)
Find a child object with the specified Qname.
Definition: obj.c:6959
uint8 obj_get_fraction_digits(const obj_template_t *obj)
Get the fraction-digits field from the object typdef.
Definition: obj.c:14960
status_t obj_gen_object_id_xpath(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node.
Definition: obj.c:11753
obj_defval_tk_t * obj_first_dev_defval_tk(const obj_deviate_t *dev)
Get the first defval_tk entry.
Definition: obj.c:19825
obj_unique_t * obj_new_unique(void)
Alloc and Init a obj_unique_t struct.
Definition: obj.c:10631
dlq_hdr_t * obj_get_leafrefQ(const obj_template_t *obj)
Get the leafrefQ for this obj.
Definition: obj.c:12993
void obj_find_delete_defval(obj_template_t *obj, const xmlChar *defval)
Find and delete a leaf-list default for deviate delete default foo.
Definition: obj.c:19863
boolean obj_has_iffeature(obj_template_t *obj)
Check any if-feature statements exist for the specified object.
Definition: obj.c:16682
void obj_clr_enable_chk(obj_template_t *obj)
Force an object to re-evaluate the enable check Will call for all children.
Definition: obj.c:20259
const xmlChar * obj_get_units(obj_template_t *obj)
Get the units clause for this object, if any.
Definition: obj.c:14386
boolean obj_is_empty(const obj_template_t *obj)
Check if object was entered in empty fashion:
Definition: obj.c:16013
boolean obj_in_edit2_mode(obj_template_t *obj)
Check if the object is an edit2 or edit3 container or list or terminal node child in an edit2 or edit...
Definition: obj.c:19591
boolean obj_in_rpc_reply(const obj_template_t *obj)
Check if the object is in an rpc-reply/output section.
Definition: obj.c:15757
boolean obj_is_action(const obj_template_t *obj)
Check if the object is a YANG 1.1 action.
Definition: obj.c:15908
boolean obj_is_uses(const obj_template_t *obj)
Check if object is a YANG uses-stmt.
Definition: obj.c:15261
obj_template_t * obj_previous_child(obj_template_t *obj)
Get the previous child object if the specified object has any children.
Definition: obj.c:8434
const xmlChar * obj_get_keystr(obj_template_t *obj)
Get the key string for this list object.
Definition: obj.c:17961
boolean obj_has_text_content(const obj_template_t *obj)
Check if the specified object type has a text content for XPath purposes.
Definition: obj.c:12380
boolean obj_get_config_flag2(const obj_template_t *obj, boolean *setflag)
Get the config flag for an obj_template_t Return the explicit value or the inherited value Also retur...
Definition: obj.c:12855
boolean obj_is_leafy(const obj_template_t *obj)
Check if object is a proper leaf or leaflist.
Definition: obj.c:15277
void obj_exit_xpath_mode(void)
Exit xpath mode and stop ignoring obj_is_enabled.
Definition: obj.c:19963
obj_template_t * obj_next_terminal_child_nokey(obj_template_t *obj)
Get the next child object if the specified object has any children; MUST BE TERMINAL NODE!...
Definition: obj.c:8214
const typ_def_t * obj_get_ctypdef(const obj_template_t *obj)
Get the typdef for the leaf or leaf-list : Const version.
Definition: obj.c:13799
boolean obj_has_aio_list(obj_template_t *obj)
Check is AIO object is a list or if its parent is a list object.
Definition: obj.c:20903
boolean obj_is_dup_local(obj_template_t *obj)
Check if this object is one that has a duplicate sibling with the same local-name and different modul...
Definition: obj.c:19145
const ncx_iffeature_t * obj_get_next_iffeature(const ncx_iffeature_t *iffeature)
Get the next if-feature clause (if any)
Definition: obj.c:15018
boolean obj_is_mp_with_rootcb(const obj_template_t *obj)
Check if current object is Mount Point object.
Definition: obj.c:21260
boolean obj_is_target_template(obj_template_t *obj)
Check a data node and its descendants match the template for NETCONF configuration sources.
Definition: obj.c:18922
boolean obj_notif_enabled(const obj_template_t *obj)
Check if the notification object is enabled.
Definition: obj.c:19306
obj_metadata_t * obj_first_metadata(const obj_template_t *obj)
Get the first object metadata definition in the object.
Definition: obj.c:17278
obj_template_t * obj_last_child(obj_template_t *obj)
Get the last child object if the specified object has any children.
Definition: obj.c:7994
const obj_template_t * obj_get_real_cparent(const obj_template_t *obj)
Get the parent of the current object; skip OBJ_TYP_CHOICE and OBJ_TYP_CASE.
Definition: obj.c:14519
boolean obj_is_mandatory_when(obj_template_t *obj)
Figure out if the obj is YANG mandatory or not Check the when-stmts, not just mandatory-stmt.
Definition: obj.c:15467
obj_template_t * obj_next_terminal_child(obj_template_t *obj)
Get the next child object if the specified object has any children; MUST BE TERMINAL NODE!...
Definition: obj.c:8179
dlq_hdr_t * obj_get_mustQ(const obj_template_t *obj)
Get the mustQ for this obj.
Definition: obj.c:12949
dlq_hdr_t * obj_get_datadefQ(obj_template_t *obj)
Get the datadefQ (or caseQ) if this object has one.
Definition: obj.c:13085
const xmlChar * obj_get_mod_name(const obj_template_t *obj)
Get the module name for this object.
Definition: obj.c:13925
boolean obj_notif_log_drops(const obj_template_t *obj)
Check if the event drops for the notification object is enabled.
Definition: obj.c:19325
void obj_set_ncx_flags(obj_template_t *obj)
Check the NCX appinfo extensions and set flags as needed.
Definition: obj.c:17409
boolean obj_use_get_when_check(const obj_template_t *obj)
check an object needs to use a when-check for GET processing
Definition: obj.c:20673
obj_template_t * obj_find_schema_template(dlq_hdr_t *que, const xmlChar *modname, const xmlChar *objname)
Find an object with the specified name For YANG schema-nodeid so NEVER lookdeep.
Definition: obj.c:6550
obj_unique_t * obj_next_unique(obj_unique_t *un)
Get the next unique-stmt for a list.
Definition: obj.c:10841
boolean obj_is_secure(const obj_template_t *obj)
Check if object is tagged ncx:secure.
Definition: obj.c:16424
boolean obj_get_xpath_oper_ok(const obj_template_t *obj)
Get the object XPath oper OK flag.
Definition: obj.c:20953
obj_template_t * obj_next_child_deep_ex(obj_template_t *obj, boolean stopnext)
Get the next child object if the specified object has any children.
Definition: obj.c:8596
boolean obj_is_cloned(const obj_template_t *obj)
Figure out if the obj is a cloned object, inserted via uses or augment statements.
Definition: obj.c:15480
boolean obj_is_final(obj_template_t *obj)
Check if the object template represents a fully expanded template or if it is inside a grouping.
Definition: obj.c:20200
ncx_module_t * obj_get_real_mod(obj_template_t *obj)
Get the module struct for the submodule or main module with this object.
Definition: obj.c:21002
uint32 obj_key_count(const obj_template_t *obj)
Get the number of keys for this object.
Definition: obj.c:11186
boolean obj_is_hidden_from_cli(const obj_template_t *obj)
Check if object is marked as a hidden object from CLI.
Definition: obj.c:16074
ncx_btype_t obj_get_basetype(const obj_template_t *obj)
Get the NCX base type enum for the object type.
Definition: obj.c:13827
const xmlChar * obj_get_typestr(const obj_template_t *obj)
Get the name of the object type.
Definition: obj.c:13025
boolean obj_is_sil_force_replay(const obj_template_t *obj)
Check if this object has the OBJ_FL_SIL_FORCE_REPLAY bit set.
Definition: obj.c:19246
boolean obj_is_choice(const obj_template_t *obj)
Check if object is a YANG choice.
Definition: obj.c:15215
status_t obj_cache_datarule(obj_template_t *obj, void *rule)
Set the data-rule back-ptr for this node.
Definition: obj.c:20364
obj_template_t * obj_get_real_parent(obj_template_t *obj)
Get the parent of the current object; skip OBJ_TYP_CHOICE and OBJ_TYP_CASE.
Definition: obj.c:14482
boolean obj_is_block_user_create(const obj_template_t *obj)
Check if object is marked as ncx:user-write with create access disabled.
Definition: obj.c:18288
struct xpath_pcb_t_ * obj_first_xpath_backptr(obj_template_t *obj)
Get the first xpath backptr.
Definition: obj.c:18518
dlq_hdr_t * obj_get_appinfoQ(obj_template_t *obj)
Get the appinfoQ for this obj.
Definition: obj.c:12925
obj_template_t * obj_get_parent(obj_template_t *obj)
Get the parent of the current object.
Definition: obj.c:14432
grp_template_t * obj_find_grouping(obj_template_t *obj, const xmlChar *grpname)
Check if a grp_template_t in the obj groupingQ hierarchy.
Definition: obj.c:9772
boolean obj_is_cli_equals_ok(const obj_template_t *obj)
Check if object is marked as ncx:default-parm-equals-ok.
Definition: obj.c:18180
obj_defval_tk_t * obj_next_defval_tk(const obj_defval_tk_t *defval_tk)
Get the next defval_tk entry.
Definition: obj.c:19806
const xmlChar * obj_get_name(const obj_template_t *obj)
Get the name field for this obj.
Definition: obj.c:12180
boolean obj_has_rw_children_ex(obj_template_t *obj, boolean term_only)
Check if there are any accessible read-write child nodes within the object.
Definition: obj.c:17041
void obj_free_unique(obj_unique_t *un)
Free a obj_unique_t struct.
Definition: obj.c:10676
boolean obj_has_ro_descendants(obj_template_t *obj)
Check if there are any accessible read-only descendant nodes within the object.
Definition: obj.c:16987
obj_template_t * obj_find_template_top(ncx_module_t *mod, const xmlChar *modname, const xmlChar *objname)
Check if an obj_template_t in the mod->datadefQ or any of the include files visible to this module.
Definition: obj.c:6665
obj_template_t * obj_first_terminal_child_nokey_nochoice(obj_template_t *obj)
Get the first child object if the specified object has any children.
Definition: obj.c:7959
const obj_key_t * obj_next_ckey(const obj_key_t *objkey)
Get the next key record: Const version.
Definition: obj.c:11162
boolean obj_is_np_container(const obj_template_t *obj)
Check if the object is an Non-Presence-container.
Definition: obj.c:16484
void obj_free_deviation(obj_deviation_t *deviation)
Clean and free an object deviation statement.
Definition: obj.c:11476
void obj_sort_children(obj_template_t *obj)
Check all the child nodes of the specified object and rearrange them into alphabetical order,...
Definition: obj.c:17329
boolean obj_is_augment(const obj_template_t *obj)
Check if the obj is an augment statement.
Definition: obj.c:15520
const obj_key_t * obj_first_ckey(const obj_template_t *obj)
Get the first key record: Const version.
Definition: obj.c:11084
status_t obj_gen_object_id(const obj_template_t *obj, xmlChar **buff)
Malloc and Generate the object ID for an object node.
Definition: obj.c:11526
boolean obj_is_create_np_ro(obj_template_t *obj)
Check if this is an empty read-only NP-container that should be created as an empty NP container.
Definition: obj.c:21693
boolean obj_is_leaf(const obj_template_t *obj)
Check if object is a proper leaf.
Definition: obj.c:15097
const xmlChar * obj_get_help_description(const obj_template_t *obj)
Get the help description field for this obj Check if a 'help' appinfo node is present.
Definition: obj.c:12576
boolean obj_is_exclusive_rpc(const obj_template_t *obj)
Check if this object has the OBJ_FL_EXCLUSIVE_WRITE bit set.
Definition: obj.c:19224
boolean obj_is_root(const obj_template_t *obj)
Check if object is marked as a root object.
Definition: obj.c:16091
boolean obj_is_singular(const obj_template_t *obj)
Check if the object can have only one instance or not.
Definition: obj.c:20550
obj_template_t * obj_get_top_aio_get2(obj_template_t *child)
Find the top AIO object.
Definition: obj.c:20857
status_t obj_set_xpath_backptrs(obj_template_t *obj)
Check a top-level data node and all its descendants to see if they have any XPath expressions that ne...
Definition: obj.c:18762
const obj_template_t * obj_find_template_con(dlq_hdr_t *que, const xmlChar *modname, const xmlChar *objname)
Find an object with the specified name Return a const pointer; used by yangdump.
Definition: obj.c:6581
void obj_set_sort_type(obj_template_t *obj, ncx_sort_type_t typ)
Set the sort type for the object if OK Otherwise this function call has no affect.
Definition: obj.c:21722
obj_deviate_t * obj_new_deviate(void)
Malloc and initialize the fields in a an object deviate statement.
Definition: obj.c:11366
boolean obj_find_all_descendants(ncx_module_t *exprmod, obj_walker_fn_t walkerfn, void *cookie1, void *cookie2, obj_template_t *startnode, const xmlChar *modname, const xmlChar *name, boolean configonly, boolean textmode, boolean useroot, boolean orself, boolean *fncalled)
Find all occurances of the specified node(s) within the descendants of the current node.
Definition: obj.c:9137
void obj_set_dup_local(obj_template_t *obj)
Flag the object as one that has a duplicate sibling with the same local-name and different module nam...
Definition: obj.c:19121
boolean obj_is_very_secure(const obj_template_t *obj)
Check if object is tagged ncx:very-secure.
Definition: obj.c:16441
uint32 obj_enabled_child_count(obj_template_t *obj)
Get the count of the number of enabled child nodes for the object template.
Definition: obj.c:17840
ncx_module_t * obj_get_mod_for_dump(obj_template_t *obj)
Get the module pointer for this object Use for sub-module !!! Used by yangdump-pro!...
Definition: obj.c:14039
boolean obj_parent_same_module(const obj_template_t *obj)
Check if the object parent object is the same.
Definition: obj.c:19451
boolean obj_npcon_has_defaults(obj_template_t *obj)
Check if the specified NP container has defaults within it Must be a config object!...
Definition: obj.c:13437
boolean obj_has_mandatory_children(obj_template_t *obj)
Check if there are any mandatory children.
Definition: obj.c:20707
uint16 obj_index_t
object index only applies to child nodes; this is assigned at runtime and any augments loaded at run-...
Definition: obj.h:797
obj_augtype_t
enumeration for different YANG augment statement types
Definition: obj.h:801
unsigned long oid_t
data type used in SNMP
Definition: obj.h:1209
uint8 obj_testflags_t
object test flags
Definition: obj.h:1224
obj_deviate_arg_t
type of deviation for each deviate entry
Definition: obj.h:1388
obj_type_t
enumeration for different YANG data def statement types the enum order is significant!...
Definition: obj.h:690
boolean(* obj_walker_fn_t)(obj_template_t *obj, void *cookie1, void *cookie2, boolean nonconfig_warn)
child or descendant node search walker function
Definition: obj.h:1493
@ OBJ_AUGTYP_RPCOUT
rpc output
Definition: obj.h:804
@ OBJ_AUGTYP_NONE
not set
Definition: obj.h:802
@ OBJ_AUGTYP_DATA
within data
Definition: obj.h:806
@ OBJ_AUGTYP_RPCIN
rpc input
Definition: obj.h:803
@ OBJ_AUGTYP_CASE
case
Definition: obj.h:805
@ OBJ_DARG_NONE
not set
Definition: obj.h:1389
@ OBJ_DARG_NOT_SUPPORTED
deviate not-supported
Definition: obj.h:1393
@ OBJ_DARG_DELETE
deviate delete
Definition: obj.h:1391
@ OBJ_DARG_ADD
deviate add
Definition: obj.h:1390
@ OBJ_DARG_REPLACE
deviate replace
Definition: obj.h:1392
@ OBJ_TYP_CASE
This object represents a YANG case schema node.
Definition: obj.h:720
@ OBJ_TYP_ANYXML
This object represents a YANG 1.1 anydata data node.
Definition: obj.h:694
@ OBJ_TYP_CHOICE
This object represents a YANG choice schema node.
Definition: obj.h:715
@ OBJ_TYP_ACTION
This object represents a YANG 1.1 action schema node.
Definition: obj.h:786
@ OBJ_TYP_REFINE
This object represents a YANG refine statement.
Definition: obj.h:739
@ OBJ_TYP_USES
This object represents a YANG uses schema node.
Definition: obj.h:731
@ OBJ_TYP_NOTIF
This object represents a YANG notification statement.
Definition: obj.h:776
@ OBJ_TYP_LEAF_LIST
This object represents a YANG leaf-list data node.
Definition: obj.h:706
@ OBJ_TYP_LEAF
This object represents a YANG leaf data node.
Definition: obj.h:703
@ OBJ_TYP_ANYDATA
This object represents a YANG 1.1 anydata data node.
Definition: obj.h:779
@ OBJ_TYP_NONE
not set
Definition: obj.h:691
@ OBJ_TYP_RPCIO
This object represents a YANG input or output statement.
Definition: obj.h:767
@ OBJ_TYP_RPC
This object represents a YANG rpc statement.
Definition: obj.h:759
@ OBJ_TYP_CONTAINER
This object represents a YANG presence or non-presence container.
Definition: obj.h:700
@ OBJ_TYP_LIST
This object represents a YANG list data node.
Definition: obj.h:709
@ OBJ_TYP_AUGMENT
This object represents a YANG augment statement.
Definition: obj.h:750
YANG Grouping Statement Handler.
NCX System Logging Manager.
Contains NCX constants.
YANG module data structures Many internal representations of YANG module constructs.
NETCONF protocol remote procedure call common definitions.
Global error messages for status code enumerations.
One YANG 'grouping' definition – sibling set template.
Definition: grp.h:87
used with various structs to cache back-ptrs the 'node' pointer may or may not be malloced!...
Definition: ncxtypes.h:1530
struct to remember error info tkc->cur_err will be checked before tkc->cur for error information
Definition: ncxtypes.h:877
YANG if-feature entry.
Definition: ncxtypes.h:953
representation of one module or submodule during and after parsing
Definition: ncxtypes.h:1138
Schema Mount Root Control Block used in the object template.
Definition: ncxtypes.h:1893
One YANG augment statement struct (top-level or in case-stmt.
Definition: obj.h:1128
dlq_hdr_t datadefQ
Q of obj_template_t.
Definition: obj.h:1144
ncx_status_t status
status-stmt
Definition: obj.h:1143
xmlChar * target
Xpath schema-node target to augment.
Definition: obj.h:1130
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1136
obj_augtype_t augtype
internal augment type enum
Definition: obj.h:1142
uint16 depth
internal nest depth of augment
Definition: obj.h:1145
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1133
struct obj_template_t_ * targobj
resolved backptr to augmented object
Definition: obj.h:1139
One YANG 'case' definition.
Definition: obj.h:1002
xmlChar * name
case name
Definition: obj.h:1003
ncx_status_t status
status-stmt
Definition: obj.h:1016
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1009
boolean nameclone
the nameclone flag is set even though the clone bit is also set; this can probably be removed
Definition: obj.h:1015
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1006
dlq_hdr_t * datadefQ
Q of obj_template_t.
Definition: obj.h:1011
One YANG 'choice' definition.
Definition: obj.h:986
dlq_hdr_t * caseQ
Q of obj_template_t.
Definition: obj.h:995
xmlChar * name
choice name
Definition: obj.h:987
ncx_status_t status
status-stmt
Definition: obj.h:997
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:994
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:991
xmlChar * defval
default case
Definition: obj.h:988
boolean caseQclone
flag caseQ is cloned
Definition: obj.h:996
One YANG 'container' definition.
Definition: obj.h:847
xmlChar * name
name of container
Definition: obj.h:849
ncx_status_t status
status-stmt
Definition: obj.h:862
xmlChar * ref
reference-stmt (not saved by server)
Definition: obj.h:855
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:863
xmlChar * presence
presence-stmt
Definition: obj.h:858
xmlChar * descr
description-stmt (not saved by server)
Definition: obj.h:852
struct obj_template_t_ * defaultparm
default parm for yangcli
Definition: obj.h:864
dlq_hdr_t * typedefQ
Q of typ_template_t.
Definition: obj.h:859
dlq_hdr_t * datadefQ
Q of obj_template_t.
Definition: obj.h:861
dlq_hdr_t * groupingQ
Q of grp_template_t.
Definition: obj.h:860
One YANG 1.1 default stored in a Q for refine and deviate.
Definition: obj.h:819
xmlChar * def
default value string
Definition: obj.h:821
dlq_hdr_t qhdr
queue header
Definition: obj.h:820
ncx_error_t def_tkerr
file and line info for compiler
Definition: obj.h:822
YANG deviate statement struct.
Definition: obj.h:1398
dlq_hdr_t defval_tkQ
Q of obj_defval_tk_t (leaf-list can have multiple default-stmt)
Definition: obj.h:1431
dlq_hdr_t uniqueQ
Q of obj_unique_t.
Definition: obj.h:1453
ncx_error_t tkerr
the error info for each sub-clause is saved because when the deviation-stmt is parsed,...
Definition: obj.h:1407
dlq_hdr_t appinfoQ
Q of ncx_appinfo_t.
Definition: obj.h:1454
ncx_error_t arg_tkerr
same comment as tkerr
Definition: obj.h:1416
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:1452
boolean config
deviating config-stmt
Definition: obj.h:1434
dlq_hdr_t qhdr
queue header
Definition: obj.h:1399
typ_def_t * typdef
typedef if deviating the type
Definition: obj.h:1419
ncx_error_t type_tkerr
same comment as tkerr
Definition: obj.h:1422
uint32 maxelems
deviating max-elements
Definition: obj.h:1450
ncx_error_t config_tkerr
same comment as tkerr
Definition: obj.h:1437
uint32 minelems
deviating min-elements
Definition: obj.h:1446
ncx_error_t minelems_tkerr
also minset
Definition: obj.h:1447
xmlChar * units
units if deviating the units
Definition: obj.h:1425
boolean empty
deviate-stmt is empty
Definition: obj.h:1410
ncx_error_t units_tkerr
same comment as tkerr
Definition: obj.h:1428
ncx_error_t maxelems_tkerr
also maxset
Definition: obj.h:1451
ncx_error_t mandatory_tkerr
same comment as tkerr
Definition: obj.h:1443
obj_deviate_arg_t arg
deviate argument enum
Definition: obj.h:1413
boolean mandatory
deviating mandatory-stmt
Definition: obj.h:1440
YANG deviation statement struct.
Definition: obj.h:1459
ncx_error_t tkerr
file and line info for compiler
Definition: obj.h:1472
dlq_hdr_t appinfoQ
Q of ncx_appinfo_t.
Definition: obj.h:1478
xmlChar * target
schema-node target to deviate
Definition: obj.h:1461
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1469
xmlChar * devmodname
set if not the targmod
Definition: obj.h:1473
dlq_hdr_t qhdr
queue header
Definition: obj.h:1460
obj_template_t * targobj
target object when resolved
Definition: obj.h:1463
dlq_hdr_t deviateQ
Q of obj_deviate_t.
Definition: obj.h:1477
status_t res
parse status
Definition: obj.h:1476
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1466
boolean empty
for display in yangdump
Definition: obj.h:1474
boolean annotation
set from annotation
Definition: obj.h:1475
xmlChar * targmodname
target module name
Definition: obj.h:1462
custom error message filter control block
Definition: obj.h:1178
dlq_hdr_t qhdr
queue header
Definition: obj.h:1179
boolean is_errortag
error-tag flag
Definition: obj.h:1181
xmlChar * matchstr
message string to match
Definition: obj.h:1180
custom error message parameter control block
Definition: obj.h:1186
dlq_hdr_t qhdr
queue header
Definition: obj.h:1187
uint32 len
state : length
Definition: obj.h:1191
xmlChar * path
path of replacement data
Definition: obj.h:1188
xmlChar * valstr
state: value string
Definition: obj.h:1194
custom error message control block
Definition: obj.h:1199
xmlChar * langstr
language string
Definition: obj.h:1202
dlq_hdr_t qhdr
queue header
Definition: obj.h:1200
dlq_hdr_t parmQ
Q of obj_errmsg_parm_t.
Definition: obj.h:1203
xmlChar * basestr
base string
Definition: obj.h:1201
dlq_hdr_t filterQ
Q of obj_errmsg_filter_t.
Definition: obj.h:1204
back-pointer to inherited if-feature statements
Definition: obj.h:1171
dlq_hdr_t qhdr
queue heaader
Definition: obj.h:1172
ncx_iffeature_t * iffeature
if-feature back-ptr
Definition: obj.h:1173
One YANG list key component.
Definition: obj.h:811
struct obj_template_t_ * keyobj
backptr to key object
Definition: obj.h:813
dlq_hdr_t qhdr
queue header
Definition: obj.h:812
boolean seen
used by yangdiff
Definition: obj.h:814
One YANG 'leaf' or 'anyxml' or 'anydata' definition.
Definition: obj.h:870
struct obj_template_t_ * leafrefobj
leafref obj backptr only if btyp == NCX_BT_LEAFREF
Definition: obj.h:908
xmlChar * name
name of leaf or anyxml/anydata
Definition: obj.h:872
ncx_status_t status
status-stmt
Definition: obj.h:890
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:884
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:895
typ_def_t * typdef
typedef for the data type (leaf only)
Definition: obj.h:887
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:881
xmlChar * units
units-stmt only in a leaf
Definition: obj.h:875
dlq_hdr_t leafrefQ
used for quick leafref validation on server
Definition: obj.h:898
xmlChar * defval
default-stmt only in a leaf
Definition: obj.h:878
dlq_hdr_t uniqrefQ
used for quick unique-stmt validation on server A leaf can be the target of a unique stmt component f...
Definition: obj.h:905
uint16 keynum
internal key number only for keay leafs
Definition: obj.h:893
One YANG 'leaf-list' definition.
Definition: obj.h:914
ncx_sort_type_t sort_type
sort type applies to system
Definition: obj.h:945
struct obj_template_t_ * leafrefobj
leafref obj backptr only if btyp == NCX_BT_LEAFREF
Definition: obj.h:943
xmlChar * name
leaf-list name
Definition: obj.h:916
ncx_status_t status
status-stmt
Definition: obj.h:937
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:925
boolean minset
min-elements set
Definition: obj.h:933
boolean maxset
max-elements set
Definition: obj.h:935
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:938
typ_def_t * typdef
typedef for the data type
Definition: obj.h:928
uint32 maxelems
max-elements value
Definition: obj.h:936
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:922
uint32 minelems
min-elements value
Definition: obj.h:934
xmlChar * units
units-stmt
Definition: obj.h:919
dlq_hdr_t leafrefQ
Q of ncx_backptr_t to obj_template_t.
Definition: obj.h:939
dlq_hdr_t defvalQ
YANG 1.1, Q of malloced ncx_backptr_t.
Definition: obj.h:940
boolean ordersys
ordered-by system or user
Definition: obj.h:932
boolean defset
T if any defaults specified for this leaf-list.
Definition: obj.h:931
One YANG 'list' definition.
Definition: obj.h:950
dlq_hdr_t uniqueQ
Q of obj_unique_t.
Definition: obj.h:966
ncx_sort_type_t sort_type
sort type applies to system
Definition: obj.h:981
xmlChar * name
list name
Definition: obj.h:952
ncx_status_t status
status-stmt
Definition: obj.h:972
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:961
ncx_error_t keytkerr
saved error info for key-stmt errors
Definition: obj.h:976
boolean minset
min-elements set
Definition: obj.h:968
boolean maxset
max-elements set
Definition: obj.h:970
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:973
xmlChar * keystr
key-stmt (not required if config=false)
Definition: obj.h:955
uint32 maxelems
max-elements value
Definition: obj.h:971
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:958
uint32 minelems
min-elements value
Definition: obj.h:969
obj_index_t last_index
internal numbering data for val_child ordering
Definition: obj.h:979
dlq_hdr_t keyQ
Q of obj_key_t.
Definition: obj.h:965
boolean ordersys
ordered-by system or user
Definition: obj.h:967
dlq_hdr_t * typedefQ
Q of typ_template_t.
Definition: obj.h:962
dlq_hdr_t * datadefQ
Q of obj_template_t.
Definition: obj.h:964
dlq_hdr_t * groupingQ
Q of grp_template_t.
Definition: obj.h:963
One YANG metadata (XML attribute) node.
Definition: obj.h:1376
ncx_error_t tkerr
file and line info for compiler
Definition: obj.h:1382
xmlChar * name
metadata name
Definition: obj.h:1379
dlq_hdr_t qhdr
queue header
Definition: obj.h:1377
typ_def_t * typdef
typedef for metadata
Definition: obj.h:1380
struct obj_template_t_ * parent
obj containing metadata
Definition: obj.h:1378
xmlns_id_t nsid
in case parent == NULL
Definition: obj.h:1381
One YANG 'notification' clause definition.
Definition: obj.h:1150
boolean in_data
defined in data, YANG 1.1 only
Definition: obj.h:1166
boolean notif_enabled
enabled or disabled in server
Definition: obj.h:1164
dlq_hdr_t datadefQ
Q of obj_template_t.
Definition: obj.h:1162
xmlChar * name
notification name
Definition: obj.h:1152
ncx_status_t status
status-stmt
Definition: obj.h:1159
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1158
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:1163
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1155
boolean notif_log_drops
log drops for this event type
Definition: obj.h:1165
dlq_hdr_t * typedefQ
Q of typ_template_t.
Definition: obj.h:1160
dlq_hdr_t * groupingQ
Q of gtp_template_t.
Definition: obj.h:1161
defines the snmp oid value, stored as an array of integers for easier comparision when performing AVL...
Definition: obj.h:1217
oid_t * oidc
OID component.
Definition: obj.h:1219
uint8 cnt
amount of Sub-Ids (max 128)
Definition: obj.h:1218
One YANG refine statement struct.
Definition: obj.h:1039
dlq_hdr_t defval_tkQ
Q of obj_defval_tk_t.
Definition: obj.h:1069
xmlChar * target
relative-path of the object to refine
Definition: obj.h:1041
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1058
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:1080
xmlChar * presence
refining the presence-stmt
Definition: obj.h:1064
uint32 maxelems
max-elements value
Definition: obj.h:1078
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1047
ncx_error_t ref_tkerr
same comment as descr_tkerr applies here
Definition: obj.h:1061
ncx_error_t config_tkerr
config and confset are in the object flags
Definition: obj.h:1072
uint32 minelems
min-elements value
Definition: obj.h:1076
struct obj_template_t_ * targobj
resolved target object to refine
Definition: obj.h:1044
ncx_error_t minelems_tkerr
also minset
Definition: obj.h:1077
ncx_error_t descr_tkerr
the token for each sub-clause is saved because when the refine-stmt is parsed, the target is not know...
Definition: obj.h:1055
ncx_error_t maxelems_tkerr
also maxset
Definition: obj.h:1079
ncx_error_t presence_tkerr
same comment as descr_tkerr applies here
Definition: obj.h:1067
ncx_error_t mandatory_tkerr
mandatory and mandset are in the object flags
Definition: obj.h:1075
One YANG rpc-stmt struct.
Definition: obj.h:1105
dlq_hdr_t datadefQ
Q of obj_template_t.
Definition: obj.h:1118
xmlChar * name
rpc method name
Definition: obj.h:1107
ncx_status_t status
status-stmt
Definition: obj.h:1115
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1113
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1110
boolean supported
mod loaded, not implemented
Definition: obj.h:1123
dlq_hdr_t * typedefQ
Q of typ_template_t.
Definition: obj.h:1116
dlq_hdr_t * groupingQ
Q of gtp_template_t.
Definition: obj.h:1117
xmlns_id_t nsid
internal fields for manager and agent
Definition: obj.h:1122
boolean is_action
YANG 1.1 only.
Definition: obj.h:1119
One YANG input-stmt or output-stmt struct.
Definition: obj.h:1085
dlq_hdr_t datadefQ
Q of obj_template_t.
Definition: obj.h:1089
xmlChar * name
input or output
Definition: obj.h:1086
dlq_hdr_t mustQ
Q of xpath_pcb_t.
Definition: obj.h:1090
boolean is_input
YPW-1406: the name can be changed temporarily in XPath validation so need a flag to tell if input or ...
Definition: obj.h:1095
struct obj_template_t_ * defaultparm
the defaultparm is only used by yangcli-pro to allow 1 parameter in a command to be entered without a...
Definition: obj.h:1100
dlq_hdr_t * typedefQ
Q of typ_template_t.
Definition: obj.h:1087
dlq_hdr_t * groupingQ
Q of gtp_template_t.
Definition: obj.h:1088
One YANG data-def-stmt.
Definition: obj.h:1231
ncx_error_t tkerr
file and line info for compiler
Definition: obj.h:1246
ncx_sid_t yang_sid
Each object specific variant has a YANG SID assigned for CBOR encoding.
Definition: obj.h:1367
obj_oid_t * oid
SNMP OID for this object (set if needed)
Definition: obj.h:1250
ncx_transaction_id_t leafref_txid
current edit transaction ID for intermediate leafref processing
Definition: obj.h:1326
uint32 yang_hash
experimental: not used
Definition: obj.h:1235
obj_testflags_t desc_testflags
see AGT_TEST_FL_* definitions
Definition: obj.h:1245
dlq_hdr_t appinfoQ
Q of ncx_appinfo_t.
Definition: obj.h:1260
dlq_hdr_t iffeatureQ
Q of ncx_iffeature_t.
Definition: obj.h:1261
dlq_hdr_t * errmsgQ
custom error message used if this is the server running
Definition: obj.h:1308
dlq_hdr_t xpath_backptrQ
Q of ncx_back_ptr_t with node == xpath_pcb_t.
Definition: obj.h:1299
void * def_hook_cb
def_hook_cb is ncx_def_hook_cbfn_t callback function for Dynamic Default Hook callback.
Definition: obj.h:1350
uint8 silflags
see OBJ_FL_* definitions
Definition: obj.h:1242
dlq_hdr_t inherited_whenQ
Q of ncx_backptr_t with node == xpath_pcb_t.
Definition: obj.h:1266
struct obj_template_t_ * usesobj
backptr to uses-obj if grouping expand
Definition: obj.h:1255
uint8 sil_priority
picks SIL callback order
Definition: obj.h:1243
ncx_transaction_id_t edit_txid
current edit transaction ID for commit test pruning
Definition: obj.h:1317
ncx_transaction_id_t must_txid
current edit transaction ID for MUST test default nodes pruning
Definition: obj.h:1320
boolean set_snmp_flags
need SNMP flags
Definition: obj.h:1251
ncx_transaction_id_t when_txid
current edit transaction ID for WHEN test default nodes pruning
Definition: obj.h:1323
dlq_hdr_t metadataQ
Q of obj_metadata_t.
Definition: obj.h:1259
void * yangmap_cb
if set, backptr to the nodemap in a YANG model mapping OBJ_IS_YANGMAP_SOURCE() indicates this is the ...
Definition: obj.h:1314
dlq_hdr_t qhdr
queue header
Definition: obj.h:1232
grp_template_t * grp
non-NULL == in a grp.datadefQ
Definition: obj.h:1247
boolean xpath_oper_ok
object OK for referencing oper-data in XPath
Definition: obj.h:1252
dlq_hdr_t inherited_iffeatureQ
Q of obj_iffeature_ptr_t.
Definition: obj.h:1263
uint32 yang_sid_tree
SID tree assignment if yang_sid is used.
Definition: obj.h:1370
struct xpath_pcb_t_ * when
optional when clause
Definition: obj.h:1258
uint32 flags
see OBJ_FL_* definitions
Definition: obj.h:1237
ncx_sm_rootcb_t * rootcb
Schema Mount Control Block.
Definition: obj.h:1361
ncx_transaction_id_t def_txid
current edit transaction ID for intermediate default nodes processing
Definition: obj.h:1329
uint32 xflags
see OBJ_FL_* definitions
Definition: obj.h:1238
uint32 xflags2
see OBJ_FL_* definitions
Definition: obj.h:1239
obj_index_t index
object index for val_child ordering
Definition: obj.h:1248
struct obj_template_t_ * parent
backptr to parent
Definition: obj.h:1254
obj_type_t objtype
object type (def)
Definition: obj.h:1233
void * commit_test_cb
backptr to the commit_test record for this object which will only exist if this object has 'must' or ...
Definition: obj.h:1305
uint32 uflags
see OBJ_FL_* definitions
Definition: obj.h:1241
obj_testflags_t testflags
see AGT_TEST_FL_* definitions
Definition: obj.h:1244
void * bool_eval_cb
The bool_eval_cb callback function may be set to allow XPath eval to be done by the callback instead ...
Definition: obj.h:1358
void * get2cb
get2fn is getcb_fn2_t for local GET2
Definition: obj.h:1281
dlq_hdr_t * dataruleQ
Q obj NACM data-rule backptrs.
Definition: obj.h:1269
void * cbset
cbset is different based on the object type:
Definition: obj.h:1278
struct ncx_module_t_ * mod
object module and namespace ID assigned at runtime this can be changed over and over as a uses statem...
Definition: obj.h:1290
xmlns_id_t nsid
namespace ID assigned to the object at run-time
Definition: obj.h:1293
struct obj_template_t_ * augobj
backptr to augment-obj if augment expand
Definition: obj.h:1256
One component in a YANG list unique target.
Definition: obj.h:827
boolean isduplicate
T: will be ignored by server.
Definition: obj.h:831
dlq_hdr_t qhdr
queue header
Definition: obj.h:828
xmlChar * xpath
saved unique str for this obj
Definition: obj.h:830
struct obj_template_t_ * unobj
unique object target
Definition: obj.h:829
One component in a YANG list unique target.
Definition: obj.h:836
ncx_error_t tkerr
file and line info for compiler
Definition: obj.h:842
dlq_hdr_t compQ
Q of obj_unique_comp_t.
Definition: obj.h:839
dlq_hdr_t qhdr
queue header
Definition: obj.h:837
xmlChar * xpath
complete saved unique str
Definition: obj.h:838
boolean isconfig
T:constraint is on config.
Definition: obj.h:841
boolean seen
needed by yangdiff
Definition: obj.h:840
One YANG uses statement struct.
Definition: obj.h:1021
boolean expand_done
expand done flag
Definition: obj.h:1033
xmlChar * name
name of grouping to use
Definition: obj.h:1023
ncx_status_t status
status-stmt
Definition: obj.h:1032
xmlChar * ref
reference-stmt (not saved on server)
Definition: obj.h:1029
grp_template_t * grp
const back-ptr to grouping
Definition: obj.h:1030
xmlChar * descr
description-stmt (not saved on server)
Definition: obj.h:1026
boolean refine_done
refine targobj done flag
Definition: obj.h:1034
xmlChar * prefix
prefix present in uses-stmt
Definition: obj.h:1022
dlq_hdr_t * datadefQ
Q of obj_template_t.
Definition: obj.h:1031
token parsing chain (main parser control block)
Definition: tk.h:415
Discriminated union for all data typedefs.
Definition: typ.h:458
One YANG 'typedef' definition – top-level type template.
Definition: typ.h:477
gather node data into a simple struct.
Definition: xml_util.h:207
NCX Syntax Token Handler.
Parameter Type Handler.
object specific variants
Definition: obj.h:1332
XML Utilities.
XML namespace support.