blob: f865102bfbdd4e679e1bcd605d250b1256a1eac9 [file] [log] [blame]
Lev Walkindc06f6b2004-10-20 15:50:55 +00001/*-
2 * Copyright (c) 2004 Lev Walkin <vlm@lionet.info>. All rights reserved.
3 * Redistribution and modifications are permitted subject to BSD license.
4 */
5#ifndef _XER_DECODER_H_
6#define _XER_DECODER_H_
7
8#include <asn_application.h>
9
Lev Walkin21b41ac2005-07-24 09:03:44 +000010#ifdef __cplusplus
11extern "C" {
12#endif
13
Lev Walkindc06f6b2004-10-20 15:50:55 +000014struct asn_TYPE_descriptor_s; /* Forward declaration */
15
16/*
Lev Walkin1d9e8dd2005-12-07 05:46:03 +000017 * The XER decoder of any ASN.1 type. May be invoked by the application.
Lev Walkin28647742017-09-12 11:07:06 -070018 * Decodes CANONICAL-XER and BASIC-XER.
Lev Walkindc06f6b2004-10-20 15:50:55 +000019 */
Lev Walkinafbf2a92017-09-12 23:30:27 -070020asn_dec_rval_t xer_decode(const struct asn_codec_ctx_s *opt_codec_ctx,
Lev Walkindc06f6b2004-10-20 15:50:55 +000021 struct asn_TYPE_descriptor_s *type_descriptor,
22 void **struct_ptr, /* Pointer to a target structure's pointer */
Lev Walkin8c3b8542005-03-10 18:52:02 +000023 const void *buffer, /* Data to be decoded */
Lev Walkin1d9e8dd2005-12-07 05:46:03 +000024 size_t size /* Size of data buffer */
Lev Walkindc06f6b2004-10-20 15:50:55 +000025 );
26
27/*
28 * Type of the type-specific XER decoder function.
29 */
Lev Walkinafbf2a92017-09-12 23:30:27 -070030typedef asn_dec_rval_t(xer_type_decoder_f)(
31 const asn_codec_ctx_t *opt_codec_ctx,
32 struct asn_TYPE_descriptor_s *type_descriptor, void **struct_ptr,
33 const char *opt_mname, /* Member name */
34 const void *buf_ptr, size_t size);
Lev Walkindc06f6b2004-10-20 15:50:55 +000035
36/*******************************
37 * INTERNALLY USEFUL FUNCTIONS *
38 *******************************/
39
40/*
41 * Generalized function for decoding the primitive values.
42 * Used by more specialized functions, such as OCTET_STRING_decode_xer_utf8
43 * and others. This function should not be used by applications, as its API
44 * is subject to changes.
45 */
Lev Walkinafbf2a92017-09-12 23:30:27 -070046asn_dec_rval_t xer_decode_general(
47 const asn_codec_ctx_t *opt_codec_ctx,
48 asn_struct_ctx_t *ctx, /* Type decoder context */
49 void *struct_key, /* Treated as opaque pointer */
50 const char *xml_tag, /* Expected XML tag name */
51 const void *buf_ptr, size_t size,
52 int (*opt_unexpected_tag_decoder)(void *struct_key, const void *chunk_buf,
53 size_t chunk_size),
54 ssize_t (*body_receiver)(void *struct_key, const void *chunk_buf,
55 size_t chunk_size, int have_more));
Lev Walkindc06f6b2004-10-20 15:50:55 +000056
57
58/*
59 * Fetch the next XER (XML) token from the stream.
60 * The function returns the number of bytes occupied by the chunk type,
61 * returned in the _ch_type. The _ch_type is only set (and valid) when
Lev Walkin97363482016-01-24 19:23:02 -080062 * the return value is >= 0.
Lev Walkindc06f6b2004-10-20 15:50:55 +000063 */
64 typedef enum pxer_chunk_type {
Lev Walkin97363482016-01-24 19:23:02 -080065 PXER_WMORE, /* Chunk type is not clear, more data expected. */
66 PXER_TAG, /* Complete XER tag */
67 PXER_TEXT, /* Plain text between XER tags */
Lev Walkin8c3b8542005-03-10 18:52:02 +000068 PXER_COMMENT /* A comment, may be part of */
Lev Walkindc06f6b2004-10-20 15:50:55 +000069 } pxer_chunk_type_e;
Lev Walkin1e443962005-02-18 18:06:36 +000070ssize_t xer_next_token(int *stateContext,
Lev Walkin0fab1a62005-03-09 22:19:25 +000071 const void *buffer, size_t size, pxer_chunk_type_e *_ch_type);
Lev Walkindc06f6b2004-10-20 15:50:55 +000072
73/*
74 * This function checks the buffer against the tag name is expected to occur.
75 */
76 typedef enum xer_check_tag {
Lev Walkin904e65b2005-02-18 14:23:48 +000077 XCT_BROKEN = 0, /* The tag is broken */
78 XCT_OPENING = 1, /* This is the <opening> tag */
79 XCT_CLOSING = 2, /* This is the </closing> tag */
80 XCT_BOTH = 3, /* This is the <modified/> tag */
81 XCT__UNK__MASK = 4, /* Mask of everything unexpected */
82 XCT_UNKNOWN_OP = 5, /* Unexpected <opening> tag */
83 XCT_UNKNOWN_CL = 6, /* Unexpected </closing> tag */
Lev Walkin8c3b8542005-03-10 18:52:02 +000084 XCT_UNKNOWN_BO = 7 /* Unexpected <modified/> tag */
Lev Walkindc06f6b2004-10-20 15:50:55 +000085 } xer_check_tag_e;
86xer_check_tag_e xer_check_tag(const void *buf_ptr, int size,
87 const char *need_tag);
88
Lev Walkindde25b32004-10-22 08:17:16 +000089/*
Lev Walkinf7982282013-03-16 07:01:42 -070090 * Get the number of bytes consisting entirely of XER whitespace characters.
Lev Walkindde25b32004-10-22 08:17:16 +000091 * RETURN VALUES:
Lev Walkinf7982282013-03-16 07:01:42 -070092 * >=0: Number of whitespace characters in the string.
Lev Walkindde25b32004-10-22 08:17:16 +000093 */
Lev Walkinf7982282013-03-16 07:01:42 -070094size_t xer_whitespace_span(const void *chunk_buf, size_t chunk_size);
Lev Walkindde25b32004-10-22 08:17:16 +000095
Lev Walkin2eeeedc2005-02-18 16:10:40 +000096/*
97 * Skip the series of anticipated extensions.
98 */
99int xer_skip_unknown(xer_check_tag_e tcv, ber_tlv_len_t *depth);
100
Lev Walkin21b41ac2005-07-24 09:03:44 +0000101#ifdef __cplusplus
102}
103#endif
104
Lev Walkindc06f6b2004-10-20 15:50:55 +0000105#endif /* _XER_DECODER_H_ */