ref: 4d79d1ed7c483fc45687e94ffc5c6568d78e916c
parent: bdb751c9fa7754d1e2df51773e9dc9e119ed58b8
author: Sigrid Solveig Haflínudóttir <sigrid@ftrv.se>
date: Fri Feb 7 22:26:03 EST 2025
remove #f (nil to be used instead) References: https://todo.sr.ht/~ft/femtolisp/22
--- a/boot/flisp.boot
+++ b/boot/flisp.boot
@@ -1,1 +1,1 @@
-(*builtins* #(0 0 0 0 0 0 0 0 0 0 0 0 #fn("5000n10<:" #()) #fn("5000n10=:" #()) 0 0 0 0 #fn("5000n10B:" #()) 0 0 0 0 0 #fn("5000n10H:" #()) 0 0 0 #fn("8000z0700}2:" #(<)) 0 #fn("6000n201N:" #()) 0 #fn("6000n201P:" #()) #fn("6000n201Q:" #()) #fn("5000n10R:" #()) #fn("5000n10S:" #()) #fn("5000n10T:" #()) 0 #fn("5000n10V:" #()) #fn("5000n10W:" #()) #fn("5000n10X:" #()) #fn("5000n10Y:" #()) #fn("5000n10Z:" #()) #fn("5000n10[:" #()) #fn("5000n10\\:" #()) #fn("5000n10]:" #()) 0 #fn("6000n201_:" #()) 0 0 0 #fn("6000n201c:" #()) #fn("6000n201d:" #()) #fn("7000z00:" #()) #fn("8000z0700}2:" #(apply)) #fn("8000z0700}2:" #(+)) #fn("8000z0700}2:" #(-)) #fn("8000z0700}2:" #(*)) #fn("8000z0700}2:" #(/)) #fn("8000z0700}2:" #(div0)) #fn("8000z0700}2:" #(=)) #fn("6000n201m:" #()) 0 #fn("8000z0700}2:" #(vector)) #fn("8000z0700}2:" #(aset!)) 0 0 0 0 0 0 0 0 0 0 0 #fn("9000n3012082>1|:" #(#fn("6000n1A061:" #()))) 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 #fn("8000z0700}2:" #(aref)) 0 #fn("5000n10\x8e:" #()) 0) *properties* #table(*funvars* #table(*prompt* (#f) lz-unpack ((data :to destination) (data :size decompressed-bytes)) void? ((x)) >= ((a . rest)) rand-uint64 (nil) help ((term)) length= ((lst n)) = ((a . rest)) car ((lst)) <= ((a . rest)) rand-uint32 (nil) /= ((a . rest)) void (rest) lz-pack ((data (level 0))) rand (nil) nan? ((x)) rand-float (nil) cons? ((value)) vm-stats (nil) * ((number…)) rand-double (nil) cdr ((lst)) + ((number…)) > ((a . rest))) *doc* #table(>= "Return #t if the arguments are in non-increasing order (previous\none is greater than or equal to the next one)." void? "Return #t if x is #<void> and #f otherwise." length= "Bounded length test.\nUse this instead of (= (length lst) n), since it avoids unnecessary\nwork and always terminates." car "Returns the first element of a list or nil if not available." *builtins* "VM instructions as closures." <= "Return #t if the arguments are in non-decreasing order (previous\none is less than or equal to the next one)." void "Return the constant #<void> while ignoring any arguments.\n#<void> is mainly used when a function has side effects but does not\nproduce any meaningful value to return, so even though #t or nil could\nbe returned instead, in case of #<void> alone, REPL will not print\nit." rand "Return a random non-negative fixnum on its maximum range." nan? "Return #t if the argument is NaN, regardless of the sign." Instructions "VM instructions mapped to their encoded byte representation." rand-double "Return a random double on [0.0, 1.0] interval." > "Return #t if the arguments are in strictly decreasing order (previous\none is greater than the next one)." cdr "Returns the tail of a list or nil if not available." + "Return sum of the numbers or 0 with no arguments." lz-unpack "Return decompressed data previously compressed using lz-pack.\nEither destination for the decompressed data or the expected size of\nthe decompressed data must be specified. In the latter case a new\narray is allocated." rand-uint64 "Return a random integer on [0, 2⁶⁴-1] interval." help "Display documentation for the specified term, if available." = "Return #t if the arguments are equal." rand-uint32 "Return a random integer on [0, 2³²-1] interval." /= "Return #t if not all arguments are equal. Shorthand for (not (= …))." lz-pack "Return data compressed using Lempel-Ziv.\nThe data must be an array, returned value will have the same type.\nThe optional level is between 0 and 10. With level 0 a simple LZSS\nusing hashing will be performed. Levels between 1 and 9 offer a\ntrade-off between time/space and ratio. Level 10 is optimal but very\nslow." rand-float "Return a random float on [0.0, 1.0] interval." arg-counts "VM instructions mapped to their expected arguments count." *prompt* "Function called by REPL to signal the user input is required.\nDefault function prints \"#;> \"." cons? "Returns #t if the value is a cons cell." vm-stats "Print various VM-related information, such as the number of GC calls\nso far, heap and stack size, etc." * "Ret
\ No newline at end of file
+(*builtins* #(nil nil nil nil nil nil nil nil nil nil nil nil #fn("5000n10<:" #()) #fn("5000n10=:" #()) nil nil nil nil #fn("5000n10B:" #()) nil nil nil nil nil #fn("5000n10H:" #()) nil nil nil #fn("8000z0700}2:" #(<)) nil #fn("6000n201N:" #()) nil #fn("6000n201P:" #()) #fn("6000n201Q:" #()) #fn("5000n10R:" #()) #fn("5000n10S:" #()) #fn("5000n10T:" #()) nil #fn("5000n10V:" #()) nil #fn("5000n10X:" #()) #fn("5000n10Y:" #()) #fn("5000n10Z:" #()) #fn("5000n10[:" #()) #fn("5000n10\\:" #()) #fn("5000n10]:" #()) nil #fn("6000n201_:" #()) nil nil nil #fn("6000n201c:" #()) #fn("6000n201d:" #()) #fn("7000z00:" #()) #fn("8000z0700}2:" #(apply)) #fn("8000z0700}2:" #(+)) #fn("8000z0700}2:" #(-)) #fn("8000z0700}2:" #(*)) #fn("8000z0700}2:" #(/)) #fn("8000z0700}2:" #(div0)) #fn("8000z0700}2:" #(=)) #fn("6000n201m:" #()) nil #fn("8000z0700}2:" #(vector)) #fn("8000z0700}2:" #(aset!)) nil nil nil nil nil nil nil nil nil nil nil #fn("9000n3012082>1|:" #(#fn("6000n1A061:" #()))) nil nil nil nil nil nil nil nil #fn("8000z0700}2:" #(aref)) nil nil nil) *properties* #table(*funvars* #table(*prompt* (nil) lz-unpack (#t #t) void? ((x)) >= ((a . rest)) rand-uint64 (#t) help ((term)) length= ((lst n)) = (#t) car (#t) <= ((a . rest)) rand-uint32 (#t) /= ((a . rest)) void (rest) lz-pack (#t) rand (#t) nan? (#t) rand-float (#t) cons? (#t) vm-stats (#t) * (#t) rand-double (#t) cdr (#t) + (#t) > ((a . rest))) *doc* #table(>= "Return #t if the arguments are in non-increasing order (previous\none is greater than or equal to the next one)." void? "Return #t if x is #<void> and nil otherwise." length= "Bounded length test.\nUse this instead of (= (length lst) n), since it avoids unnecessary\nwork and always terminates." car "Returns the first element of a list or nil if not available." *builtins* "VM instructions as closures." <= "Return #t if the arguments are in non-decreasing order (previous\none is less than or equal to the next one)." void "Return the constant #<void> while ignoring any arguments.\n#<void> is mainly used when a function has side effects but does not\nproduce any meaningful value to return, so even though #t or nil could\nbe returned instead, in case of #<void> alone, REPL will not print\nit." rand "Return a random non-negative fixnum on its maximum range." nan? "Return #t if the argument is NaN, regardless of the sign." Instructions "VM instructions mapped to their encoded byte representation." rand-double "Return a random double on [0.0, 1.0] interval." > "Return #t if the arguments are in strictly decreasing order (previous\none is greater than the next one)." cdr "Returns the tail of a list or nil if not available." + "Return sum of the numbers or 0 with no arguments." lz-unpack "Return decompressed data previously compressed using lz-pack.\nEither destination for the decompressed data or the expected size of\nthe decompressed data must be specified. In the latter case a new\narray is allocated." rand-uint64 "Return a random integer on [0, 2⁶⁴-1] interval." help "Display documentation for the specified term, if available." = "Return #t if the arguments are equal." rand-uint32 "Return a random integer on [0, 2³²-1] interval." /= "Return #t if not all arguments are equal. Shorthand for (not (= …))." lz-pack "Return data compressed using Lempel-Ziv.\nThe data must be an array, returned value will have the same type.\nThe optional level is between 0 and 10. With level 0 a simple LZSS\nusing hashing will be performed. Levels between 1 and 9 offer a\ntrade-off between time/space and ratio. Level 10 is optimal but very\nslow." rand-float "Return a random float on [0.0, 1.0] interval." arg-counts "VM instructions mapped to their expected arguments count." *prompt* "Function called by REPL to signal the user input is required.\nDefault function prints \"#;> \"." cons? "Returns #t if the value is a cons cell." vm-stats "Print various VM-related information, such as the number of GC calls\nso far, heap and stack size, etc." * "Return product of the numbers or 1 with no arguments.
\ No newline at end of file
binary files a/boot/flisp.boot.builtin b/boot/flisp.boot.builtin differ
--- a/src/builtins.c
+++ b/src/builtins.c
@@ -65,7 +65,7 @@
return bind;
v = cdr_(v);
}
- return FL_f;
+ return FL_nil;
}
fl_purefn
@@ -79,7 +79,7 @@
if((c = ptr(v))->car == args[0])
return v;
}
- return FL_f;
+ return FL_nil;
}
BUILTIN("length", length)
@@ -158,7 +158,7 @@
BUILTIN("keyword?", keywordp)
{
argcount(nargs, 1);
- return (issymbol(args[0]) && iskeyword((symbol_t*)ptr(args[0]))) ? FL_t : FL_f;
+ return (issymbol(args[0]) && iskeyword((symbol_t*)ptr(args[0]))) ? FL_t : FL_nil;
}
fl_purefn
@@ -210,11 +210,11 @@
{
argcount(nargs, 1);
if(issymbol(args[0]))
- return isconstant((symbol_t*)ptr(args[0])) ? FL_t : FL_f;
+ return isconstant((symbol_t*)ptr(args[0])) ? FL_t : FL_nil;
if(iscons(args[0])){
if(car_(args[0]) == FL_quote)
return FL_t;
- return FL_f;
+ return FL_nil;
}
return FL_t;
}
@@ -246,7 +246,7 @@
return FL_t;
}
}
- return FL_f;
+ return FL_nil;
}
fl_purefn
@@ -256,7 +256,7 @@
value_t v = args[0];
return (isfixnum(v) || ismpint(v) ||
(iscprim(v) && cp_numtype(ptr(v)) < T_FLOAT)) ?
- FL_t : FL_f;
+ FL_t : FL_nil;
}
fl_purefn
@@ -263,7 +263,7 @@
BUILTIN("bignum?", bignump)
{
argcount(nargs, 1);
- return ismpint(args[0]) ? FL_t : FL_f;
+ return ismpint(args[0]) ? FL_t : FL_nil;
}
BUILTIN("fixnum", fixnum)
@@ -402,7 +402,7 @@
{
argcount(nargs, 1);
const char *path = tostring(args[0]);
- return access(path, F_OK) == 0 ? FL_t : FL_f;
+ return access(path, F_OK) == 0 ? FL_t : FL_nil;
}
BUILTIN("delete-file", delete_file)
@@ -420,7 +420,7 @@
char *name = tostring(args[0]);
char *val = getenv(name);
if(val == nil)
- return FL_f;
+ return FL_nil;
return cvalue_static_cstring(val);
}
@@ -429,7 +429,7 @@
argcount(nargs, 2);
char *name = tostring(args[0]);
int result;
- if(args[1] == FL_f)
+ if(args[1] == FL_nil)
result = unsetenv(name);
else{
char *val = tostring(args[1]);
--- a/src/compiler.lsp
+++ b/src/compiler.lsp
@@ -24,7 +24,7 @@
(def (load? i)
(member i '(load0 load1 loadt loadf loadnil loadvoid))) ; FIXME no load immediate here yet
(let ((bc (aref e 0)))
- (if (null? args)
+ (if (not args)
(if (and (eq? inst 'car)
(eq? (car bc) 'cdr))
(set-car! bc 'cadr)
@@ -61,19 +61,12 @@
(set! args ()))))
(let ((lasti (car bc)))
- (cond ((and (eq? inst 'brf)
- (cond ((and (eq? lasti 'not)
- (eq? (cadr bc) 'null?))
- (aset! e 0 (cons (car args) (cons 'brn (cddr bc)))))
- ((eq? lasti 'not)
- (aset! e 0 (cons (car args) (cons 'brt (cdr bc)))))
+ (cond ((and (eq? inst 'brn)
+ (cond ((eq? lasti 'not)
+ (aset! e 0 (cons (car args) (cons 'brnn (cdr bc)))))
((eq? lasti 'eq?)
(aset! e 0 (cons (car args) (cons 'brne (cdr bc)))))
- ((eq? lasti 'null?)
- (aset! e 0 (cons (car args) (cons 'brnn (cdr bc)))))
- (else #f))))
- ((and (eq? inst 'brt) (eq? lasti 'null?))
- (aset! e 0 (cons (car args) (cons 'brn (cdr bc)))))
+ (else nil))))
(else
(aset! e 0 (nreconc (cons inst args) bc)))))))
e))
@@ -96,8 +89,8 @@
(label-to-loc (table))
(fixup-to-label (table))
(bcode (buffer))
- (vi #f)
- (nxt #f))
+ (vi nil)
+ (nxt nil))
(io-write bcode #int32(0))
(while (< i n)
(begin
@@ -112,8 +105,6 @@
(if long?
(case vi
(jmp 'jmp.l)
- (brt 'brt.l)
- (brf 'brf.l)
(brne 'brne.l)
(brnn 'brnn.l)
(brn 'brn.l)
@@ -120,8 +111,8 @@
(else vi))
vi))))
(set! i (+ i 1))
- (set! nxt (if (< i n) (aref v i) #f))
- (cond ((memq vi '(jmp brf brt brne brnn brn))
+ (set! nxt (and (< i n) (aref v i)))
+ (cond ((memq vi '(jmp brne brnn brn))
(put! fixup-to-label (sizeof bcode) nxt)
(io-write bcode ((if long? int32 int16) 0))
(set! i (+ i 1)))
@@ -148,7 +139,7 @@
; other number arguments are always uint8
(io-write bcode (uint8 nxt))
(set! i (+ i 1)))))
- (else #f))))))
+ (else nil))))))
(for-each
(λ (addr labl)
@@ -182,7 +173,7 @@
(aset! g 3 (nconc ce (list sym))))))))
(def (index-of item lst start)
- (cond ((null? lst) #f)
+ (cond ((not lst) nil)
((eq? item (car lst)) start)
(else (index-of item (cdr lst) (+ start 1)))))
@@ -192,7 +183,7 @@
(in-env? s (cdr env)))))
(def (lookup-sym s env lev)
- (if (null? env)
+ (if (not env)
'global
(let* ((curr (car env))
(vi (assq s curr)))
@@ -227,9 +218,9 @@
(def (compile-aset! g env args)
(let ((nref (- (length args) 2)))
(cond ((= nref 1)
- (compile-app g env #f (cons 'aset! args)))
+ (compile-app g env nil (cons 'aset! args)))
((> nref 1)
- (compile-app g env #f (cons 'aref (list-head args nref)))
+ (compile-app g env nil (cons 'aref (list-head args nref)))
(let ((nargs (compile-arglist g env (list-tail args nref))))
(bcode:stack g (- nargs))
(emit g 'aset!)))
@@ -238,7 +229,7 @@
(def (compile-set! g env s rhs)
(let ((loc (lookup-sym s env 0)))
(if (eq? loc 'global)
- (begin (compile-in g env #f rhs)
+ (begin (compile-in g env nil rhs)
(emit g 'setg s))
(let ((arg? (= (car loc) 0)))
(let ((h? (vinfo:heap? (cdr loc)))
@@ -248,11 +239,11 @@
(if h?
(begin (emit g (if arg? 'loada 'loadc) idx)
(bcode:stack g 1)
- (compile-in g env #f rhs)
+ (compile-in g env nil rhs)
(bcode:stack g -1)
(emit g 'set-car!))
- (begin (compile-in g env #f rhs)
+ (begin (compile-in g env nil rhs)
(if (not arg?) (error (string "internal error: misallocated var " s)))
(emit g 'seta idx))))))))
@@ -273,14 +264,14 @@
(then (caddr x))
(else (if (cons? (cdddr x))
(cadddr x)
- #f)))
+ nil)))
(cond ((eq? test #t)
(compile-in g env tail? then))
- ((eq? test #f)
+ ((eq? test nil)
(compile-in g env tail? else))
(else
- (compile-in g env #f test elsel)
- (emit g 'brf elsel)
+ (compile-in g env nil test elsel)
+ (emit g 'brn elsel)
(mark-label g thenl)
(compile-in g env tail? then)
(if tail?
@@ -295,15 +286,15 @@
((atom? (cdr forms))
(compile-in g env tail? (car forms)))
(else
- (compile-in g env #f (car forms))
+ (compile-in g env nil (car forms))
(emit g 'pop)
(compile-begin g env tail? (cdr forms)))))
(def (compile-prog1 g env x)
- (compile-in g env #f (cadr x))
+ (compile-in g env nil (cadr x))
(if (cons? (cddr x))
(begin (bcode:stack g 1)
- (compile-begin g env #f (cddr x))
+ (compile-begin g env nil (cddr x))
(emit g 'pop)
(bcode:stack g -1))))
@@ -310,14 +301,14 @@
(def (compile-while g env cond body)
(let ((top (make-label g))
(end (make-label g)))
- (compile-in g env #f (void))
+ (compile-in g env nil (void))
(bcode:stack g 1)
(mark-label g top)
- (compile-in g env #f cond)
- (emit g 'brf end)
+ (compile-in g env nil cond)
+ (emit g 'brn end)
(emit g 'pop)
(bcode:stack g -1)
- (compile-in g env #f body)
+ (compile-in g env nil body)
(emit g 'jmp top)
(mark-label g end)))
@@ -335,7 +326,7 @@
((atom? (cdr forms)) (compile-in g env tail? (car forms) outl))
(else
(let ((end (or outl (make-label g))))
- (compile-in g env #f (car forms) outl)
+ (compile-in g env nil (car forms) outl)
(bcode:stack g 1)
(unless outl (emit g 'dup))
(emit g branch end)
@@ -345,15 +336,15 @@
(unless outl (mark-label g end))))))
(def (compile-and g env tail? forms outl)
- (compile-short-circuit g env tail? forms #t 'brf outl))
+ (compile-short-circuit g env tail? forms #t 'brn outl))
(def (compile-or g env tail? forms)
- (compile-short-circuit g env tail? forms #f 'brt #f))
+ (compile-short-circuit g env tail? forms nil 'brnn nil))
;; calls
(def (compile-arglist g env lst)
(for-each (λ (a)
- (compile-in g env #f a)
+ (compile-in g env nil a)
(bcode:stack g 1))
lst)
(length lst))
@@ -369,17 +360,17 @@
fixnum? 'fixnum? equal? 'equal?
eq? 'eq? symbol? 'symbol?
div0 'div0 builtin? 'builtin?
- aset! 'aset! - '- boolean? 'boolean? not 'not
+ aset! 'aset! - '- not 'not
apply 'apply atom? 'atom? nan? 'nan?
set-cdr! 'set-cdr! / '/
function? 'function? vector 'vector
list 'list bound? 'bound?
- < '< * '* cdr 'cdr cadr 'cadr null? 'null?
+ < '< * '* cdr 'cdr cadr 'cadr
+ '+ eqv? 'eqv? compare 'compare aref 'aref
set-car! 'set-car! car 'car for 'for
cons? 'cons? = '= vector? 'vector?)))
(λ (b)
- (get b2i b #f))))
+ (get b2i b nil))))
(def (compile-builtin-call g env tail? x head b nargs)
(def (num-compare)
@@ -386,7 +377,7 @@
(if (= nargs 0)
(argc-error b 1)
(emit g b nargs)))
- (let ((count (get arg-counts b #f)))
+ (let ((count (get arg-counts b nil)))
(if (and count
(not (length= (cdr x) count)))
(argc-error b count))
@@ -458,7 +449,7 @@
head)))
(if (length> (cdr x) 255)
;; more than 255 arguments, need long versions of instructions
- (begin (compile-in g env #f head)
+ (begin (compile-in g env nil head)
(bcode:stack g 1)
(let ((nargs (compile-arglist g env (cdr x))))
(bcode:stack g (- nargs))
@@ -469,7 +460,7 @@
(not (in-env? head env))
(equal? (top-level-value 'cadr) cadr)
(length= x 2))
- (begin (compile-in g env #f (cadr x))
+ (begin (compile-in g env nil (cadr x))
(emit g 'cadr))
(if (and (cons? head)
(is-lambda? (car head))
@@ -477,7 +468,7 @@
(compile-let g env tail? x)
(begin
(unless b
- (compile-in g env #f head)
+ (compile-in g env nil head)
(bcode:stack g 1))
(let ((nargs (compile-arglist g env (cdr x))))
(bcode:stack g (- nargs))
@@ -490,13 +481,12 @@
(def (fits-i8 x) (and (fixnum? x) (>= 127 x -128)))
-(def (compile-in g env tail? x (outl #f))
+(def (compile-in g env tail? x (outl nil))
(cond ((symbol? x) (compile-sym g env x #t))
((atom? x)
(cond ((eq? x 0) (emit g 'load0))
((eq? x 1) (emit g 'load1))
((eq? x #t) (emit g 'loadt))
- ((eq? x #f) (emit g 'loadf))
((eq? x nil) (emit g 'loadnil))
((void? x) (emit g 'loadvoid))
((fits-i8 x) (emit g 'loadi8 x))
@@ -515,10 +505,10 @@
(prog1 (compile-prog1 g env x))
(λ (receive (the-f cenv) (compile-f- env x)
(begin (emit g 'loadv the-f)
- (if (not (null? cenv))
+ (if cenv
(begin
(for-each (λ (var)
- (compile-sym g env var #f))
+ (compile-sym g env var nil))
cenv)
(emit g 'closure (length cenv)))))))
(and (compile-and g env tail? (cdr x) outl))
@@ -537,10 +527,10 @@
(is-lambda? (car (car value)))
(lambda:vars (car value)))))
(compile-set! g env name (car value))))
- (trycatch (compile-in g env #f `(λ () ,(cadr x)))
+ (trycatch (compile-in g env nil `(λ () ,(cadr x)))
(unless (1arg-lambda? (caddr x))
(error "trycatch: second form must be a 1-argument lambda"))
- (compile-in g env #f (caddr x))
+ (compile-in g env nil (caddr x))
(emit g 'trycatch))
(else (compile-app g env tail? x))))))
@@ -555,7 +545,7 @@
(def (lambda-vars l)
(def (check-formals l o opt kw)
- (cond ((or (null? l) (symbol? l)) #t)
+ (cond ((or (not l) (symbol? l)) #t)
((and (cons? l) (symbol? (car l)))
(if (or opt kw)
(error "compile error: invalid argument list "
@@ -580,7 +570,7 @@
(error "compile error: invalid argument list " o)
(error "compile error: invalid formal argument " l
" in list " o)))))
- (check-formals l l #f #f)
+ (check-formals l l nil nil)
(map (λ (s) (if (cons? s) (keyword->symbol (car s)) s))
(to-proper l)))
@@ -589,8 +579,8 @@
(if (cons? opta)
(let ((nxt (make-label g)))
(emit g 'brbound i)
- (emit g 'brt nxt)
- (compile-in g (extend-env env (list-head vars i) '()) #f (cadar opta))
+ (emit g 'brnn nxt)
+ (compile-in g (extend-env env (list-head vars i) '()) nil (cadar opta))
(emit g 'seta i)
(emit g 'pop)
(mark-label g nxt)
@@ -638,10 +628,10 @@
(void)))
(V (get-defined-vars B))
(new-B (lower-define B)))
- (if (null? V)
- new-B
+ (if V
(cons `(λ ,V ,new-B)
- (map void V)))))
+ (map void V))
+ new-B)))
(cond ((or (atom? e) (quoted? e))
e)
((eq? (car e) 'def)
@@ -657,38 +647,38 @@
(def (lambda:vars e) (lambda-vars (cadr e)))
(def (diff s1 s2)
- (cond ((null? s1) '())
+ (cond ((not s1) nil)
((memq (car s1) s2) (diff (cdr s1) s2))
(else (cons (car s1) (diff (cdr s1) s2)))))
;; bindings that are both captured and set!'d
(def (complex-bindings- e vars head nested capt setd)
- (cond ((null? vars) #f)
+ (cond ((not vars) nil)
((symbol? e)
(if (and nested (memq e vars))
(put! capt e #t)))
- ((or (atom? e) (quoted? e)) #f)
+ ((or (atom? e) (quoted? e)) nil)
((eq? (car e) 'set!)
(if (memq (cadr e) vars)
(begin (put! setd (cadr e) #t)
(if nested (put! capt (cadr e) #t))))
- (complex-bindings- (caddr e) vars #f nested capt setd))
+ (complex-bindings- (caddr e) vars nil nested capt setd))
((is-lambda? (car e))
(complex-bindings- (lambda:body e)
(diff vars (lambda:vars e))
- #f
+ nil
(or (not head) nested)
capt setd))
(else
(cons (complex-bindings- (car e) vars (inlineable? e) nested capt setd)
(map (λ (x)
- (complex-bindings- x vars #f nested capt setd))
+ (complex-bindings- x vars nil nested capt setd))
(cdr e))))))
(def (complex-bindings e vars)
(let ((capt (table))
(setd (table)))
- (complex-bindings- e vars #f #f capt setd)
+ (complex-bindings- e vars nil nil capt setd)
(filter (λ (x) (has? capt x))
(table-keys setd))))
@@ -721,31 +711,28 @@
(vars (lambda:vars f))
(opta (filter cons? (cadr f)))
(last (lastcdr f)))
- (let* ((name (if (null? last) 'λ last))
+ (let* ((name (if (not last) 'λ last))
(nargs (if (atom? args) 0 (length args)))
(nreq (- nargs (length opta)))
(kwa (filter keyword-arg? opta)))
;; emit argument checking prologue
- (if (not (null? opta))
- (begin
- (if (null? kwa)
- (emit g 'optargs nreq
- (if (null? atail) nargs (- nargs)))
- (begin
- (bcode:indexfor g (make-perfect-hash-table
- (map cons
- (map car kwa)
- (iota (length kwa)))))
- (emit g 'keyargs nreq (length kwa)
- (if (null? atail) nargs (- nargs)))))
- (emit-optional-arg-inits g env opta vars nreq)))
+ (when opta
+ (if (not kwa)
+ (emit g 'optargs nreq
+ (if atail (- nargs) nargs))
+ (begin
+ (bcode:indexfor g (make-perfect-hash-table
+ (map cons
+ (map car kwa)
+ (iota (length kwa)))))
+ (emit g 'keyargs nreq (length kwa)
+ (if atail (- nargs) nargs))))
+ (emit-optional-arg-inits g env opta vars nreq))
- (cond ((> nargs 255) (emit g (if (null? atail)
- 'largc 'lvargc)
- nargs))
- ((not (null? atail)) (emit g 'vargc nargs))
- ((null? opta) (emit g 'argc nargs)))
+ (cond ((> nargs 255) (emit g (if atail 'lvargc 'largc) nargs))
+ (atail (emit g 'vargc nargs))
+ ((not opta) (emit g 'argc nargs)))
(let ((newenv (extend-env env vars (complex-bindings (lambda:body f) vars))))
(box-vars g (car newenv))
@@ -773,11 +760,11 @@
(def (hex5 n)
(string-lpad (number->string n 16) 5 #\0))
-(def (disassemble f (ip #f) . lev?)
- (if (null? lev?)
- (begin (disassemble f ip 0)
- (newline)
- (return (void))))
+(def (disassemble f (ip nil) . lev?)
+ (when (not lev?)
+ (disassemble f ip 0)
+ (newline)
+ (return (void)))
(let ((lev (car lev?))
(code (function:code f))
(vals (function:vals f)))
@@ -784,7 +771,7 @@
(def (print-val v)
(if (and (function? v) (not (builtin? v)))
(begin (newline)
- (disassemble v #f (+ lev 1)))
+ (disassemble v nil (+ lev 1)))
(print v)))
(def (print-inst inst s sz) (princ (if (and ip (= lev 0) (>= ip (1- s)) (< ip (+ s sz)))
" >"
@@ -798,7 +785,7 @@
(let ((inst (table-foldl (λ (k v z)
(or z (and (eq? v (aref code i))
k)))
- #f Instructions)))
+ nil Instructions)))
(if (> i 4) (newline))
(dotimes (xx lev) (princ "\t"))
(set! i (+ i 1))
@@ -841,12 +828,12 @@
(princ (number->string (ref-int32-LE code i)) " ")
(set! i (+ i 4)))
- ((jmp brf brt brne brnn brn)
+ ((jmp brne brnn brn)
(print-inst inst i 2)
(princ "@" (hex5 (+ i -4 (ref-int16-LE code i))))
(set! i (+ i 2)))
- ((jmp.l brf.l brt.l brne.l brnn.l brn.l)
+ ((jmp.l brne.l brnn.l brn.l)
(print-inst inst i 4)
(princ "@" (hex5 (+ i -4 (ref-int32-LE code i))))
(set! i (+ i 4)))
@@ -867,7 +854,7 @@
(def (make-perfect-hash-table alist)
(def ($hash-keyword key n) (mod0 (abs (hash key)) n))
(let loop1 ((n (length alist)))
- (let ((v (vector-alloc (* 2 n) #f)))
+ (let ((v (vector-alloc (* 2 n) nil)))
(let loop2 ((lst alist))
(if (cons? lst)
(let ((key (caar lst)))
--- a/src/cvalues.c
+++ b/src/cvalues.c
@@ -570,7 +570,7 @@
case TAG_SYM: return FL_symbolsym;
case TAG_VECTOR: return FL_vectorsym;
case TAG_FUNCTION:
- if(args[0] == FL_t || args[0] == FL_f)
+ if(args[0] == FL_t)
return FL_booleansym;
if(args[0] == FL_nil)
return FL_nullsym;
@@ -651,7 +651,7 @@
argcount(nargs, 1);
return (iscprim(args[0]) ||
(iscvalue(args[0]) && cv_isPOD(ptr(args[0])))) ?
- FL_t : FL_f;
+ FL_t : FL_nil;
}
static void
--- a/src/docs_extra.lsp
+++ b/src/docs_extra.lsp
@@ -1,7 +1,7 @@
-(defmacro (doc-for term (doc #f))
+(defmacro (doc-for term (doc nil))
(let* ((sym (or (and (cons? term) (car term)) term))
(val (top-level-value sym))
- (funvars (and (cons? term) (cdr term))))
+ (funvars (cons? term)))
(if (not funvars)
(when (function? val)
(error "docs: " sym ": no funvars specified"))
--- a/src/flisp.c
+++ b/src/flisp.c
@@ -22,7 +22,7 @@
value_t FL_commadot, FL_trycatch, FL_backquote;
value_t FL_conssym, FL_symbolsym, FL_fixnumsym, FL_vectorsym, FL_builtinsym, FL_vu8sym;
value_t FL_definesym, FL_defmacrosym, FL_forsym, FL_setqsym;
-value_t FL_tsym, FL_Tsym, FL_fsym, FL_Fsym, FL_booleansym, FL_nullsym, FL_evalsym, FL_fnsym;
+value_t FL_tsym, FL_Tsym, FL_booleansym, FL_nullsym, FL_evalsym, FL_fnsym;
value_t FL_nulsym, FL_alarmsym, FL_backspacesym, FL_tabsym, FL_linefeedsym, FL_newlinesym;
value_t FL_vtabsym, FL_pagesym, FL_returnsym, FL_escsym, FL_spacesym, FL_deletesym;
value_t FL_IOError, FL_ParseError, FL_TypeError, FL_ArgError, FL_MemoryError;
@@ -249,7 +249,7 @@
BUILTIN("gensym?", gensymp)
{
argcount(nargs, 1);
- return isgensym(args[0]) ? FL_t : FL_f;
+ return isgensym(args[0]) ? FL_t : FL_nil;
}
char *
@@ -1105,7 +1105,7 @@
if(iscbuiltin(v)){
v = (value_t)ptrhash_get(&FL(reverse_dlsym_lookup_table), ptr(v));
if(v == (value_t)HT_NOTFOUND)
- return FL_f;
+ return FL_nil;
return v;
}
type_error("function", v);
@@ -1370,15 +1370,13 @@
FL_newlinesym = csymbol("newline");
FL_tsym = csymbol("t");
FL_Tsym = csymbol("T");
- FL_fsym = csymbol("f");
- FL_Fsym = csymbol("F");
FL_builtins_table_sym = csymbol("*builtins*");
set(FL_printprettysym = csymbol("*print-pretty*"), FL_t);
set(FL_printreadablysym = csymbol("*print-readably*"), FL_t);
set(FL_printwidthsym = csymbol("*print-width*"), fixnum(FL(scr_width)));
- set(FL_printlengthsym = csymbol("*print-length*"), FL_f);
- set(FL_printlevelsym = csymbol("*print-level*"), FL_f);
+ set(FL_printlengthsym = csymbol("*print-length*"), FL_nil);
+ set(FL_printlevelsym = csymbol("*print-level*"), FL_nil);
FL(lasterror) = FL_nil;
for(i = 0; i < nelem(builtins); i++){
--- a/src/flisp.h
+++ b/src/flisp.h
@@ -347,7 +347,6 @@
enum {
FL_nil = builtin(OP_LOADNIL),
FL_t = builtin(OP_LOADT),
- FL_f = builtin(OP_LOADF),
FL_void = builtin(OP_LOADVOID),
FL_eof = builtin(OP_EOF_OBJECT),
};
@@ -435,7 +434,7 @@
extern value_t FL_commadot, FL_trycatch, FL_backquote;
extern value_t FL_conssym, FL_symbolsym, FL_fixnumsym, FL_vectorsym, FL_builtinsym, FL_vu8sym;
extern value_t FL_definesym, FL_defmacrosym, FL_forsym, FL_setqsym;
-extern value_t FL_tsym, FL_Tsym, FL_fsym, FL_Fsym, FL_booleansym, FL_nullsym, FL_evalsym, FL_fnsym;
+extern value_t FL_tsym, FL_Tsym, FL_booleansym, FL_nullsym, FL_evalsym, FL_fnsym;
extern value_t FL_nulsym, FL_alarmsym, FL_backspacesym, FL_tabsym, FL_linefeedsym, FL_newlinesym;
extern value_t FL_vtabsym, FL_pagesym, FL_returnsym, FL_escsym, FL_spacesym, FL_deletesym;
extern value_t FL_IOError, FL_ParseError, FL_TypeError, FL_ArgError, FL_MemoryError;
--- a/src/iostream.c
+++ b/src/iostream.c
@@ -51,7 +51,7 @@
BUILTIN("iostream?", iostreamp)
{
argcount(nargs, 1);
- return isiostream(args[0]) ? FL_t : FL_f;
+ return isiostream(args[0]) ? FL_t : FL_nil;
}
fl_purefn
@@ -58,7 +58,7 @@
BUILTIN("eof-object?", eof_objectp)
{
argcount(nargs, 1);
- return args[0] == FL_eof ? FL_t : FL_f;
+ return args[0] == FL_eof ? FL_t : FL_nil;
}
fl_purefn
@@ -143,7 +143,7 @@
ios_t *s = toiostream(args[0]);
int r = ios_wait(s, nargs > 1 ? todouble(args[1]) : -1);
if(r >= 0)
- return r ? FL_t : FL_f;
+ return r ? FL_t : FL_nil;
if(r == IOS_EOF)
return FL_eof;
lerrorf(FL_IOError, "i/o error");
@@ -167,7 +167,7 @@
off_t off = tooffset(args[1]);
off_t res = ios_skip(s, off);
if(res < 0)
- return FL_f;
+ return FL_nil;
return sizeof(res) == sizeof(int64_t) ? mk_int64(res) : mk_int32(res);
}
@@ -174,7 +174,7 @@
BUILTIN("io-flush", io_flush)
{
argcount(nargs, 1);
- return ios_flush(toiostream(args[0])) == 0 ? FL_t : FL_f;
+ return ios_flush(toiostream(args[0])) == 0 ? FL_t : FL_nil;
}
BUILTIN("io-close", io_close)
@@ -204,7 +204,7 @@
BUILTIN("io-eof?", io_eofp)
{
argcount(nargs, 1);
- return ios_eof(toiostream(args[0])) ? FL_t : FL_f;
+ return ios_eof(toiostream(args[0])) ? FL_t : FL_nil;
}
BUILTIN("io-seek", io_seek)
@@ -214,7 +214,7 @@
size_t pos = tosize(args[1]);
off_t res = ios_seek(s, (off_t)pos);
if(res < 0)
- return FL_f;
+ return FL_nil;
return FL_t;
}
@@ -224,7 +224,7 @@
ios_t *s = toiostream(args[0]);
off_t res = ios_pos(s);
if(res < 0)
- return FL_f;
+ return FL_nil;
return size_wrap((size_t)res);
}
--- a/src/maxstack.inc
+++ b/src/maxstack.inc
@@ -13,7 +13,7 @@
case OP_LOADA: case OP_LOADI8: case OP_LOADV: case OP_LOADG:
ip++; // fallthrough
case OP_LOADA0: case OP_LOADA1:
- case OP_DUP: case OP_LOADT: case OP_LOADF: case OP_LOADNIL: case OP_LOADVOID:
+ case OP_DUP: case OP_LOADT: case OP_LOADNIL: case OP_LOADVOID:
case OP_LOAD0:
case OP_LOAD1: case OP_LOADC0:
case OP_LOADC1:
@@ -20,12 +20,6 @@
sp++;
break;
- case OP_BRF: case OP_BRT:
- SWAP_INT16(ip);
- ip += 2;
- sp--;
- break;
-
case OP_POP: case OP_RET:
case OP_CONS: case OP_SETCAR: case OP_SETCDR:
case OP_EQ: case OP_EQV: case OP_EQUAL: case OP_ADD2: case OP_SUB2:
@@ -103,11 +97,6 @@
SWAP_INT32(ip);
ip += 4;
continue;
- case OP_BRFL: case OP_BRTL:
- SWAP_INT32(ip);
- ip += 4;
- sp--;
- break;
case OP_BRNE:
SWAP_INT16(ip);
ip += 2;
@@ -147,9 +136,8 @@
break;
case OP_CAR: case OP_CDR: case OP_CADR:
- case OP_NOT: case OP_NEG:
+ case OP_NOT: case OP_NEG: case OP_NUMBERP:
case OP_CONSP: case OP_ATOMP: case OP_SYMBOLP:
- case OP_NULLP: case OP_BOOLEANP: case OP_NUMBERP:
case OP_FIXNUMP: case OP_BOUNDP: case OP_BUILTINP:
case OP_FUNCTIONP: case OP_VECTORP: case OP_NANP:
continue;
--- a/src/opcodes.c
+++ b/src/opcodes.c
@@ -1,19 +1,17 @@
#include "flisp.h"
const Builtin builtins[N_OPCODES] = {
- [OP_SETCAR] = {"set-car!", 2},
[OP_NANP] = {"nan?", 1},
+ [OP_SETCAR] = {"set-car!", 2},
[OP_CDR] = {"cdr", 1},
- [OP_BOOLEANP] = {"boolean?", 1},
[OP_FUNCTIONP] = {"function?", 1},
[OP_CADR] = {"cadr", 1},
[OP_SETCDR] = {"set-cdr!", 2},
[OP_EQ] = {"eq?", 2},
[OP_APPLY] = {"apply", -2},
- [OP_NULLP] = {"null?", 1},
+ [OP_ASET] = {"aset!", -3},
[OP_CONSP] = {"cons?", 1},
[OP_ATOMP] = {"atom?", 1},
- [OP_ASET] = {"aset!", -3},
[OP_NOT] = {"not", 1},
[OP_LIST] = {"list", ANYARGS},
[OP_CONS] = {"cons", 2},
@@ -26,8 +24,8 @@
[OP_IDIV] = {"div0", 2},
[OP_FIXNUMP] = {"fixnum?", 1},
[OP_NUMEQ] = {"=", -1},
- [OP_SYMBOLP] = {"symbol?", 1},
[OP_BUILTINP] = {"builtin?", 1},
+ [OP_SYMBOLP] = {"symbol?", 1},
[OP_SUB] = {"-", -1},
[OP_COMPARE] = {"compare", 2},
[OP_FOR] = {"for", 3},
--- a/src/opcodes.h
+++ b/src/opcodes.h
@@ -2,7 +2,7 @@
OP_LOADA0,
OP_LOADA1,
OP_LOADV,
- OP_BRF,
+ OP_BRN,
OP_POP,
OP_CALL,
OP_TCALL,
@@ -24,13 +24,13 @@
OP_LOADC1,
OP_AREF2,
OP_ATOMP,
- OP_BRT,
+ OP_LOADVOID,
OP_BRNN,
OP_LOAD1,
OP_LT,
OP_ADD2,
OP_SETCDR,
- OP_LOADF,
+ OP_KEYARGS,
OP_CONS,
OP_EQ,
OP_SYMBOLP,
@@ -37,8 +37,8 @@
OP_NOT,
OP_CADR,
OP_NEG,
- OP_NULLP,
- OP_BOOLEANP,
+ OP_NANP,
+ OP_BRBOUND,
OP_NUMBERP,
OP_FIXNUMP,
OP_BOUNDP,
@@ -48,8 +48,8 @@
OP_SHIFT,
OP_SETCAR,
OP_JMPL,
- OP_BRFL,
- OP_BRTL,
+ OP_BRNL,
+ OP_BOX,
OP_EQV,
OP_EQUAL,
OP_LIST,
@@ -84,16 +84,9 @@
OP_TCALLL,
OP_BRNEL,
OP_BRNNL,
- OP_BRN,
- OP_BRNL,
- OP_OPTARGS,
- OP_BRBOUND,
- OP_KEYARGS,
- OP_BOX,
- OP_BOXL,
OP_AREF,
- OP_LOADVOID,
- OP_NANP,
+ OP_BOXL,
+ OP_OPTARGS,
OP_EOF_OBJECT,
N_OPCODES
}opcode_t;
--- a/src/print.c
+++ b/src/print.c
@@ -177,8 +177,7 @@
return cv_len(ptr(v)) < SMALL_STR_LEN;
return (
isfixnum(v) || isbuiltin(v) || iscprim(v) ||
- v == FL_f || v == FL_t ||
- v == FL_nil || v == FL_eof || v == FL_void
+ v == FL_t || v == FL_nil || v == FL_eof || v == FL_void
);
}
@@ -420,8 +419,6 @@
case TAG_FUNCTION:
if(v == FL_t)
outsn(f, "#t", 2);
- else if(v == FL_f)
- outsn(f, "#f", 2);
else if(v == FL_nil)
outsn(f, "nil", 3);
else if(v == FL_eof)
@@ -854,10 +851,10 @@
void
fl_print(ios_t *f, value_t v)
{
- FL(print_pretty) = symbol_value(FL_printprettysym) != FL_f;
+ FL(print_pretty) = symbol_value(FL_printprettysym) != FL_nil;
if(FL(print_pretty))
set_print_width();
- FL(print_princ) = symbol_value(FL_printreadablysym) == FL_f;
+ FL(print_princ) = symbol_value(FL_printreadablysym) == FL_nil;
value_t pl = symbol_value(FL_printlengthsym);
FL(print_length) = isfixnum(pl) ? numval(pl) : -1;
pl = symbol_value(FL_printlevelsym);
@@ -875,6 +872,6 @@
memset(FL(consflags), 0, 4*bitvector_nwords(FL(heapsize)/sizeof(cons_t)));
if((iscons(v) || isvector(v) || isfunction(v) || iscvalue(v)) &&
- !fl_isstring(v) && v != FL_t && v != FL_f && v != FL_nil && v != FL_void)
+ !fl_isstring(v) && v != FL_t && v != FL_nil && v != FL_void)
htable_reset(&FL(printconses), 32);
}
--- a/src/read.c
+++ b/src/read.c
@@ -647,8 +647,6 @@
sym = ctx->tokval;
if(sym == FL_tsym || sym == FL_Tsym)
return FL_t;
- if(sym == FL_fsym || sym == FL_Fsym)
- return FL_f;
// constructor notation
c = nextchar();
ctx->loc = RS->loc;
--- a/src/string.c
+++ b/src/string.c
@@ -13,7 +13,7 @@
BUILTIN("string?", stringp)
{
argcount(nargs, 1);
- return fl_isstring(args[0]) ? FL_t : FL_f;
+ return fl_isstring(args[0]) ? FL_t : FL_nil;
}
BUILTIN("string-length", string_length)
@@ -48,7 +48,7 @@
cprim_t *cp = ptr(args[0]);
if(cp_class(cp) == FL(runetype)){
int w = fl_wcwidth(*(Rune*)cp_data(cp));
- return w < 0 ? FL_f : fixnum(w);
+ return w < 0 ? FL_nil : fixnum(w);
}
}
if(!fl_isstring(args[0]))
@@ -56,7 +56,7 @@
char *str = tostring(args[0]);
size_t len = cv_len(ptr(args[0]));
ssize_t w = u8_strwidth(str, len);
- return w < 0 ? FL_f : size_wrap(w);
+ return w < 0 ? FL_nil : size_wrap(w);
}
BUILTIN("string-reverse", string_reverse)
@@ -94,7 +94,7 @@
{
bool term = false;
if(nargs == 2)
- term = args[1] != FL_f;
+ term = args[1] != FL_nil;
else
argcount(nargs, 1);
if(!fl_isstring(args[0]))
@@ -125,8 +125,8 @@
ios_t *s = value2c(ios_t*, buf);
value_t oldpr = symbol_value(FL_printreadablysym);
value_t oldpp = symbol_value(FL_printprettysym);
- set(FL_printreadablysym, FL_f);
- set(FL_printprettysym, FL_f);
+ set(FL_printreadablysym, FL_nil);
+ set(FL_printprettysym, FL_nil);
uint32_t i;
FOR_ARGS(i, 0, arg, args){
USED(arg);
@@ -256,7 +256,7 @@
cprim_t *cp = ptr(args[0]);
if(!iscprim(args[0]) || cp_class(cp) != FL(runetype))
type_error("rune", args[0]);
- return isalpharune(*(Rune*)cp_data(cp)) ? FL_t : FL_f;
+ return isalpharune(*(Rune*)cp_data(cp)) ? FL_t : FL_nil;
}
fl_purefn
@@ -266,7 +266,7 @@
cprim_t *cp = ptr(args[0]);
if(!iscprim(args[0]) || cp_class(cp) != FL(runetype))
type_error("rune", args[0]);
- return islowerrune(*(Rune*)cp_data(cp)) ? FL_t : FL_f;
+ return islowerrune(*(Rune*)cp_data(cp)) ? FL_t : FL_nil;
}
fl_purefn
@@ -276,7 +276,7 @@
cprim_t *cp = ptr(args[0]);
if(!iscprim(args[0]) || cp_class(cp) != FL(runetype))
type_error("rune", args[0]);
- return isupperrune(*(Rune*)cp_data(cp)) ? FL_t : FL_f;
+ return isupperrune(*(Rune*)cp_data(cp)) ? FL_t : FL_nil;
}
fl_purefn
@@ -286,7 +286,7 @@
cprim_t *cp = ptr(args[0]);
if(!iscprim(args[0]) || cp_class(cp) != FL(runetype))
type_error("rune", args[0]);
- return istitlerune(*(Rune*)cp_data(cp)) ? FL_t : FL_f;
+ return istitlerune(*(Rune*)cp_data(cp)) ? FL_t : FL_nil;
}
fl_purefn
@@ -296,7 +296,7 @@
cprim_t *cp = ptr(args[0]);
if(!iscprim(args[0]) || cp_class(cp) != FL(runetype))
type_error("rune", args[0]);
- return isdigitrune(*(Rune*)cp_data(cp)) ? FL_t : FL_f;
+ return isdigitrune(*(Rune*)cp_data(cp)) ? FL_t : FL_nil;
}
fl_purefn
@@ -306,7 +306,7 @@
cprim_t *cp = ptr(args[0]);
if(!iscprim(args[0]) || cp_class(cp) != FL(runetype))
type_error("rune", args[0]);
- return isspacerune(*(Rune*)cp_data(cp)) ? FL_t : FL_f;
+ return isspacerune(*(Rune*)cp_data(cp)) ? FL_t : FL_nil;
}
BUILTIN("string-find", string_find)
@@ -343,7 +343,7 @@
type_error("string", args[1]);
}
if(needlesz > len-start)
- return FL_f;
+ return FL_nil;
if(needlesz == 0)
return size_wrap(start);
size_t i;
@@ -351,7 +351,7 @@
if(s[i] == needle[0] && memcmp(&s[i+1], needle+1, needlesz-1) == 0)
return size_wrap(i);
}
- return FL_f;
+ return FL_nil;
}
static unsigned long
@@ -419,7 +419,7 @@
if(nargs == 2)
radix = get_radix_arg(args[1]);
if(!fl_read_numtok(str, &n, (int)radix))
- return FL_f;
+ return FL_nil;
return n;
}
@@ -429,5 +429,5 @@
argcount(nargs, 1);
char *s = tostring(args[0]);
size_t len = cv_len(ptr(args[0]));
- return u8_isvalid(s, len) ? FL_t : FL_f;
+ return u8_isvalid(s, len) ? FL_t : FL_nil;
}
--- a/src/system.lsp
+++ b/src/system.lsp
@@ -14,7 +14,7 @@
#.(void))
(def (void? x)
- "Return #t if x is #<void> and #f otherwise."
+ "Return #t if x is #<void> and nil otherwise."
(eq? x #.(void)))
;;; syntax environment
@@ -23,7 +23,7 @@
(def *syntax-environment* (table)))
(def (set-syntax! s v) (put! *syntax-environment* s v))
-(def (symbol-syntax s) (get *syntax-environment* s #f))
+(def (symbol-syntax s) (get *syntax-environment* s nil))
(defmacro (defmacro form . body)
(let ((doc (value-get-doc body)))
@@ -40,7 +40,7 @@
,.(map void binds)))
(defmacro (let binds . body)
- (let ((lname #f))
+ (let ((lname nil))
(when (symbol? binds)
(set! lname binds)
(set! binds (car body))
@@ -59,14 +59,14 @@
(defmacro (cond . clauses)
(def (cond-clauses->if lst)
(if (atom? lst)
- #f
+ nil
(let ((clause (car lst)))
(if (or (eq? (car clause) 'else)
(eq? (car clause) #t))
- (if (null? (cdr clause))
+ (if (not (cdr clause))
(car clause)
(cons 'begin (cdr clause)))
- (if (null? (cdr clause))
+ (if (not (cdr clause))
; test by itself
(list 'or
(car clause)
@@ -102,7 +102,7 @@
(def *properties* (table)))
(def (putprop sym key val)
- (let ((kt (get *properties* key #f)))
+ (let ((kt (get *properties* key nil)))
(unless kt
(let ((t (table)))
(put! *properties* key t)
@@ -110,12 +110,12 @@
(put! kt sym val)
val))
-(def (getprop sym key (def #f))
- (let ((kt (get *properties* key #f)))
+(def (getprop sym key (def nil))
+ (let ((kt (get *properties* key nil)))
(or (and kt (get kt sym def)) def)))
(def (remprop sym key)
- (let ((kt (get *properties* key #f)))
+ (let ((kt (get *properties* key nil)))
(and kt (has? kt sym) (del! kt sym))))
;;; documentation
@@ -155,28 +155,24 @@
;;; standard procedures
(def (member item lst)
- (cond ((null? lst) #f)
- ((equal? (car lst) item) lst)
- (#t (member item (cdr lst)))))
+ (cond ((equal? (car lst) item) lst)
+ (lst (member item (cdr lst)))))
(def (memv item lst)
- (cond ((null? lst) #f)
- ((eqv? (car lst) item) lst)
- (#t (memv item (cdr lst)))))
+ (cond ((eqv? (car lst) item) lst)
+ (lst (memv item (cdr lst)))))
(def (assoc item lst)
- (cond ((null? lst) #f)
- ((equal? (caar lst) item) (car lst))
- (#t (assoc item (cdr lst)))))
+ (cond ((equal? (caar lst) item) (car lst))
+ (lst (assoc item (cdr lst)))))
(def (assv item lst)
- (cond ((null? lst) #f)
- ((eqv? (caar lst) item) (car lst))
- (#t (assv item (cdr lst)))))
+ (cond ((eqv? (caar lst) item) (car lst))
+ (lst (assv item (cdr lst)))))
(def (> a . rest)
"Return #t if the arguments are in strictly decreasing order (previous
one is greater than the next one)."
(let loop ((a a) (rest rest))
- (or (null? rest)
+ (or (not rest)
(and (< (car rest) a)
(loop (car rest) (cdr rest))))))
(defmacro (> a . rest)
@@ -186,7 +182,7 @@
"Return #t if the arguments are in non-decreasing order (previous
one is less than or equal to the next one)."
(let loop ((a a) (rest rest))
- (or (null? rest)
+ (or (not rest)
(unless (or (< (car rest) a)
(nan? a))
(loop (car rest) (cdr rest))))))
@@ -195,7 +191,7 @@
"Return #t if the arguments are in non-increasing order (previous
one is greater than or equal to the next one)."
(let loop ((a a) (rest rest))
- (or (null? rest)
+ (or (not rest)
(unless (or (< a (car rest))
(nan? a))
(loop (car rest) (cdr rest))))))
@@ -225,10 +221,10 @@
(* (rand-double) n)))
(def (abs x) (if (< x 0) (- x) x))
(def (max x0 . xs)
- (if (null? xs) x0
+ (if (not xs) x0
(foldl (λ (a b) (if (< a b) b a)) x0 xs)))
(def (min x0 . xs)
- (if (null? xs) x0
+ (if (not xs) x0
(foldl (λ (a b) (if (< a b) a b)) x0 xs)))
(def (char? x) (eq? (typeof x) 'rune))
(def (array? x) (or (vector? x)
@@ -267,7 +263,7 @@
(let ((*values* (list '*values*)))
(set! values
(λ vs
- (if (and (cons? vs) (null? (cdr vs)))
+ (if (and (cons? vs) (not (cdr vs)))
(car vs)
(cons *values* vs))))
(set! call-with-values
@@ -289,7 +285,7 @@
(or (pred (car lst))
(any pred (cdr lst)))))
-(def (list? a) (or (null? a) (and (cons? a) (list? (cdr a)))))
+(def (list? a) (or (not a) (and (cons? a) (list? (cdr a)))))
(def (list-tail lst n)
(if (<= n 0) lst
@@ -307,7 +303,7 @@
"Bounded length test.
Use this instead of (= (length lst) n), since it avoids unnecessary
work and always terminates."
- (cond ((< n 0) #f)
+ (cond ((< n 0) nil)
((= n 0) (atom? lst))
((atom? lst) (= n 0))
(else (length= (cdr lst) (- n 1)))))
@@ -329,7 +325,7 @@
(cdr (last-pair l))))
(def (to-proper l)
- (cond ((null? l) l)
+ (cond ((not l) l)
((atom? l) (list l))
(else (cons (car l) (to-proper (cdr l))))))
@@ -365,7 +361,7 @@
(def (count f l)
(def (count- f l n)
- (if (null? l)
+ (if (not l)
n
(count- f (cdr l) (if (f (car l))
(+ n 1)
@@ -377,15 +373,15 @@
(cons zero (nestlist f (f zero) (- n 1)))))
(def (foldr f zero lst)
- (if (null? lst) zero
+ (if (not lst) zero
(f (car lst) (foldr f zero (cdr lst)))))
(def (foldl f zero lst)
- (if (null? lst) zero
+ (if (not lst) zero
(foldl f (f (car lst) zero) (cdr lst))))
(def (reverse- zero lst)
- (if (null? lst) zero
+ (if (not lst) zero
(reverse- (cons (car lst) zero) (cdr lst))))
(def (reverse lst) (reverse- () lst))
@@ -491,14 +487,14 @@
((not (any splice-form? x))
(let ((lc (lastcdr x))
(forms (map (λ (x) (bq-bracket1 x d)) x)))
- (if (null? lc)
+ (if (not lc)
(cons list forms)
- (if (null? (cdr forms))
+ (if (not (cdr forms))
(list cons (car forms) (bq-process lc d))
(nconc (cons list* forms) (list (bq-process lc d)))))))
(else
(let loop ((p x) (q ()))
- (cond ((null? p) ;; proper list
+ (cond ((not p) ;; proper list
(cons 'nconc (reverse! q)))
((cons? p)
(cond ((eq? (car p) 'unquote)
@@ -531,16 +527,16 @@
body))
,(cadar binds))))
-(defmacro (when c . body) (list 'if c (cons 'begin body) #f))
-(defmacro (unless c . body) (list 'if c #f (cons 'begin body)))
+(defmacro (when c . body) (list 'if c (cons 'begin body) nil))
+(defmacro (unless c . body) (list 'if c nil (cons 'begin body)))
(defmacro (case key . clauses)
(def (vals->cond key v)
(cond ((eq? v 'else) 'else)
- ((null? v) #f)
+ ((not v) nil)
((symbol? v) `(eq? ,key ,(quote-value v)))
((atom? v) `(eqv? ,key ,(quote-value v)))
- ((null? (cdr v)) `(eqv? ,key ,(quote-value (car v))))
+ ((not (cdr v)) `(eqv? ,key ,(quote-value (car v))))
((every symbol? v)
`(memq ,key ',v))
(else `(memv ,key ',v))))
@@ -663,7 +659,7 @@
(def (print . args) (for-each write args))
(def (princ . args)
- (with-bindings ((*print-readably* #f))
+ (with-bindings ((*print-readably* nil))
(for-each write args)))
(def (newline (port *output-stream*))
@@ -781,7 +777,7 @@
(iostream->string b)))
(def (string-join strlist sep)
- (if (null? strlist) ""
+ (if (not strlist) ""
(let ((b (buffer)))
(io-write b (car strlist))
(for-each (λ (s) (io-write b sep)
@@ -871,8 +867,8 @@
. ,name))))
(def (expand-define e env)
- (if (or (null? (cdr e)) (atom? (cadr e)))
- (if (null? (cddr e))
+ (if (or (not (cdr e)) (atom? (cadr e)))
+ (if (not (cddr e))
e
(let ((name (cadr e))
(doc (value-get-doc (cddr e))))
@@ -997,7 +993,7 @@
(for-each (λ (topfun)
(find-in-f topfun f ()))
e)
- #f))))
+ nil))))
(if p
(string-join (map string (reverse! p)) "/")
"λ")))
@@ -1062,7 +1058,7 @@
(princ *linefeed*))
(def (simple-sort l)
- (if (or (null? l) (null? (cdr l))) l
+ (if (or (not l) (not (cdr l))) l
(let ((piv (car l)))
(receive (less grtr)
(partition (λ (x) (< x piv)) (cdr l))
@@ -1078,7 +1074,7 @@
*print-pretty* *print-width* *print-readably*
*print-level* *print-length* *os-name* *interactive*
*prompt* *os-version* procedure? top-level-bound?)))
- (with-bindings ((*print-pretty* #f)
+ (with-bindings ((*print-pretty* nil)
(*print-readably* #t))
(let* ((syms
(filter (λ (s)
@@ -1127,9 +1123,9 @@
(def (__rcscript)
(let* ((homevar (case *os-name*
- (("unknown") #f)
+ (("unknown") nil)
(("plan9") "home")
- (("macos") (princ "\x1b]0;femtolisp v0.999\007") #f)
+ (("macos") (princ "\x1b]0;femtolisp v0.999\007") nil)
(else "HOME")))
(home (and homevar (os-getenv homevar)))
(fname (and home (string home *directory-separator* ".flisprc"))))
@@ -1139,7 +1135,7 @@
(__init_globals)
(if (cons? (cdr argv))
(begin (set! *argv* (cdr argv))
- (set! *interactive* #f)
+ (set! *interactive* nil)
(__script (cadr argv)))
(begin (set! *argv* argv)
(set! *interactive* #t)
--- a/src/table.c
+++ b/src/table.c
@@ -78,7 +78,7 @@
BUILTIN("table?", tablep)
{
argcount(nargs, 1);
- return ishashtable(args[0]) ? FL_t : FL_f;
+ return ishashtable(args[0]) ? FL_t : FL_nil;
}
htable_t *
@@ -159,7 +159,7 @@
{
argcount(nargs, 2);
htable_t *h = totable(args[0]);
- return equalhash_has(h, (void*)args[1]) ? FL_t : FL_f;
+ return equalhash_has(h, (void*)args[1]) ? FL_t : FL_nil;
}
// (del! table key)
--- a/src/vm.inc
+++ b/src/vm.inc
@@ -12,8 +12,8 @@
PUSH(vector_elt(v, *ip++));
NEXT_OP;
-OP(OP_BRF)
- ip += POP() != FL_f ? 2 : GET_INT16(ip);
+OP(OP_BRN)
+ ip += POP() == FL_nil ? GET_INT16(ip) : 2;
NEXT_OP;
OP(OP_POP)
@@ -232,7 +232,7 @@
NEXT_OP;
OP(OP_CONSP)
- FL(stack)[FL(sp)-1] = iscons(FL(stack)[FL(sp)-1]) ? FL_t : FL_f;
+ FL(stack)[FL(sp)-1] = iscons(FL(stack)[FL(sp)-1]) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_BRNE)
@@ -296,13 +296,9 @@
NEXT_OP;
OP(OP_ATOMP)
- FL(stack)[FL(sp)-1] = iscons(FL(stack)[FL(sp)-1]) ? FL_f : FL_t;
+ FL(stack)[FL(sp)-1] = iscons(FL(stack)[FL(sp)-1]) ? FL_nil : FL_t;
NEXT_OP;
-OP(OP_BRT)
- ip += POP() != FL_f ? GET_INT16(ip) : 2;
- NEXT_OP;
-
OP(OP_BRNN)
ip += POP() != FL_nil ? GET_INT16(ip) : 2;
NEXT_OP;
@@ -322,7 +318,7 @@
b = FL(stack)[FL(sp)-i];
if(bothfixnums(a, b)){
if((fixnum_t)a >= (fixnum_t)b){
- v = FL_f;
+ v = FL_nil;
break;
}
}else{
@@ -330,7 +326,7 @@
if(x > 1)
x = numval(fl_compare(a, b, false));
if(x >= 0){
- v = FL_f;
+ v = FL_nil;
break;
}
}
@@ -373,10 +369,6 @@
POPN(1);
NEXT_OP;
-OP(OP_LOADF)
- PUSH(FL_f);
- NEXT_OP;
-
OP(OP_CONS)
if(FL(curheap) > FL(lim))
fl_gc(0);
@@ -389,16 +381,17 @@
NEXT_OP;
OP(OP_EQ)
- FL(stack)[FL(sp)-2] = FL(stack)[FL(sp)-2] == FL(stack)[FL(sp)-1] ? FL_t : FL_f;
+ FL(stack)[FL(sp)-2] = FL(stack)[FL(sp)-2] == FL(stack)[FL(sp)-1] ? FL_t : FL_nil;
POPN(1);
NEXT_OP;
OP(OP_SYMBOLP)
- FL(stack)[FL(sp)-1] = issymbol(FL(stack)[FL(sp)-1]) ? FL_t : FL_f;
+ FL(stack)[FL(sp)-1] = issymbol(FL(stack)[FL(sp)-1]) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_NOT)
- FL(stack)[FL(sp)-1] = FL(stack)[FL(sp)-1] == FL_f ? FL_t : FL_f;
+ v = FL(stack)[FL(sp)-1];
+ FL(stack)[FL(sp)-1] = v == FL_nil ? FL_t : FL_nil;
NEXT_OP;
OP(OP_CADR)
@@ -428,7 +421,7 @@
OP(OP_NANP)
{
value_t q = FL(stack)[FL(sp)-1];
- v = FL_f;
+ v = FL_nil;
if(iscprim(q)){
void *data = cp_data(ptr(q));
switch(cp_numtype(ptr(q))){
@@ -448,33 +441,24 @@
}
NEXT_OP;
-OP(OP_NULLP)
- FL(stack)[FL(sp)-1] = FL(stack)[FL(sp)-1] == FL_nil ? FL_t : FL_f;
- NEXT_OP;
-
-OP(OP_BOOLEANP)
- v = FL(stack)[FL(sp)-1];
- FL(stack)[FL(sp)-1] = (v == FL_t || v == FL_f) ? FL_t : FL_f;
- NEXT_OP;
-
OP(OP_NUMBERP)
v = FL(stack)[FL(sp)-1];
- FL(stack)[FL(sp)-1] = fl_isnumber(v) ? FL_t : FL_f;
+ FL(stack)[FL(sp)-1] = fl_isnumber(v) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_FIXNUMP)
- FL(stack)[FL(sp)-1] = isfixnum(FL(stack)[FL(sp)-1]) ? FL_t : FL_f;
+ FL(stack)[FL(sp)-1] = isfixnum(FL(stack)[FL(sp)-1]) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_BOUNDP)
FL(stack)[ipd] = (uintptr_t)ip;
sym = tosymbol(FL(stack)[FL(sp)-1]);
- FL(stack)[FL(sp)-1] = sym->binding == UNBOUND ? FL_f : FL_t;
+ FL(stack)[FL(sp)-1] = sym->binding == UNBOUND ? FL_nil : FL_t;
NEXT_OP;
OP(OP_BUILTINP)
v = FL(stack)[FL(sp)-1];
- FL(stack)[FL(sp)-1] = (isbuiltin(v) || iscbuiltin(v)) ? FL_t : FL_f;
+ FL(stack)[FL(sp)-1] = (isbuiltin(v) || iscbuiltin(v)) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_FUNCTIONP)
@@ -482,11 +466,11 @@
FL(stack)[FL(sp)-1] =
((tag(v) == TAG_FUNCTION &&
(isbuiltin(v) || v>(N_BUILTINS<<3))) ||
- iscbuiltin(v)) ? FL_t : FL_f;
+ iscbuiltin(v)) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_VECTORP)
- FL(stack)[FL(sp)-1] = isvector(FL(stack)[FL(sp)-1]) ? FL_t : FL_f;
+ FL(stack)[FL(sp)-1] = isvector(FL(stack)[FL(sp)-1]) ? FL_t : FL_nil;
NEXT_OP;
OP(OP_JMPL)
@@ -493,14 +477,6 @@
ip += GET_INT32(ip);
NEXT_OP;
-OP(OP_BRFL)
- ip += POP() == FL_f ? GET_INT32(ip) : 4;
- NEXT_OP;
-
-OP(OP_BRTL)
- ip += POP() != FL_f ? GET_INT32(ip) : 4;
- NEXT_OP;
-
OP(OP_BRNEL)
ip += FL(stack)[FL(sp)-2] != FL(stack)[FL(sp)-1] ? GET_INT32(ip) : 4;
POPN(2);
@@ -510,10 +486,6 @@
ip += POP() != FL_nil ? GET_INT32(ip) : 4;
NEXT_OP;
-OP(OP_BRN)
- ip += POP() == FL_nil ? GET_INT16(ip) : 2;
- NEXT_OP;
-
OP(OP_BRNL)
ip += POP() == FL_nil ? GET_INT32(ip) : 4;
NEXT_OP;
@@ -522,9 +494,9 @@
if(FL(stack)[FL(sp)-2] == FL(stack)[FL(sp)-1])
v = FL_t;
else if(!leafp(FL(stack)[FL(sp)-2]) || !leafp(FL(stack)[FL(sp)-1]))
- v = FL_f;
+ v = FL_nil;
else
- v = fl_compare(FL(stack)[FL(sp)-2], FL(stack)[FL(sp)-1], true) == 0 ? FL_t : FL_f;
+ v = fl_compare(FL(stack)[FL(sp)-2], FL(stack)[FL(sp)-1], true) == 0 ? FL_t : FL_nil;//FL_nil
FL(stack)[FL(sp)-2] = v;
POPN(1);
NEXT_OP;
@@ -533,7 +505,7 @@
if(FL(stack)[FL(sp)-2] == FL(stack)[FL(sp)-1])
v = FL_t;
else
- v = fl_compare(FL(stack)[FL(sp)-2], FL(stack)[FL(sp)-1], true) == 0 ? FL_t : FL_f;
+ v = fl_compare(FL(stack)[FL(sp)-2], FL(stack)[FL(sp)-1], true) == 0 ? FL_t : FL_nil;//FL_nil
FL(stack)[FL(sp)-2] = v;
POPN(1);
NEXT_OP;
@@ -671,11 +643,11 @@
b = FL(stack)[FL(sp)-i];
if(bothfixnums(a, b)){
if(a != b){
- v = FL_f;
+ v = FL_nil;
break;
}
}else if(numeric_compare(a, b, true, false, true) != 0){
- v = FL_f;
+ v = FL_nil;
break;
}
}
@@ -920,7 +892,7 @@
i = GET_INT32(ip);
ip += 4;
v = FL(stack)[bp+i];
- PUSH(v != UNBOUND ? FL_t : FL_f);
+ PUSH(v != UNBOUND ? FL_t : FL_nil);
NEXT_OP;
OP(OP_KEYARGS)
--- a/test/ast/asttools.lsp
+++ b/test/ast/asttools.lsp
@@ -10,12 +10,12 @@
(cons item lst)))
(def (index-of item lst start)
- (cond ((null? lst) #f)
+ (cond ((not lst) nil)
((eq? item (car lst)) start)
(#t (index-of item (cdr lst) (+ start 1)))))
(def (each f l)
- (if (null? l) l
+ (if (not l) l
(begin (f (car l))
(each f (cdr l)))))
@@ -69,7 +69,7 @@
; convert to proper list, i.e. remove "dots", and append
(def (append.2 l tail)
- (cond ((null? l) tail)
+ (cond ((not l) tail)
((atom? l) (cons l tail))
(#t (cons (car l) (append.2 (cdr l) tail)))))
@@ -101,7 +101,7 @@
; name is just there for reference
; this assumes lambda is the only remaining naming form
(def (lookup-var v env lev)
- (if (null? env) v
+ (if (not env) v
(let ((i (index-of v (car env) 0)))
(if i (list 'lexref lev i v)
(lookup-var v (cdr env) (+ lev 1))))))
@@ -166,6 +166,6 @@
(let ((m (match ',pat expr)))
(if m
; matches; perform expansion
- (apply ,expander (map (lambda (var) (cdr (or (assq var m) '(0 . #f))))
+ (apply ,expander (map (lambda (var) (cdr (or (assq var m) '(0 . nil))))
',args))
- #f)))))
+ nil)))))
--- a/test/ast/match.lsp
+++ b/test/ast/match.lsp
@@ -3,7 +3,7 @@
; by Jeff Bezanson
(def (unique lst)
- (if (null? lst)
+ (if (not lst)
()
(cons (car lst)
(filter (lambda (x) (not (eq? x (car lst))))
@@ -14,7 +14,7 @@
; expression tree pattern matching
; matches expr against pattern p and returns an assoc list ((var . expr) (var . expr) ...)
-; mapping variables to captured subexpressions, or #f if no match.
+; mapping variables to captured subexpressions, or nil if no match.
; when a match succeeds, __ is always bound to the whole matched expression.
;
; p is an expression in the following pattern language:
@@ -57,7 +57,7 @@
(and (match- (caddr p) expr state)
(cons (cons (cadr p) expr) state)))
((eq? (car p) '-$) ; greedy alternation for toplevel pattern
- (match-alt (cdr p) () (list expr) state #f 1))
+ (match-alt (cdr p) () (list expr) state nil 1))
(#t
(and (cons? expr)
(equal? (car p) (car expr))
@@ -68,7 +68,8 @@
; match an alternation
(def (match-alt alt prest expr state var L)
- (if (null? alt) #f ; no alternatives left
+ (if (not alt)
+ nil ; no alternatives left
(let ((subma (match- (car alt) (car expr) state)))
(or (and subma
(match-seq prest (cdr expr)
@@ -82,7 +83,7 @@
; match generalized kleene star (try consuming min to max)
(def (match-star- p prest expr state var min max L sofar)
(cond ; case 0: impossible to match
- ((> min max) #f)
+ ((> min max) nil)
; case 1: only allowed to match 0 subexpressions
((= max 0) (match-seq prest expr
(if var (cons (cons var (reverse sofar)) state)
@@ -102,16 +103,16 @@
; match sequences of expressions
(def (match-seq p expr state L)
- (cond ((not state) #f)
- ((null? p) (if (null? expr) state #f))
+ (cond ((not state) nil)
+ ((not p) (if (not expr) state nil))
(#t
(let ((subp (car p))
- (var #f))
+ (var nil))
(if (and (cons? subp)
- (eq? (car subp) '--))
+ (eq? (car subp) '--))
(begin (set! var (cadr subp))
- (set! subp (caddr subp)))
- #f)
+ (set! subp (caddr subp)))
+ nil)
(let ((head (if (cons? subp) (car subp) ())))
(cond ((eq? subp '...)
(match-star '_ (cdr p) expr state var 0 L L))
@@ -149,7 +150,7 @@
; try to transform expr using a pattern-lambda from plist
; returns the new expression, or expr if no matches
(def (apply-patterns plist expr)
- (if (null? plist) expr
+ (if (not plist) expr
(if (procedure? plist)
(let ((enew (plist expr)))
(if (not enew)
--- a/test/color.lsp
+++ b/test/color.lsp
@@ -4,12 +4,12 @@
(def (dict-new) ())
(def (dict-extend dl key value)
- (cond ((null? dl) (list (cons key value)))
+ (cond ((not dl) (list (cons key value)))
((equal? key (caar dl)) (cons (cons key value) (cdr dl)))
(else (cons (car dl) (dict-extend (cdr dl) key value)))))
(def (dict-lookup dl key)
- (cond ((null? dl) ())
+ (cond ((not dl) nil)
((equal? key (caar dl)) (cdar dl))
(else (dict-lookup (cdr dl) key))))
@@ -33,11 +33,11 @@
(def (graph-add-node g n1) (dict-extend g n1 ()))
(def (graph-from-edges edge-list)
- (if (null? edge-list)
+ (if (not edge-list)
(graph-empty)
- (graph-connect (graph-from-edges (cdr edge-list))
- (caar edge-list)
- (cdar edge-list))))
+ (graph-connect (graph-from-edges (cdr edge-list))
+ (caar edge-list)
+ (cdar edge-list))))
; graph coloring --------------------------------------------------------------
(def (node-colorable? g coloring node-to-color color-of-node)
@@ -50,13 +50,13 @@
(graph-neighbors g node-to-color)))))
(def (try-each f lst)
- (if (null? lst) #f
+ (if (not lst) nil
(let ((ret (f (car lst))))
(if ret ret (try-each f (cdr lst))))))
(def (color-node g coloring colors uncolored-nodes color)
(cond
- ((null? uncolored-nodes) coloring)
+ ((not uncolored-nodes) coloring)
((node-colorable? g coloring (car uncolored-nodes) color)
(let ((new-coloring
(cons (cons (car uncolored-nodes) color) coloring)))
@@ -65,8 +65,8 @@
colors)))))
(def (color-graph g colors)
- (if (null? colors)
- (and (null? (graph-nodes g)) ())
+ (if (not colors)
+ (and (not (graph-nodes g)) nil)
(color-node g () colors (graph-nodes g) (car colors))))
(def (color-pairs pairs colors)
--- a/test/perf.lsp
+++ b/test/perf.lsp
@@ -16,10 +16,11 @@
(time (dotimes (n 5000) (expand '(dotimes (i 100) body1 body2))))
(def (my-append . lsts)
- (cond ((null? lsts) ())
- ((null? (cdr lsts)) (car lsts))
+ (cond ((not lsts) nil)
+ ((not (cdr lsts)) (car lsts))
(else (letrec ((append2 (λ (l d)
- (if (null? l) d
+ (if (not l)
+ d
(cons (car l)
(append2 (cdr l) d))))))
(append2 (car lsts) (apply my-append (cdr lsts)))))))
--- a/test/test.lsp
+++ b/test/test.lsp
@@ -9,7 +9,7 @@
;(def (reverse lst)
; ((label rev-help (λ (lst result)
-; (if (null? lst) result
+; (if (not lst) result
; (rev-help (cdr lst) (cons (car lst) result)))))
; lst ()))
@@ -16,10 +16,10 @@
(def (append- . lsts)
((label append-h
(λ (lsts)
- (cond ((null? lsts) ())
- ((null? (cdr lsts)) (car lsts))
+ (cond ((not lsts) ())
+ ((not (cdr lsts)) (car lsts))
(#t ((label append2 (λ (l d)
- (if (null? l) d
+ (if (not l) d
(cons (car l)
(append2 (cdr l) d)))))
(car lsts) (append-h (cdr lsts)))))))
@@ -77,7 +77,7 @@
(def (mapl f . lsts)
((label mapl-
(λ (lsts)
- (if (null? (car lsts)) ()
+ (if (not (car lsts)) ()
(begin (apply f lsts) (mapl- (map cdr lsts))))))
lsts))
@@ -251,7 +251,7 @@
(def (filt1 pred lst)
(def (filt1- pred lst accum)
- (if (null? lst) accum
+ (if (not lst) accum
(if (pred (car lst))
(filt1- pred (cdr lst) (cons (car lst) accum))
(filt1- pred (cdr lst) accum))))
@@ -265,7 +265,7 @@
; (pairwise? p a b c d) == (and (p a b) (p b c) (p c d))
(def (pairwise? pred . args)
- (or (null? args)
+ (or (not args)
(let f ((a (car args)) (d (cdr args)))
- (or (null? d)
+ (or (not d)
(and (pred a (car d)) (f (car d) (cdr d)))))))
--- a/test/torus.lsp
+++ b/test/torus.lsp
@@ -1,7 +1,8 @@
; -*- scheme -*-
(def (maplist f l)
- (if (null? l) ()
- (cons (f l) (maplist f (cdr l)))))
+ (if (not l)
+ nil
+ (cons (f l) (maplist f (cdr l)))))
; produce a beautiful, toroidal cons structure
; make m copies of a CDR-circular list of length n, and connect corresponding
--- a/test/unittest.lsp
+++ b/test/unittest.lsp
@@ -1,7 +1,7 @@
; -*- scheme -*-
(defmacro (assert-fail expr . what)
- `(assert (trycatch (begin ,expr #f)
- (λ (e) ,(if (null? what) #t
+ `(assert (trycatch (begin ,expr nil)
+ (λ (e) ,(if (not what) #t
`(eq? (car e) ',(car what)))))))
(def (every-int n)
@@ -197,15 +197,15 @@
; and, or
(assert (equal? #t (and)))
-(assert (equal? #f (or)))
-(assert (equal? 1 (and '() 'x 1)))
-(assert (equal? 1 (or #f #f #f #f #f 1 #f #f #f #f)))
-(assert (equal? 2 (if (and '() 'x 1) 2 0)))
-(assert (equal? 2 (if (or #f #f #f #f #f 1 #f #f #f #f) 2 0)))
-(assert (equal? #f (and '() 1 'x #f)))
-(assert (equal? #f (or #f #f #f #f #f #f #f #f #f #f)))
-(assert (equal? 0 (if (and '() 1 'x #f) 2 0)))
-(assert (equal? 0 (if (or #f #f #f #f #f #f #f #f #f #f) 2 0)))
+(assert (equal? nil (or)))
+(assert (equal? 1 (and '(1) 'x 1)))
+(assert (equal? 1 (or nil nil nil nil nil 1 nil nil nil nil)))
+(assert (equal? 2 (if (and '(1) 'x 1) 2 0)))
+(assert (equal? 2 (if (or nil nil nil nil nil 1 nil nil nil nil) 2 0)))
+(assert (equal? nil (and '(1) 1 'x nil)))
+(assert (equal? nil (or nil nil nil nil nil nil nil nil nil nil)))
+(assert (equal? 0 (if (and '(1) 1 'x nil) 2 0)))
+(assert (equal? 0 (if (or nil nil nil nil nil nil nil nil nil nil) 2 0)))
; failing applications
(assert-fail ((λ (x) x) 1 2))
@@ -380,7 +380,7 @@
(iostream->string b)))
(let ((c #\a))
- (assert (equal? (with-output-to-string #f (λ () (print (list c c))))
+ (assert (equal? (with-output-to-string nil (λ () (print (list c c))))
"(#\\a #\\a)")))
(assert-fail (eval '(set! (car (cons 1 2)) 3)))
@@ -407,16 +407,16 @@
(assert (equal? (bound? 'abc) #t))
(assert (equal? (eval '(+ abc 1)) 2))
(makunbound 'abc)
-(assert (equal? (bound? 'abc) #f))
+(assert (equal? (bound? 'abc) nil))
(assert-fail (eval '(+ abc 1)))
;; c***r of empty list
-(assert (null? (car '())))
-(assert (null? (cdr '())))
-(assert (null? (cadr '())))
-(assert (null? (cdar '())))
-(assert (null? (caaar '())))
-(assert (null? (cdddr '())))
+(assert (not (car '())))
+(assert (not (cdr '())))
+(assert (not (cadr '())))
+(assert (not (cdar '())))
+(assert (not (caaar '())))
+(assert (not (cdddr '())))
;; for-each with multiple lists
(def q '())
@@ -466,8 +466,8 @@
(for 1 100 (λ (i)
(table eq? 2 eqv? 2
equal? 2 atom? 1
- not 1 null? 1
- boolean? 1 symbol? 1
+ not 1 nan? 1
+ cons? 1 symbol? 1
number? 1 bound? 1
cons? 1 builtin? 1
vector? 1 fixnum? 1
--- a/tools/gen.lsp
+++ b/tools/gen.lsp
@@ -1,106 +1,99 @@
(def opcodes '(
; C opcode, lisp compiler opcode, arg count, builtin lambda, DOC (NEW)
- OP_LOADA0 loada0 #f 0 ()
- OP_LOADA1 loada1 #f 0 ()
- OP_LOADV loadv #f 0 ()
- OP_BRF brf #f 0 ()
- OP_POP pop #f 0 ()
- OP_CALL call #f 0 ()
- OP_TCALL tcall #f 0 ()
- OP_LOADG loadg #f 0 ()
- OP_LOADA loada #f 0 ()
- OP_LOADC loadc #f 0 ()
- OP_RET ret #f 0 ()
- OP_DUP dup #f 0 ()
+ OP_LOADA0 loada0 nil nil nil
+ OP_LOADA1 loada1 nil nil nil
+ OP_LOADV loadv nil nil nil
+ OP_BRN brn nil nil nil
+ OP_POP pop nil nil nil
+ OP_CALL call nil nil nil
+ OP_TCALL tcall nil nil nil
+ OP_LOADG loadg nil nil nil
+ OP_LOADA loada nil nil nil
+ OP_LOADC loadc nil nil nil
+ OP_RET ret nil nil nil
+ OP_DUP dup nil nil nil
OP_CAR car 1 (λ (x) (car x)) (
((lst) "Returns the first element of a list or nil if not available."))
OP_CDR cdr 1 (λ (x) (cdr x)) (
((lst) "Returns the tail of a list or nil if not available."))
- OP_CLOSURE closure #f 0 ()
- OP_SETA seta #f 0 ()
- OP_JMP jmp #f 0 ()
- OP_LOADC0 loadc0 #f 0 ()
+ OP_CLOSURE closure nil nil nil
+ OP_SETA seta nil nil nil
+ OP_JMP jmp nil nil nil
+ OP_LOADC0 loadc0 nil nil nil
OP_CONSP cons? 1 (λ (x) (cons? x)) (
((value) "Returns #t if the value is a cons cell."))
- OP_BRNE brne #f 0 ()
- OP_LOADT loadt #f 0 ()
- OP_LOAD0 load0 #f 0 ()
- OP_LOADC1 loadc1 #f 0 ()
- OP_AREF2 aref2 #f 0 ()
- OP_ATOMP atom? 1 (λ (x) (atom? x)) ()
- OP_BRT brt #f 0 ()
- OP_BRNN brnn #f 0 ()
- OP_LOAD1 load1 #f 0 ()
- OP_LT < -1 (λ rest (apply < rest)) ()
- OP_ADD2 add2 #f 0 ()
- OP_SETCDR set-cdr! 2 (λ (x y) (set-cdr! x y)) ()
- OP_LOADF loadf #f 0 ()
- OP_CONS cons 2 (λ (x y) (cons x y)) ()
- OP_EQ eq? 2 (λ (x y) (eq? x y)) ()
- OP_SYMBOLP symbol? 1 (λ (x) (symbol? x)) ()
- OP_NOT not 1 (λ (x) (not x)) ()
- OP_CADR cadr 1 (λ (x) (cadr x)) ()
- OP_NEG neg #f 0 ()
- OP_NULLP null? 1 (λ (x) (null? x)) ()
- OP_BOOLEANP boolean? 1 (λ (x) (boolean? x)) ()
- OP_NUMBERP number? 1 (λ (x) (number? x)) ()
- OP_FIXNUMP fixnum? 1 (λ (x) (fixnum? x)) ()
- OP_BOUNDP bound? 1 (λ (x) (bound? x)) ()
- OP_BUILTINP builtin? 1 (λ (x) (builtin? x)) ()
- OP_FUNCTIONP function? 1 (λ (x) (function? x)) ()
- OP_VECTORP vector? 1 (λ (x) (vector? x)) ()
- OP_SHIFT shift #f 0 ()
- OP_SETCAR set-car! 2 (λ (x y) (set-car! x y)) ()
- OP_JMPL jmp.l #f 0 ()
- OP_BRFL brf.l #f 0 ()
- OP_BRTL brt.l #f 0 ()
- OP_EQV eqv? 2 (λ (x y) (eqv? x y)) ()
- OP_EQUAL equal? 2 (λ (x y) (equal? x y)) ()
- OP_LIST list ANYARGS (λ rest rest) ()
- OP_APPLY apply -2 (λ rest (apply apply rest)) ()
+ OP_BRNE brne nil nil nil
+ OP_LOADT loadt nil nil nil
+ OP_LOAD0 load0 nil nil nil
+ OP_LOADC1 loadc1 nil nil nil
+ OP_AREF2 aref2 nil nil nil
+ OP_ATOMP atom? 1 (λ (x) (atom? x)) nil
+ OP_LOADVOID loadvoid nil nil nil
+ OP_BRNN brnn nil nil nil
+ OP_LOAD1 load1 nil nil nil
+ OP_LT < -1 (λ rest (apply < rest)) nil
+ OP_ADD2 add2 nil nil nil
+ OP_SETCDR set-cdr! 2 (λ (x y) (set-cdr! x y)) nil
+ OP_KEYARGS keyargs nil nil nil
+ OP_CONS cons 2 (λ (x y) (cons x y)) nil
+ OP_EQ eq? 2 (λ (x y) (eq? x y)) nil
+ OP_SYMBOLP symbol? 1 (λ (x) (symbol? x)) nil
+ OP_NOT not 1 (λ (x) (not x)) nil
+ OP_CADR cadr 1 (λ (x) (cadr x)) nil
+ OP_NEG neg nil nil nil
+ OP_NANP nan? 1 (λ (x) (nan? x)) nil
+ OP_BRBOUND brbound nil nil nil
+ OP_NUMBERP number? 1 (λ (x) (number? x)) nil
+ OP_FIXNUMP fixnum? 1 (λ (x) (fixnum? x)) nil
+ OP_BOUNDP bound? 1 (λ (x) (bound? x)) nil
+ OP_BUILTINP builtin? 1 (λ (x) (builtin? x)) nil
+ OP_FUNCTIONP function? 1 (λ (x) (function? x)) nil
+ OP_VECTORP vector? 1 (λ (x) (vector? x)) nil
+ OP_SHIFT shift nil nil nil
+ OP_SETCAR set-car! 2 (λ (x y) (set-car! x y)) nil
+ OP_JMPL jmp.l nil nil nil
+ OP_BRNL brn.l nil nil nil
+ OP_BOX box nil nil nil
+ OP_EQV eqv? 2 (λ (x y) (eqv? x y)) nil
+ OP_EQUAL equal? 2 (λ (x y) (equal? x y)) nil
+ OP_LIST list ANYARGS (λ rest rest) nil
+ OP_APPLY apply -2 (λ rest (apply apply rest)) nil
OP_ADD + ANYARGS (λ rest (apply + rest)) (
((number…) "Return sum of the numbers or 0 with no arguments."))
- OP_SUB - -1 (λ rest (apply - rest)) ()
+ OP_SUB - -1 (λ rest (apply - rest)) nil
OP_MUL * ANYARGS (λ rest (apply * rest)) (
((number…) "Return product of the numbers or 1 with no arguments."))
- OP_DIV / -1 (λ rest (apply / rest)) ()
- OP_IDIV div0 2 (λ rest (apply div0 rest)) ()
- OP_NUMEQ = -1 (λ rest (apply = rest)) ()
- OP_COMPARE compare 2 (λ (x y) (compare x y)) ()
- OP_ARGC argc #f 0 ()
- OP_VECTOR vector ANYARGS (λ rest (apply vector rest)) ()
- OP_ASET aset! -3 (λ rest (apply aset! rest)) ()
- OP_LOADNIL loadnil #f 0 ()
- OP_LOADI8 loadi8 #f 0 ()
- OP_LOADVL loadv.l #f 0 ()
- OP_LOADGL loadg.l #f 0 ()
- OP_LOADAL loada.l #f 0 ()
- OP_LOADCL loadc.l #f 0 ()
- OP_SETG setg #f 0 ()
- OP_SETGL setg.l #f 0 ()
- OP_SETAL seta.l #f 0 ()
- OP_VARGC vargc #f 0 ()
- OP_TRYCATCH trycatch #f 0 ()
- OP_FOR for 3 (λ (a b f) (for a b (λ (x) (f x)))) ()
- OP_TAPPLY tapply #f 0 ()
- OP_SUB2 sub2 #f 0 ()
- OP_LARGC largc #f 0 ()
- OP_LVARGC lvargc #f 0 ()
- OP_CALLL call.l #f 0 ()
- OP_TCALLL tcall.l #f 0 ()
- OP_BRNEL brne.l #f 0 ()
- OP_BRNNL brnn.l #f 0 ()
- OP_BRN brn #f 0 ()
- OP_BRNL brn.l #f 0 ()
- OP_OPTARGS optargs #f 0 ()
- OP_BRBOUND brbound #f 0 ()
- OP_KEYARGS keyargs #f 0 ()
- OP_BOX box #f 0 ()
- OP_BOXL box.l #f 0 ()
- OP_AREF aref -2 (λ rest (apply aref rest)) ()
- OP_LOADVOID loadvoid #f 0 ()
- OP_NANP nan? 1 (λ (x) (nan? x)) ()
- OP_EOF_OBJECT dummy_eof #f 0 ()
+ OP_DIV / -1 (λ rest (apply / rest)) nil
+ OP_IDIV div0 2 (λ rest (apply div0 rest)) nil
+ OP_NUMEQ = -1 (λ rest (apply = rest)) nil
+ OP_COMPARE compare 2 (λ (x y) (compare x y)) nil
+ OP_ARGC argc nil nil nil
+ OP_VECTOR vector ANYARGS (λ rest (apply vector rest)) nil
+ OP_ASET aset! -3 (λ rest (apply aset! rest)) nil
+ OP_LOADNIL loadnil nil nil nil
+ OP_LOADI8 loadi8 nil nil nil
+ OP_LOADVL loadv.l nil nil nil
+ OP_LOADGL loadg.l nil nil nil
+ OP_LOADAL loada.l nil nil nil
+ OP_LOADCL loadc.l nil nil nil
+ OP_SETG setg nil nil nil
+ OP_SETGL setg.l nil nil nil
+ OP_SETAL seta.l nil nil nil
+ OP_VARGC vargc nil nil nil
+ OP_TRYCATCH trycatch nil nil nil
+ OP_FOR for 3 (λ (a b f) (for a b (λ (x) (f x)))) nil
+ OP_TAPPLY tapply nil nil nil
+ OP_SUB2 sub2 nil nil nil
+ OP_LARGC largc nil nil nil
+ OP_LVARGC lvargc nil nil nil
+ OP_CALLL call.l nil nil nil
+ OP_TCALLL tcall.l nil nil nil
+ OP_BRNEL brne.l nil nil nil
+ OP_BRNNL brnn.l nil nil nil
+ OP_AREF aref -2 (λ rest (apply aref rest)) nil
+ OP_BOXL box.l nil nil nil
+ OP_OPTARGS optargs nil nil nil
+ OP_EOF_OBJECT dummy_eof nil nil nil
))
(def (for-each-n f lst n)