-l option; minor refactoring

This commit is contained in:
ESL 2023-03-26 00:38:50 -04:00
parent 033991b0d7
commit 709304b17d
3 changed files with 563 additions and 461 deletions

27
i.c
View file

@ -171,6 +171,7 @@ static void _sck(obj *s) {
/* small object representation extras */ /* small object representation extras */
#define bool_obj(b) obj_from_bool(b) #define bool_obj(b) obj_from_bool(b)
#define char_obj(b) obj_from_char(b) #define char_obj(b) obj_from_char(b)
#define null_obj() mknull()
#define eof_obj() mkeof() #define eof_obj() mkeof()
#define fixnum_obj(x) obj_from_fixnum(x) #define fixnum_obj(x) obj_from_fixnum(x)
#define flonum_obj(x) hp_pushptr(dupflonum(x), FLONUM_NTAG) #define flonum_obj(x) hp_pushptr(dupflonum(x), FLONUM_NTAG)
@ -436,7 +437,7 @@ define_instrhelper(cxi_failactype) {
{ ac = _x; spush((obj)"list"); musttail return cxi_failactype(IARGS); } } while (0) { ac = _x; spush((obj)"list"); musttail return cxi_failactype(IARGS); } } while (0)
#define ckv(x) do { obj _x = (x); if (unlikely(!isvector(_x))) \ #define ckv(x) do { obj _x = (x); if (unlikely(!isvector(_x))) \
{ ac = _x; spush((obj)"vector"); musttail return cxi_failactype(IARGS); } } while (0) { ac = _x; spush((obj)"vector"); musttail return cxi_failactype(IARGS); } } while (0)
#define ckc(x) do { obj _x = (x); if (unlikely(!ischar(_x))) \ #define ckc(x) do { obj _x = (x); if (unlikely(!is_char_obj(_x))) \
{ ac = _x; spush((obj)"char"); musttail return cxi_failactype(IARGS); } } while (0) { ac = _x; spush((obj)"char"); musttail return cxi_failactype(IARGS); } } while (0)
#define cks(x) do { obj _x = (x); if (unlikely(!isstring(_x))) \ #define cks(x) do { obj _x = (x); if (unlikely(!isstring(_x))) \
{ ac = _x; spush((obj)"string"); musttail return cxi_failactype(IARGS); } } while (0) { ac = _x; spush((obj)"string"); musttail return cxi_failactype(IARGS); } } while (0)
@ -806,9 +807,9 @@ define_instruction(shrarg) {
if (unlikely(m < 0)) { if (unlikely(m < 0)) {
fail("argument count error on entry (not enough arguments)"); fail("argument count error on entry (not enough arguments)");
} else if (unlikely(m == 0)) { } else if (unlikely(m == 0)) {
spush(mknull()); spush(null_obj());
} else { } else {
obj l = mknull(); obj l = null_obj();
hp_reserve(pairbsz()*m); hp_reserve(pairbsz()*m);
while (m > 0) { while (m > 0) {
*--hp = l; *--hp = sref(n + m - 1); *--hp = l; *--hp = sref(n + m - 1);
@ -926,7 +927,7 @@ define_instruction(listp) {
define_instruction(list) { define_instruction(list) {
int i, n = fixnum_from_obj(*ip++); int i, n = fixnum_from_obj(*ip++);
hp_reserve(pairbsz()*n); hp_reserve(pairbsz()*n);
for (ac = mknull(), i = n-1; i >= 0; --i) { for (ac = null_obj(), i = n-1; i >= 0; --i) {
*--hp = ac; /* cdr */ *--hp = ac; /* cdr */
*--hp = sref(i); /* car */ *--hp = sref(i); /* car */
ac = hend_pair(); ac = hend_pair();
@ -939,7 +940,7 @@ define_instruction(lmk) {
int i, n; obj v; ckk(ac); int i, n; obj v; ckk(ac);
n = fixnum_from_obj(ac); n = fixnum_from_obj(ac);
hp_reserve(pairbsz()*n); v = sref(0); hp_reserve(pairbsz()*n); v = sref(0);
ac = mknull(); ac = null_obj();
for (i = 0; i < n; ++i) { for (i = 0; i < n; ++i) {
*--hp = ac; /* cdr */ *--hp = ac; /* cdr */
*--hp = v; /* car */ *--hp = v; /* car */
@ -1026,10 +1027,10 @@ define_instruction(lpair) {
} }
define_instruction(lrev) { define_instruction(lrev) {
obj l = ac, o = mknull(); int n = 0; obj l = ac, o = null_obj(); int n = 0;
while (ispair(ac)) { ac = cdr(ac); ++n; } while (ispair(ac)) { ac = cdr(ac); ++n; }
hp_reserve(pairbsz()*n); hp_reserve(pairbsz()*n);
for (ac = l; ac != mknull(); ac = cdr(ac)) { for (ac = l; ac != null_obj(); ac = cdr(ac)) {
*--hp = o; *--hp = car(ac); *--hp = o; *--hp = car(ac);
o = hend_pair(); o = hend_pair();
} }
@ -1038,14 +1039,14 @@ define_instruction(lrev) {
} }
define_instruction(lrevi) { define_instruction(lrevi) {
obj t, v = mknull(); obj t, v = null_obj();
while (ispair(ac)) t = cdr(ac), cdr(ac) = v, v = ac, ac = t; while (ispair(ac)) t = cdr(ac), cdr(ac) = v, v = ac, ac = t;
ac = v; ac = v;
gonexti(); gonexti();
} }
define_instruction(charp) { define_instruction(charp) {
ac = bool_obj(ischar(ac)); ac = bool_obj(is_char_obj(ac));
gonexti(); gonexti();
} }
@ -1178,7 +1179,7 @@ define_instruction(vcat) {
} }
define_instruction(vtol) { define_instruction(vtol) {
obj l = mknull(); int n; obj l = null_obj(); int n;
ckv(ac); n = vectorlen(ac); ckv(ac); n = vectorlen(ac);
hp_reserve(pairbsz()*n); hp_reserve(pairbsz()*n);
while (n > 0) { while (n > 0) {
@ -1200,7 +1201,7 @@ define_instruction(ltov) {
} }
define_instruction(stol) { define_instruction(stol) {
obj l = mknull(); int n; obj l = null_obj(); int n;
cks(ac); n = stringlen(ac); cks(ac); n = stringlen(ac);
hp_reserve(pairbsz()*n); hp_reserve(pairbsz()*n);
while (n > 0) { while (n > 0) {
@ -2885,10 +2886,10 @@ define_instruction(rdsc) {
define_instruction(litf) { ac = bool_obj(0); gonexti(); } define_instruction(litf) { ac = bool_obj(0); gonexti(); }
define_instruction(litt) { ac = bool_obj(1); gonexti(); } define_instruction(litt) { ac = bool_obj(1); gonexti(); }
define_instruction(litn) { ac = mknull(); gonexti(); } define_instruction(litn) { ac = null_obj(); gonexti(); }
define_instruction(pushlitf) { ac = bool_obj(0); spush(ac); gonexti(); } define_instruction(pushlitf) { ac = bool_obj(0); spush(ac); gonexti(); }
define_instruction(pushlitt) { ac = bool_obj(1); spush(ac); gonexti(); } define_instruction(pushlitt) { ac = bool_obj(1); spush(ac); gonexti(); }
define_instruction(pushlitn) { ac = mknull(); spush(ac); gonexti(); } define_instruction(pushlitn) { ac = null_obj(); spush(ac); gonexti(); }
define_instruction(lit0) { ac = fixnum_obj(0); gonexti(); } define_instruction(lit0) { ac = fixnum_obj(0); gonexti(); }
define_instruction(lit1) { ac = fixnum_obj(1); gonexti(); } define_instruction(lit1) { ac = fixnum_obj(1); gonexti(); }

989
k.c

File diff suppressed because it is too large Load diff

View file

@ -1555,6 +1555,12 @@
(repl-eval-top-form x) (repl-eval-top-form x)
(loop (repl-read iport))))) (loop (repl-read iport)))))
(define (repl-file fname)
(define iport (open-input-file fname))
(repl-from-port iport)
(close-input-port iport))
(define (run-repl) (define (run-repl)
(repl-from-port (current-input-port))) (repl-from-port (current-input-port)))
@ -1563,6 +1569,8 @@
(cond (cond
[(syntax-match? '("-c" *) args) [(syntax-match? '("-c" *) args)
(process-file (cadr args))] (process-file (cadr args))]
[(syntax-match? '("-l" *) args)
(repl-file (cadr args))]
[(syntax-match? '("-t") args) [(syntax-match? '("-t") args)
(run-tests)] (run-tests)]
[(syntax-match? '("-v") args) [(syntax-match? '("-v") args)