Browse Source

Allow encoding of improper lists

improper-lists
Paul J. Davis 6 years ago
parent
commit
f01770755d
1 changed files with 11 additions and 6 deletions
  1. +11
    -6
      c_src/encoder.c

+ 11
- 6
c_src/encoder.c View File

@ -632,6 +632,7 @@ encode_iter(ErlNifEnv* env, int argc, const ERL_NIF_TERM argv[])
ERL_NIF_TERM stack; ERL_NIF_TERM stack;
ERL_NIF_TERM curr; ERL_NIF_TERM curr;
ERL_NIF_TERM item; ERL_NIF_TERM item;
ERL_NIF_TERM tmp;
const ERL_NIF_TERM* tuple; const ERL_NIF_TERM* tuple;
int arity; int arity;
ErlNifSInt64 lval; ErlNifSInt64 lval;
@ -689,9 +690,11 @@ encode_iter(ErlNifEnv* env, int argc, const ERL_NIF_TERM argv[])
} }
continue; continue;
} }
if(!enif_get_list_cell(env, curr, &item, &curr)) {
ret = enc_error(e, "internal_error");
goto done;
if(!enif_get_list_cell(env, curr, &item, &tmp)) {
item = curr;
curr = enif_make_list(env, 0);
} else {
curr = tmp;
} }
if(!enif_get_tuple(env, item, &arity, &tuple)) { if(!enif_get_tuple(env, item, &arity, &tuple)) {
ret = enc_obj_error(e, "invalid_object_member", item); ret = enc_obj_error(e, "invalid_object_member", item);
@ -732,9 +735,11 @@ encode_iter(ErlNifEnv* env, int argc, const ERL_NIF_TERM argv[])
ret = enc_error(e, "internal_error"); ret = enc_error(e, "internal_error");
goto done; goto done;
} }
if(!enif_get_list_cell(env, curr, &item, &curr)) {
ret = enc_error(e, "internal_error");
goto done;
if(!enif_get_list_cell(env, curr, &item, &tmp)) {
item = curr;
curr = enif_make_list(env, 0);
} else {
curr = tmp;
} }
stack = enif_make_list_cell(env, curr, stack); stack = enif_make_list_cell(env, curr, stack);
stack = enif_make_list_cell(env, e->atoms->ref_array, stack); stack = enif_make_list_cell(env, e->atoms->ref_array, stack);

Loading…
Cancel
Save