mirror of
https://github.com/janet-lang/janet
synced 2025-01-15 09:55:40 +00:00
Merge branch 'master' into threads-3
This commit is contained in:
commit
a1f35e21c7
@ -2145,7 +2145,7 @@
|
|||||||
(if-let [jp (os/getenv "JANET_HEADERPATH")] (setdyn :headerpath jp))
|
(if-let [jp (os/getenv "JANET_HEADERPATH")] (setdyn :headerpath jp))
|
||||||
|
|
||||||
# Flag handlers
|
# Flag handlers
|
||||||
(def handlers :private
|
(def handlers
|
||||||
{"h" (fn [&]
|
{"h" (fn [&]
|
||||||
(print "usage: " (dyn :executable "janet") " [options] script args...")
|
(print "usage: " (dyn :executable "janet") " [options] script args...")
|
||||||
(print
|
(print
|
||||||
@ -2213,7 +2213,7 @@
|
|||||||
(while (< i lenargs)
|
(while (< i lenargs)
|
||||||
(def arg (in args i))
|
(def arg (in args i))
|
||||||
(if (and *handleopts* (= "-" (string/slice arg 0 1)))
|
(if (and *handleopts* (= "-" (string/slice arg 0 1)))
|
||||||
(+= i (dohandler (string/slice arg 1 2) i))
|
(+= i (dohandler (string/slice arg 1) i))
|
||||||
(do
|
(do
|
||||||
(set *no-file* false)
|
(set *no-file* false)
|
||||||
(dofile arg :prefix "" :exit *exit-on-error* :evaluator evaluator)
|
(dofile arg :prefix "" :exit *exit-on-error* :evaluator evaluator)
|
||||||
|
@ -85,6 +85,7 @@ static const JanetInstructionDef janet_ops[] = {
|
|||||||
{"gten", JOP_NUMERIC_GREATER_THAN_EQUAL},
|
{"gten", JOP_NUMERIC_GREATER_THAN_EQUAL},
|
||||||
{"gtim", JOP_GREATER_THAN_IMMEDIATE},
|
{"gtim", JOP_GREATER_THAN_IMMEDIATE},
|
||||||
{"gtn", JOP_NUMERIC_GREATER_THAN},
|
{"gtn", JOP_NUMERIC_GREATER_THAN},
|
||||||
|
{"in", JOP_IN},
|
||||||
{"jmp", JOP_JUMP},
|
{"jmp", JOP_JUMP},
|
||||||
{"jmpif", JOP_JUMP_IF},
|
{"jmpif", JOP_JUMP_IF},
|
||||||
{"jmpno", JOP_JUMP_IF_NOT},
|
{"jmpno", JOP_JUMP_IF_NOT},
|
||||||
|
@ -80,6 +80,7 @@ enum JanetInstructionType janet_instructions[JOP_INSTRUCTION_COUNT] = {
|
|||||||
JINT_SSS, /* JOP_RESUME, */
|
JINT_SSS, /* JOP_RESUME, */
|
||||||
JINT_SSU, /* JOP_SIGNAL, */
|
JINT_SSU, /* JOP_SIGNAL, */
|
||||||
JINT_SSS, /* JOP_PROPAGATE */
|
JINT_SSS, /* JOP_PROPAGATE */
|
||||||
|
JINT_SSS, /* JOP_IN, */
|
||||||
JINT_SSS, /* JOP_GET, */
|
JINT_SSS, /* JOP_GET, */
|
||||||
JINT_SSS, /* JOP_PUT, */
|
JINT_SSS, /* JOP_PUT, */
|
||||||
JINT_SSU, /* JOP_GET_INDEX, */
|
JINT_SSU, /* JOP_GET_INDEX, */
|
||||||
|
@ -106,6 +106,9 @@ static JanetSlot do_debug(JanetFopts opts, JanetSlot *args) {
|
|||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
static JanetSlot do_in(JanetFopts opts, JanetSlot *args) {
|
static JanetSlot do_in(JanetFopts opts, JanetSlot *args) {
|
||||||
|
return opreduce(opts, args, JOP_IN, janet_wrap_nil());
|
||||||
|
}
|
||||||
|
static JanetSlot do_get(JanetFopts opts, JanetSlot *args) {
|
||||||
return opreduce(opts, args, JOP_GET, janet_wrap_nil());
|
return opreduce(opts, args, JOP_GET, janet_wrap_nil());
|
||||||
}
|
}
|
||||||
static JanetSlot do_put(JanetFopts opts, JanetSlot *args) {
|
static JanetSlot do_put(JanetFopts opts, JanetSlot *args) {
|
||||||
@ -302,7 +305,8 @@ static const JanetFunOptimizer optimizers[] = {
|
|||||||
{NULL, do_lte},
|
{NULL, do_lte},
|
||||||
{NULL, do_eq},
|
{NULL, do_eq},
|
||||||
{NULL, do_neq},
|
{NULL, do_neq},
|
||||||
{fixarity2, do_propagate}
|
{fixarity2, do_propagate},
|
||||||
|
{fixarity2, do_get}
|
||||||
};
|
};
|
||||||
|
|
||||||
const JanetFunOptimizer *janetc_funopt(uint32_t flags) {
|
const JanetFunOptimizer *janetc_funopt(uint32_t flags) {
|
||||||
|
@ -61,6 +61,7 @@
|
|||||||
#define JANET_FUN_EQ 30
|
#define JANET_FUN_EQ 30
|
||||||
#define JANET_FUN_NEQ 31
|
#define JANET_FUN_NEQ 31
|
||||||
#define JANET_FUN_PROP 32
|
#define JANET_FUN_PROP 32
|
||||||
|
#define JANET_FUN_GET 33
|
||||||
|
|
||||||
/* Compiler typedefs */
|
/* Compiler typedefs */
|
||||||
typedef struct JanetCompiler JanetCompiler;
|
typedef struct JanetCompiler JanetCompiler;
|
||||||
|
@ -262,17 +262,6 @@ static Janet janet_core_setdyn(int32_t argc, Janet *argv) {
|
|||||||
return argv[1];
|
return argv[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
// XXX inline asm function with a new op - OP_GET_PERMISSIVE?
|
|
||||||
// This would match up with OP_GET which is used for 'in'.
|
|
||||||
static Janet janet_core_get(int32_t argc, Janet *argv) {
|
|
||||||
janet_arity(argc, 2, 3);
|
|
||||||
Janet result = janet_get_permissive(argv[0], argv[1]);
|
|
||||||
if (argc == 3 && janet_checktype(result, JANET_NIL)) {
|
|
||||||
return argv[2];
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
static Janet janet_core_native(int32_t argc, Janet *argv) {
|
static Janet janet_core_native(int32_t argc, Janet *argv) {
|
||||||
JanetModule init;
|
JanetModule init;
|
||||||
janet_arity(argc, 1, 2);
|
janet_arity(argc, 1, 2);
|
||||||
@ -696,14 +685,6 @@ static const JanetReg corelib_cfuns[] = {
|
|||||||
JDOC("(slice x &opt start end)\n\n"
|
JDOC("(slice x &opt start end)\n\n"
|
||||||
"Extract a sub-range of an indexed data strutrue or byte sequence.")
|
"Extract a sub-range of an indexed data strutrue or byte sequence.")
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"get", janet_core_get,
|
|
||||||
JDOC("(get ds key &opt dflt)\n\n"
|
|
||||||
"Get the value mapped to key in data structure ds, and return dflt or nil if not found. "
|
|
||||||
"Similar to in, but will not throw an error if the key is invalid for the data structure "
|
|
||||||
"unless the data structure is an abstract type. In that case, the abstract type getter may throw "
|
|
||||||
"an error.")
|
|
||||||
},
|
|
||||||
{NULL, NULL, NULL}
|
{NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -785,7 +766,7 @@ static void templatize_varop(
|
|||||||
SSI(JOP_GET_INDEX, 3, 0, 0), /* accum = args[0] */
|
SSI(JOP_GET_INDEX, 3, 0, 0), /* accum = args[0] */
|
||||||
SI(JOP_LOAD_INTEGER, 5, 1), /* i = 1 */
|
SI(JOP_LOAD_INTEGER, 5, 1), /* i = 1 */
|
||||||
/* Main loop */
|
/* Main loop */
|
||||||
SSS(JOP_GET, 4, 0, 5), /* operand = args[i] */
|
SSS(JOP_IN, 4, 0, 5), /* operand = args[i] */
|
||||||
SSS(op, 3, 3, 4), /* accum = accum op operand */
|
SSS(op, 3, 3, 4), /* accum = accum op operand */
|
||||||
SSI(JOP_ADD_IMMEDIATE, 5, 5, 1), /* i++ */
|
SSI(JOP_ADD_IMMEDIATE, 5, 5, 1), /* i++ */
|
||||||
SSI(JOP_EQUALS, 2, 5, 1), /* jump? = (i == argn) */
|
SSI(JOP_EQUALS, 2, 5, 1), /* jump? = (i == argn) */
|
||||||
@ -833,7 +814,7 @@ static void templatize_comparator(
|
|||||||
SI(JOP_LOAD_INTEGER, 5, 1), /* i = 1 */
|
SI(JOP_LOAD_INTEGER, 5, 1), /* i = 1 */
|
||||||
|
|
||||||
/* Main loop */
|
/* Main loop */
|
||||||
SSS(JOP_GET, 4, 0, 5), /* next = args[i] */
|
SSS(JOP_IN, 4, 0, 5), /* next = args[i] */
|
||||||
SSS(op, 2, 3, 4), /* jump? = last compare next */
|
SSS(op, 2, 3, 4), /* jump? = last compare next */
|
||||||
SI(JOP_JUMP_IF_NOT, 2, 7), /* if not jump? goto fail (return false) */
|
SI(JOP_JUMP_IF_NOT, 2, 7), /* if not jump? goto fail (return false) */
|
||||||
SSI(JOP_ADD_IMMEDIATE, 5, 5, 1), /* i++ */
|
SSI(JOP_ADD_IMMEDIATE, 5, 5, 1), /* i++ */
|
||||||
@ -880,7 +861,7 @@ static void make_apply(JanetTable *env) {
|
|||||||
SI(JOP_LOAD_INTEGER, 4, 0), /* i = 0 */
|
SI(JOP_LOAD_INTEGER, 4, 0), /* i = 0 */
|
||||||
|
|
||||||
/* Main loop */
|
/* Main loop */
|
||||||
SSS(JOP_GET, 5, 1, 4), /* x = args[i] */
|
SSS(JOP_IN, 5, 1, 4), /* x = args[i] */
|
||||||
SSI(JOP_ADD_IMMEDIATE, 4, 4, 1), /* i++ */
|
SSI(JOP_ADD_IMMEDIATE, 4, 4, 1), /* i++ */
|
||||||
SSI(JOP_EQUALS, 3, 4, 2), /* jump? = (i == argn) */
|
SSI(JOP_EQUALS, 3, 4, 2), /* jump? = (i == argn) */
|
||||||
SI(JOP_JUMP_IF, 3, 3), /* if jump? go forward 3 */
|
SI(JOP_JUMP_IF, 3, 3), /* if jump? go forward 3 */
|
||||||
@ -920,6 +901,14 @@ static const uint32_t resume_asm[] = {
|
|||||||
JOP_RETURN
|
JOP_RETURN
|
||||||
};
|
};
|
||||||
static const uint32_t in_asm[] = {
|
static const uint32_t in_asm[] = {
|
||||||
|
JOP_IN | (1 << 24),
|
||||||
|
JOP_LOAD_NIL | (3 << 8),
|
||||||
|
JOP_EQUALS | (3 << 8) | (3 << 24),
|
||||||
|
JOP_JUMP_IF | (3 << 8) | (2 << 16),
|
||||||
|
JOP_RETURN,
|
||||||
|
JOP_RETURN | (2 << 8)
|
||||||
|
};
|
||||||
|
static const uint32_t get_asm[] = {
|
||||||
JOP_GET | (1 << 24),
|
JOP_GET | (1 << 24),
|
||||||
JOP_LOAD_NIL | (3 << 8),
|
JOP_LOAD_NIL | (3 << 8),
|
||||||
JOP_EQUALS | (3 << 8) | (3 << 24),
|
JOP_EQUALS | (3 << 8) | (3 << 24),
|
||||||
@ -1021,6 +1010,13 @@ JanetTable *janet_core_env(JanetTable *replacements) {
|
|||||||
"strings, symbols, and buffers are all associative and can be used. Arrays, tuples, strings, buffers, "
|
"strings, symbols, and buffers are all associative and can be used. Arrays, tuples, strings, buffers, "
|
||||||
"and symbols must use integer keys that are in bounds or an error is raised. Structs and tables can "
|
"and symbols must use integer keys that are in bounds or an error is raised. Structs and tables can "
|
||||||
"take any value as a key except nil and will return nil or dflt if not found."));
|
"take any value as a key except nil and will return nil or dflt if not found."));
|
||||||
|
janet_quick_asm(env, JANET_FUN_GET,
|
||||||
|
"get", 3, 2, 3, 4, get_asm, sizeof(in_asm),
|
||||||
|
JDOC("(get ds key &opt dflt)\n\n"
|
||||||
|
"Get the value mapped to key in data structure ds, and return dflt or nil if not found. "
|
||||||
|
"Similar to in, but will not throw an error if the key is invalid for the data structure "
|
||||||
|
"unless the data structure is an abstract type. In that case, the abstract type getter may throw "
|
||||||
|
"an error."));
|
||||||
janet_quick_asm(env, JANET_FUN_PUT,
|
janet_quick_asm(env, JANET_FUN_PUT,
|
||||||
"put", 3, 3, 3, 3, put_asm, sizeof(put_asm),
|
"put", 3, 3, 3, 3, put_asm, sizeof(put_asm),
|
||||||
JDOC("(put ds key value)\n\n"
|
JDOC("(put ds key value)\n\n"
|
||||||
|
@ -146,7 +146,7 @@ static int destructure(JanetCompiler *c,
|
|||||||
janetc_emit_ssu(c, JOP_GET_INDEX, nextright, right, (uint8_t) i, 1);
|
janetc_emit_ssu(c, JOP_GET_INDEX, nextright, right, (uint8_t) i, 1);
|
||||||
} else {
|
} else {
|
||||||
JanetSlot k = janetc_cslot(janet_wrap_integer(i));
|
JanetSlot k = janetc_cslot(janet_wrap_integer(i));
|
||||||
janetc_emit_sss(c, JOP_GET, nextright, right, k, 1);
|
janetc_emit_sss(c, JOP_IN, nextright, right, k, 1);
|
||||||
}
|
}
|
||||||
if (destructure(c, subval, nextright, leaf, attr))
|
if (destructure(c, subval, nextright, leaf, attr))
|
||||||
janetc_freeslot(c, nextright);
|
janetc_freeslot(c, nextright);
|
||||||
@ -162,7 +162,7 @@ static int destructure(JanetCompiler *c,
|
|||||||
if (janet_checktype(kvs[i].key, JANET_NIL)) continue;
|
if (janet_checktype(kvs[i].key, JANET_NIL)) continue;
|
||||||
JanetSlot nextright = janetc_farslot(c);
|
JanetSlot nextright = janetc_farslot(c);
|
||||||
JanetSlot k = janetc_value(janetc_fopts_default(c), kvs[i].key);
|
JanetSlot k = janetc_value(janetc_fopts_default(c), kvs[i].key);
|
||||||
janetc_emit_sss(c, JOP_GET, nextright, right, k, 1);
|
janetc_emit_sss(c, JOP_IN, nextright, right, k, 1);
|
||||||
if (destructure(c, kvs[i].value, nextright, leaf, attr))
|
if (destructure(c, kvs[i].value, nextright, leaf, attr))
|
||||||
janetc_freeslot(c, nextright);
|
janetc_freeslot(c, nextright);
|
||||||
}
|
}
|
||||||
|
@ -156,7 +156,7 @@ bad:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Gets a value and returns. Can panic. */
|
/* Gets a value and returns. Can panic. */
|
||||||
Janet janet_get(Janet ds, Janet key) {
|
Janet janet_in(Janet ds, Janet key) {
|
||||||
Janet value;
|
Janet value;
|
||||||
switch (janet_type(ds)) {
|
switch (janet_type(ds)) {
|
||||||
default:
|
default:
|
||||||
@ -207,7 +207,7 @@ Janet janet_get(Janet ds, Janet key) {
|
|||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
Janet janet_get_permissive(Janet ds, Janet key) {
|
Janet janet_get(Janet ds, Janet key) {
|
||||||
JanetType t = janet_type(ds);
|
JanetType t = janet_type(ds);
|
||||||
switch (t) {
|
switch (t) {
|
||||||
default:
|
default:
|
||||||
|
@ -204,7 +204,7 @@ static Janet call_nonfn(JanetFiber *fiber, Janet callee) {
|
|||||||
key = callee;
|
key = callee;
|
||||||
}
|
}
|
||||||
fiber->stacktop = fiber->stackstart;
|
fiber->stacktop = fiber->stackstart;
|
||||||
return janet_get(ds, key);
|
return janet_in(ds, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get a callable from a keyword method name and check ensure that it is valid. */
|
/* Get a callable from a keyword method name and check ensure that it is valid. */
|
||||||
@ -275,6 +275,7 @@ static JanetSignal run_vm(JanetFiber *fiber, Janet in, JanetFiberStatus status)
|
|||||||
&&label_JOP_RESUME,
|
&&label_JOP_RESUME,
|
||||||
&&label_JOP_SIGNAL,
|
&&label_JOP_SIGNAL,
|
||||||
&&label_JOP_PROPAGATE,
|
&&label_JOP_PROPAGATE,
|
||||||
|
&&label_JOP_IN,
|
||||||
&&label_JOP_GET,
|
&&label_JOP_GET,
|
||||||
&&label_JOP_PUT,
|
&&label_JOP_PUT,
|
||||||
&&label_JOP_GET_INDEX,
|
&&label_JOP_GET_INDEX,
|
||||||
@ -476,7 +477,6 @@ static JanetSignal run_vm(JanetFiber *fiber, Janet in, JanetFiberStatus status)
|
|||||||
&&label_unknown_op,
|
&&label_unknown_op,
|
||||||
&&label_unknown_op,
|
&&label_unknown_op,
|
||||||
&&label_unknown_op,
|
&&label_unknown_op,
|
||||||
&&label_unknown_op,
|
|
||||||
&&label_unknown_op
|
&&label_unknown_op
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
@ -912,6 +912,11 @@ static JanetSignal run_vm(JanetFiber *fiber, Janet in, JanetFiberStatus status)
|
|||||||
janet_putindex(stack[A], C, stack[B]);
|
janet_putindex(stack[A], C, stack[B]);
|
||||||
vm_checkgc_pcnext();
|
vm_checkgc_pcnext();
|
||||||
|
|
||||||
|
VM_OP(JOP_IN)
|
||||||
|
vm_commit();
|
||||||
|
stack[A] = janet_in(stack[B], stack[C]);
|
||||||
|
vm_pcnext();
|
||||||
|
|
||||||
VM_OP(JOP_GET)
|
VM_OP(JOP_GET)
|
||||||
vm_commit();
|
vm_commit();
|
||||||
stack[A] = janet_get(stack[B], stack[C]);
|
stack[A] = janet_get(stack[B], stack[C]);
|
||||||
|
@ -1055,6 +1055,7 @@ enum JanetOpCode {
|
|||||||
JOP_RESUME,
|
JOP_RESUME,
|
||||||
JOP_SIGNAL,
|
JOP_SIGNAL,
|
||||||
JOP_PROPAGATE,
|
JOP_PROPAGATE,
|
||||||
|
JOP_IN,
|
||||||
JOP_GET,
|
JOP_GET,
|
||||||
JOP_PUT,
|
JOP_PUT,
|
||||||
JOP_GET_INDEX,
|
JOP_GET_INDEX,
|
||||||
@ -1318,8 +1319,8 @@ JANET_API int janet_equals(Janet x, Janet y);
|
|||||||
JANET_API int32_t janet_hash(Janet x);
|
JANET_API int32_t janet_hash(Janet x);
|
||||||
JANET_API int janet_compare(Janet x, Janet y);
|
JANET_API int janet_compare(Janet x, Janet y);
|
||||||
JANET_API int janet_cstrcmp(const uint8_t *str, const char *other);
|
JANET_API int janet_cstrcmp(const uint8_t *str, const char *other);
|
||||||
|
JANET_API Janet janet_in(Janet ds, Janet key);
|
||||||
JANET_API Janet janet_get(Janet ds, Janet key);
|
JANET_API Janet janet_get(Janet ds, Janet key);
|
||||||
JANET_API Janet janet_get_permissive(Janet ds, Janet key);
|
|
||||||
JANET_API Janet janet_getindex(Janet ds, int32_t index);
|
JANET_API Janet janet_getindex(Janet ds, int32_t index);
|
||||||
JANET_API int32_t janet_length(Janet x);
|
JANET_API int32_t janet_length(Janet x);
|
||||||
JANET_API Janet janet_lengthv(Janet x);
|
JANET_API Janet janet_lengthv(Janet x);
|
||||||
|
Loading…
Reference in New Issue
Block a user