* `201 Created` for created resources * `204 No Content` for replaced resources. * See [RESTCONF: HTTP return codes are not according to RFC 8040](https://github.com/clicon/clixon/issues/56) * HTTP `Location:` fields added in RESTCONF POST replies
154 lines
4.8 KiB
C
154 lines
4.8 KiB
C
/*
|
|
*
|
|
***** BEGIN LICENSE BLOCK *****
|
|
|
|
Copyright (C) 2009-2019 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 *****
|
|
|
|
* Clixon XML XPATH 1.0 according to https://www.w3.org/TR/xpath-10
|
|
*/
|
|
#ifndef _CLIXON_XPATH_H
|
|
#define _CLIXON_XPATH_H
|
|
|
|
/*
|
|
* Types
|
|
*/
|
|
enum xp_op{
|
|
XO_AND,
|
|
XO_OR,
|
|
XO_DIV,
|
|
XO_MOD,
|
|
XO_ADD,
|
|
XO_MULT,
|
|
XO_SUB,
|
|
XO_EQ,
|
|
XO_NE,
|
|
XO_GE,
|
|
XO_LE,
|
|
XO_LT,
|
|
XO_GT,
|
|
XO_UNION,
|
|
};
|
|
|
|
/* Axis specifiers according to https://www.w3.org/TR/xpath-10/#NT-AxisName */
|
|
enum axis_type{
|
|
A_NAN = 0, /* Not set */
|
|
A_ANCESTOR,
|
|
A_ANCESTOR_OR_SELF,
|
|
A_ATTRIBUTE,
|
|
A_CHILD,
|
|
A_DESCENDANT,
|
|
A_DESCENDANT_OR_SELF,
|
|
A_FOLLOWING,
|
|
A_FOLLOWING_SIBLING,
|
|
A_NAMESPACE,
|
|
A_PARENT,
|
|
A_PRECEEDING,
|
|
A_PRECEEDING_SIBLING,
|
|
A_SELF,
|
|
A_ROOT /* XXX Not in https://www.w3.org/TR/xpath-10 */
|
|
};
|
|
|
|
/* used as non-terminal type in yacc rules */
|
|
enum xp_type{
|
|
XP_EXP,
|
|
XP_AND,
|
|
XP_RELEX,
|
|
XP_ADD,
|
|
XP_UNION,
|
|
XP_PATHEXPR,
|
|
XP_LOCPATH,
|
|
XP_ABSPATH,
|
|
XP_RELLOCPATH,
|
|
XP_STEP,
|
|
XP_NODE, /* s0 is namespace prefix, s1 is name */
|
|
XP_NODE_FN,
|
|
XP_PRED,
|
|
XP_PRI0,
|
|
XP_PRIME_NR,
|
|
XP_PRIME_STR,
|
|
XP_PRIME_FN,
|
|
};
|
|
|
|
/*! XPATH Parsing generates a tree of nodes that is later traversed
|
|
*/
|
|
struct xpath_tree{
|
|
enum xp_type xs_type;
|
|
int xs_int;
|
|
double xs_double;
|
|
char *xs_s0;
|
|
char *xs_s1;
|
|
struct xpath_tree *xs_c0; /* child 0 */
|
|
struct xpath_tree *xs_c1; /* child 1 */
|
|
};
|
|
typedef struct xpath_tree xpath_tree;
|
|
|
|
/*
|
|
* Prototypes
|
|
*/
|
|
char* xpath_tree_int2str(int nodetype);
|
|
int xpath_tree_print(cbuf *cb, xpath_tree *xs);
|
|
int xpath_tree_free(xpath_tree *xs);
|
|
int xpath_parse(cvec *nsc, char *xpath, xpath_tree **xptree);
|
|
int xpath_vec_ctx(cxobj *xcur, cvec *nsc, char *xpath, xp_ctx **xrp);
|
|
|
|
#if defined(__GNUC__) && __GNUC__ >= 3
|
|
int xpath_vec_bool(cxobj *xcur, cvec *nsc, char *xpformat, ...) __attribute__ ((format (printf, 3, 4)));
|
|
int xpath_vec_flag(cxobj *xcur, cvec *nsc, char *xpformat, uint16_t flags,
|
|
cxobj ***vec, size_t *veclen, ...) __attribute__ ((format (printf, 3, 7)));
|
|
|
|
#else
|
|
int xpath_vec_bool(cxobj *xcur, cvec *nsc, char *xpformat, ...);
|
|
int xpath_vec_flag(cxobj *xcur, cvec *nsc, char *xpformat, uint16_t flags,
|
|
cxobj ***vec, size_t *veclen, ...);
|
|
#endif
|
|
|
|
/* Functions with explicit namespace context (nsc) set. If you do not need
|
|
* explicit namespace contexts (most do not) consider using the API functions
|
|
* below without nsc set.
|
|
* If you do not know what a namespace context is, see README.md#xml-and-xpath
|
|
*/
|
|
#if defined(__GNUC__) && __GNUC__ >= 3
|
|
cxobj *xpath_first_nsc(cxobj *xcur, cvec *nsc, char *xpformat, ...) __attribute__ ((format (printf, 3, 4)));
|
|
int xpath_vec_nsc(cxobj *xcur, cvec *nsc, char *xpformat, cxobj ***vec, size_t *veclen, ...) __attribute__ ((format (printf, 3, 6)));
|
|
#else
|
|
cxobj *xpath_first_nsc(cxobj *xcur, cvec *nsc, char *xpformat, ...);
|
|
int xpath_vec_nsc(cxobj *xcur, cvec *nsc, char *xpformat, cxobj ***vec, size_t *veclen, ...);
|
|
#endif
|
|
|
|
/* Functions with nsc == NULL (implicit xpath context). */
|
|
#if defined(__GNUC__) && __GNUC__ >= 3
|
|
cxobj *xpath_first(cxobj *xcur, char *xpformat, ...) __attribute__ ((format (printf, 2, 3)));
|
|
int xpath_vec(cxobj *xcur, char *xpformat, cxobj ***vec, size_t *veclen, ...) __attribute__ ((format (printf, 2, 5)));
|
|
#else
|
|
cxobj *xpath_first(cxobj *xcur, char *xpformat, ...);
|
|
int xpath_vec(cxobj *xcur, char *xpformat, cxobj ***vec, size_t *veclen, ...);
|
|
#endif
|
|
|
|
#endif /* _CLIXON_XPATH_H */
|