Skip to content

Commit

Permalink
Merge pull request #146 from v0-e/jer-relative-oid-fix
Browse files Browse the repository at this point in the history
jer: RELATIVE-OID add quotes
  • Loading branch information
mouse07410 authored Dec 3, 2023
2 parents d57abfb + da521e0 commit bc7f333
Showing 1 changed file with 28 additions and 2 deletions.
30 changes: 28 additions & 2 deletions skeletons/RELATIVE-OID_jer.c
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,14 @@
#include <asn_internal.h>
#include <RELATIVE-OID.h>

#define CQUOTE 0x22

static enum jer_pbd_rval
RELATIVE_OID__jer_body_decode(const asn_TYPE_descriptor_t *td, void *sptr,
const void *chunk_buf, size_t chunk_size) {
RELATIVE_OID_t *st = (RELATIVE_OID_t *)sptr;
const char *chunk_end = (const char *)chunk_buf + chunk_size;
const char* p = (const char*)chunk_buf;
const char *endptr;
asn_oid_arc_t s_arcs[6];
asn_oid_arc_t *arcs = s_arcs;
Expand All @@ -19,6 +22,22 @@ RELATIVE_OID__jer_body_decode(const asn_TYPE_descriptor_t *td, void *sptr,

(void)td;

/* Strip quotes */
for (; p < chunk_end; ++p) {
if (*p == CQUOTE) {
++p;
break;
}
}
for (; chunk_end >= p; --chunk_end) {
if (*chunk_end == CQUOTE)
break;
}
if (chunk_end - p < 0)
return JPBD_BROKEN_ENCODING;
chunk_size = chunk_end - p;
chunk_buf = p;

num_arcs = OBJECT_IDENTIFIER_parse_arcs(
(const char *)chunk_buf, chunk_size, arcs,
sizeof(s_arcs) / sizeof(s_arcs[0]), &endptr);
Expand Down Expand Up @@ -65,15 +84,22 @@ RELATIVE_OID_encode_jer(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_consume_bytes_f *cb, void *app_key) {
const RELATIVE_OID_t *st = (const RELATIVE_OID_t *)sptr;
asn_enc_rval_t er = {0,0,0};
ssize_t ro_encoded = 0;

(void)ilevel; /* Unused argument */
(void)flags; /* Unused argument */

if(!st || !st->buf)
ASN__ENCODE_FAILED;

er.encoded = RELATIVE_OID__dump_body(st, cb, app_key);
if(er.encoded < 0) ASN__ENCODE_FAILED;
ASN__CALLBACK("\"", 1);
ro_encoded = RELATIVE_OID__dump_body(st, cb, app_key);
if(ro_encoded < 0) goto cb_failed;
er.encoded += ro_encoded;
ASN__CALLBACK("\"", 1);

ASN__ENCODED_OK(er);

cb_failed:
ASN__ENCODE_FAILED;
}

0 comments on commit bc7f333

Please sign in to comment.