mirror of
https://github.com/janet-lang/janet
synced 2025-01-13 00:50:26 +00:00
More work on serializer.
This commit is contained in:
parent
58edb63607
commit
145688b49f
@ -381,13 +381,10 @@ static const char *gst_deserialize_impl(
|
|||||||
gst_array_push(vm, visited, ret);
|
gst_array_push(vm, visited, ret);
|
||||||
err = gst_deserialize_impl(vm, data, end, &data, visited, &parent);
|
err = gst_deserialize_impl(vm, data, end, &data, visited, &parent);
|
||||||
if (err != NULL) return err;
|
if (err != NULL) return err;
|
||||||
err = gst_deserialize_impl(vm, data, end, &data, visited, &def);
|
|
||||||
if (err != NULL) return err;
|
|
||||||
err = gst_deserialize_impl(vm, data, end, &data, visited, &env);
|
err = gst_deserialize_impl(vm, data, end, &data, visited, &env);
|
||||||
if (err != NULL) return err;
|
if (err != NULL) return err;
|
||||||
printf("parent: %s\n", (const char *)gst_to_string(vm, parent));
|
err = gst_deserialize_impl(vm, data, end, &data, visited, &def);
|
||||||
printf("def: %s\n", (const char *)gst_to_string(vm, def));
|
if (err != NULL) return err;
|
||||||
printf("env: %s\n", (const char *)gst_to_string(vm, env));
|
|
||||||
if (parent.type == GST_NIL) {
|
if (parent.type == GST_NIL) {
|
||||||
ret.data.function->parent = NULL;
|
ret.data.function->parent = NULL;
|
||||||
} else if (parent.type == GST_FUNCTION) {
|
} else if (parent.type == GST_FUNCTION) {
|
||||||
@ -396,7 +393,7 @@ static const char *gst_deserialize_impl(
|
|||||||
deser_error("expected function");
|
deser_error("expected function");
|
||||||
}
|
}
|
||||||
deser_assert(def.type == GST_FUNCDEF, "expected funcdef");
|
deser_assert(def.type == GST_FUNCDEF, "expected funcdef");
|
||||||
ret.data.function->def = env.data.def;
|
ret.data.function->def = def.data.def;
|
||||||
if (env.type == GST_NIL) {
|
if (env.type == GST_NIL) {
|
||||||
ret.data.function->env = NULL;
|
ret.data.function->env = NULL;
|
||||||
} else {
|
} else {
|
||||||
@ -446,6 +443,7 @@ const char *gst_deserialize(
|
|||||||
const char *err;
|
const char *err;
|
||||||
GstArray *visited = gst_array(vm, 10);
|
GstArray *visited = gst_array(vm, 10);
|
||||||
err = gst_deserialize_impl(vm, data, data + len, nextData, visited, &ret);
|
err = gst_deserialize_impl(vm, data, data + len, nextData, visited, &ret);
|
||||||
|
printf("Read %ld\n", *nextData - data);
|
||||||
if (err != NULL) return err;
|
if (err != NULL) return err;
|
||||||
*out = ret;
|
*out = ret;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -699,10 +697,10 @@ const char *gst_serialize_impl(
|
|||||||
ev = fn->env ? gst_wrap_funcenv(fn->env) : gst_wrap_nil();
|
ev = fn->env ? gst_wrap_funcenv(fn->env) : gst_wrap_nil();
|
||||||
err = gst_serialize_impl(vm, buffer, visited, nextId, pv);
|
err = gst_serialize_impl(vm, buffer, visited, nextId, pv);
|
||||||
if (err != NULL) return err;
|
if (err != NULL) return err;
|
||||||
err = gst_serialize_impl(vm, buffer, visited, nextId, dv);
|
|
||||||
if (err != NULL) return err;
|
|
||||||
err = gst_serialize_impl(vm, buffer, visited, nextId, ev);
|
err = gst_serialize_impl(vm, buffer, visited, nextId, ev);
|
||||||
if (err != NULL) return err;
|
if (err != NULL) return err;
|
||||||
|
err = gst_serialize_impl(vm, buffer, visited, nextId, dv);
|
||||||
|
if (err != NULL) return err;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -14,5 +14,9 @@
|
|||||||
(scheck 123412.12)
|
(scheck 123412.12)
|
||||||
(scheck (funcdef (fn [] 1)))
|
(scheck (funcdef (fn [] 1)))
|
||||||
(scheck (funcenv (fn [] 1)))
|
(scheck (funcenv (fn [] 1)))
|
||||||
(scheck (funcenv ((fn [a] (fn [] a)) 1)))
|
(do
|
||||||
|
(: producer (fn [a] (fn [] a)))
|
||||||
|
(: f (producer "hello!"))
|
||||||
|
(scheck (funcenv f))
|
||||||
|
)
|
||||||
(scheck (fn [] 1))
|
(scheck (fn [] 1))
|
||||||
|
Loading…
Reference in New Issue
Block a user