From: rayslava Date: Sat, 19 Jan 2013 19:27:18 +0000 (+0400) Subject: Arithmetic operations on lists X-Git-Url: http://repo.macrolet.net/gitweb/?a=commitdiff_plain;h=3bdebbdae839ed59ce4da43c7e6228a67d9cf6cf;p=jscl.git Arithmetic operations on lists --- diff --git a/ecmalisp.lisp b/ecmalisp.lisp index 7e3cda3..4d42329 100644 --- a/ecmalisp.lisp +++ b/ecmalisp.lisp @@ -1482,10 +1482,19 @@ (type-check (("x" "number" x) ("y" "number" y)) (concat "x" op "y"))) -(define-builtin + (x y) (num-op-num x "+" y)) -(define-builtin - (x y) (num-op-num x "-" y)) -(define-builtin * (x y) (num-op-num x "*" y)) -(define-builtin / (x y) (num-op-num x "/" y)) +(defmacro define-builtin-arithmetic (op) +`(define-raw-builtin ,op (&rest args) + (if args + (let ((res (ls-compile (car args)))) + (dolist (x (cdr args)) + (setq res (num-op-num res ,(symbol-name op) (ls-compile x)))) + res) + "0"))) + +(define-builtin-arithmetic +) +(define-builtin-arithmetic -) +(define-builtin-arithmetic *) +(define-builtin-arithmetic /) (define-builtin mod (x y) (num-op-num x "%" y))