瀏覽代碼

Allow encoding of improper lists

improper-lists
Paul J. Davis 6 年之前
父節點
當前提交
f01770755d
共有 1 個檔案被更改,包括 11 行新增6 行删除
  1. +11
    -6
      c_src/encoder.c

+ 11
- 6
c_src/encoder.c 查看文件

@ -632,6 +632,7 @@ encode_iter(ErlNifEnv* env, int argc, const ERL_NIF_TERM argv[])
ERL_NIF_TERM stack;
ERL_NIF_TERM curr;
ERL_NIF_TERM item;
ERL_NIF_TERM tmp;
const ERL_NIF_TERM* tuple;
int arity;
ErlNifSInt64 lval;
@ -689,9 +690,11 @@ encode_iter(ErlNifEnv* env, int argc, const ERL_NIF_TERM argv[])
}
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)) {
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");
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, e->atoms->ref_array, stack);

Loading…
取消
儲存