diff options
author | Lev Walkin <vlm@lionet.info> | 2004-10-23 11:20:06 +0000 |
---|---|---|
committer | Lev Walkin <vlm@lionet.info> | 2004-10-23 11:20:06 +0000 |
commit | 9a6f65b2a18219811d38b6e4ba8a2ddb567dca53 (patch) | |
tree | 2a5606d66477dd2d58594c14bf7f1a94f15d6137 /skeletons/UniversalString.c | |
parent | 36b8b8270318e3d814c8092f75fb900bf8721850 (diff) |
XER decoding support
Diffstat (limited to 'skeletons/UniversalString.c')
-rw-r--r-- | skeletons/UniversalString.c | 68 |
1 files changed, 63 insertions, 5 deletions
diff --git a/skeletons/UniversalString.c b/skeletons/UniversalString.c index 2221000f..f3279b40 100644 --- a/skeletons/UniversalString.c +++ b/skeletons/UniversalString.c @@ -1,9 +1,10 @@ /*- - * Copyright (c) 2003 Lev Walkin <vlm@lionet.info>. All rights reserved. + * Copyright (c) 2003, 2004 Lev Walkin <vlm@lionet.info>. All rights reserved. * Redistribution and modifications are permitted subject to BSD license. */ #include <asn_internal.h> #include <UniversalString.h> +#include <UTF8String.h> /* * UniversalString basic type description. @@ -18,10 +19,10 @@ asn_TYPE_descriptor_t asn_DEF_UniversalString = { OCTET_STRING_free, UniversalString_print, /* Convert into UTF8 and print */ asn_generic_no_constraint, - OCTET_STRING_decode_ber, /* Implemented in terms of OCTET STRING */ - OCTET_STRING_encode_der, /* Implemented in terms of OCTET STRING */ - 0, /* Not implemented yet */ - UniversalString_encode_xer, /* Convert into UTF8 */ + OCTET_STRING_decode_ber, + OCTET_STRING_encode_der, + UniversalString_decode_xer, /* Convert from UTF-8 */ + UniversalString_encode_xer, /* Convert into UTF-8 */ 0, /* Use generic outmost tag fetcher */ asn_DEF_UniversalString_tags, sizeof(asn_DEF_UniversalString_tags) @@ -93,6 +94,63 @@ UniversalString__dump(const UniversalString_t *st, return wrote; } +asn_dec_rval_t +UniversalString_decode_xer(asn_codec_ctx_t *opt_codec_ctx, + asn_TYPE_descriptor_t *td, void **sptr, + const char *opt_mname, void *buf_ptr, size_t size) { + asn_dec_rval_t rc; + + rc = OCTET_STRING_decode_xer_utf8(opt_codec_ctx, td, sptr, opt_mname, + buf_ptr, size); + if(rc.code == RC_OK) { + /* + * Now we have a whole string in UTF-8 format. + * Convert it into UCS-4. + */ + uint32_t *wcs; + size_t wcs_len; + UTF8String_t *st; +#ifndef WORDS_BIGENDIAN + int little_endian = 1; +#endif + + assert(*sptr); + st = (UTF8String_t *)*sptr; + assert(st->buf); + wcs_len = UTF8String_to_wcs(st, 0, 0); + + wcs = (uint32_t *)MALLOC(4 * (wcs_len + 1)); + if(wcs == 0 || UTF8String_to_wcs(st, wcs, wcs_len) != wcs_len) { + rc.code = RC_FAIL; + rc.consumed = 0; + return rc; + } else { + wcs[wcs_len] = 0; /* nul-terminate */ + } + +#ifndef WORDS_BIGENDIAN + if(*(char *)&little_endian) { + /* Swap byte order in encoding */ + uint32_t *wc = wcs; + uint32_t *wc_end = wcs + wcs_len; + for(; wc < wc_end; wc++) { + /* *wc = htonl(*wc); */ + uint32_t wch = *wc; + *((uint8_t *)wc + 0) = wch >> 24; + *((uint8_t *)wc + 1) = wch >> 16; + *((uint8_t *)wc + 2) = wch >> 8; + *((uint8_t *)wc + 3) = wch; + } + } +#endif /* WORDS_BIGENDIAN */ + + FREEMEM(st->buf); + st->buf = (uint8_t *)wcs; + st->size = 4 * wcs_len; + } + return rc; +} + asn_enc_rval_t UniversalString_encode_xer(asn_TYPE_descriptor_t *td, void *sptr, int ilevel, enum xer_encoder_flags_e flags, |