1
0
mirror of https://github.com/janet-lang/janet synced 2025-01-13 17:10:27 +00:00
Check for empty capture stack in replace rule.
This commit is contained in:
Calvin Rose 2020-03-06 10:01:04 -06:00
parent f9e9c70b6c
commit 714bd61d56
2 changed files with 14 additions and 5 deletions

View File

@ -369,19 +369,23 @@ tail:
s->mode = oldmode; s->mode = oldmode;
if (!result) return NULL; if (!result) return NULL;
Janet cap; Janet cap = janet_wrap_nil();
Janet constant = s->constants[rule[2]]; Janet constant = s->constants[rule[2]];
switch (janet_type(constant)) { switch (janet_type(constant)) {
default: default:
cap = constant; cap = constant;
break; break;
case JANET_STRUCT: case JANET_STRUCT:
if (s->captures->count) {
cap = janet_struct_get(janet_unwrap_struct(constant), cap = janet_struct_get(janet_unwrap_struct(constant),
s->captures->data[s->captures->count - 1]); s->captures->data[s->captures->count - 1]);
}
break; break;
case JANET_TABLE: case JANET_TABLE:
if (s->captures->count) {
cap = janet_table_get(janet_unwrap_table(constant), cap = janet_table_get(janet_unwrap_table(constant),
s->captures->data[s->captures->count - 1]); s->captures->data[s->captures->count - 1]);
}
break; break;
case JANET_CFUNCTION: case JANET_CFUNCTION:
cap = janet_unwrap_cfunction(constant)(s->captures->count - cs.cap, cap = janet_unwrap_cfunction(constant)(s->captures->count - cs.cap,

View File

@ -112,4 +112,9 @@
(assert (= false (and false false)) "and 1") (assert (= false (and false false)) "and 1")
(assert (= false (or false false)) "or 1") (assert (= false (or false false)) "or 1")
# #300 Regression test
# Just don't segfault
(assert (peg/match '{:main (replace "S" {"S" :spade})} "S7") "regression #300")
(end-suite) (end-suite)