Major New features
* New and updated search functions using xpath, api-path and instance-id
* New search functions using api-path and instance_id:
* C search functions: `clixon_find_instance_id()` and `clixon_find_api_path()`
* Binary search optimization in lists for indexed leafs in all three formats.
* This improves search performance to O(logN) which is drastical improvements for large lists.
* You can also register explicit indexes for making binary search (not only list keys)
* For more info, see docs at [paths](https://clixon-docs.readthedocs.io/en/latest/paths.html) and
[search](https://clixon-docs.readthedocs.io/en/latest/xml.html#searching-in-xml)
API changes on existing features (you may need to change your code)
* On failed validation of leafrefs, error message changed from: `No such leaf` to `No leaf <name> matching path <path>`.
* CLI Error message (clicon_rpc_generate_error()) changed when backend returns netconf error to be more descriptive:
* Original: `Config error: Validate failed. Edit and try again or discard changes: Invalid argument`
* New (example): `Netconf error: application operation-failed Identityref validation failed, undefined not derived from acl-base . Validate failed. Edit and try again or discard changes"
Minor changes
* Test framework
* Added `-- -S <file>` command-line to main example to be able to return any state to main example.
* Added `test/cicd` test scripts for running on a set of other hosts
* C-code restructuring
* clixon_yang.c partitioned and moved code into clixon_yang_parse_lib.c and clixon_yang_module.c and move back some code from clixon_yang_type.c.
* partly to reduce size, but most important to limit code that accesses internal yang structures, only clixon_yang.c does this now.
68 lines
2.3 KiB
C
68 lines
2.3 KiB
C
/*
|
|
*
|
|
***** BEGIN LICENSE BLOCK *****
|
|
|
|
Copyright (C) 2009-2020 Olof Hagsand
|
|
|
|
This file is part of CLIXON.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
|
|
Alternatively, the contents of this file may be used under the terms of
|
|
the GNU General Public License Version 3 or later (the "GPL"),
|
|
in which case the provisions of the GPL are applicable instead
|
|
of those above. If you wish to allow use of your version of this file only
|
|
under the terms of the GPL, and not to allow others to
|
|
use your version of this file under the terms of Apache License version 2,
|
|
indicate your decision by deleting the provisions above and replace them with
|
|
the notice and other provisions required by the GPL. If you do not delete
|
|
the provisions above, a recipient may use your version of this file under
|
|
the terms of any one of the Apache License version 2 or the GPL.
|
|
|
|
***** END LICENSE BLOCK *****
|
|
|
|
*/
|
|
#ifndef _CLIXON_JSON_PARSE_H_
|
|
#define _CLIXON_JSON_PARSE_H_
|
|
|
|
/*
|
|
* Types
|
|
*/
|
|
|
|
struct clicon_json_yacc_arg{ /* XXX: mostly unrelevant */
|
|
const char *jy_name; /* Name of syntax (for error string) */
|
|
int jy_linenum; /* Number of \n in parsed buffer */
|
|
char *jy_parse_string; /* original (copy of) parse string */
|
|
void *jy_lexbuf; /* internal parse buffer from lex */
|
|
cxobj *jy_current;
|
|
};
|
|
|
|
/*
|
|
* Variables
|
|
*/
|
|
extern char *clixon_json_parsetext;
|
|
|
|
/*
|
|
* Prototypes
|
|
*/
|
|
int json_scan_init(struct clicon_json_yacc_arg *jy);
|
|
int json_scan_exit(struct clicon_json_yacc_arg *jy);
|
|
|
|
int json_parse_init(struct clicon_json_yacc_arg *jy);
|
|
int json_parse_exit(struct clicon_json_yacc_arg *jy);
|
|
|
|
int clixon_json_parselex(void *);
|
|
int clixon_json_parseparse(void *);
|
|
void clixon_json_parseerror(void *, char*);
|
|
|
|
#endif /* _CLIXON_JSON_PARSE_H_ */
|