From: rayslava Date: Sat, 19 Jan 2013 21:11:16 +0000 (+0400) Subject: Comparisons on lists X-Git-Url: http://repo.macrolet.net/gitweb/?a=commitdiff_plain;h=98d94399ef4613cbcc82b23ec5a60781bc2c6a35;p=jscl.git Comparisons on lists --- diff --git a/ecmalisp.lisp b/ecmalisp.lisp index 244d07c..39750b9 100644 --- a/ecmalisp.lisp +++ b/ecmalisp.lisp @@ -1554,11 +1554,24 @@ (define-builtin mod (x y) (num-op-num x "%" y)) -(define-builtin < (x y) (js!bool (num-op-num x "<" y))) -(define-builtin > (x y) (js!bool (num-op-num x ">" y))) -(define-builtin = (x y) (js!bool (num-op-num x "==" y))) -(define-builtin <= (x y) (js!bool (num-op-num x "<=" y))) -(define-builtin >= (x y) (js!bool (num-op-num x ">=" y))) +(defmacro define-builtin-comparison (op sym) + `(define-raw-builtin ,op (&rest args) + (js!bool + (let ((x (car args)) + (res "true")) + (dolist (y (cdr args)) + (setq res (concat "(" + (ls-compile x) " " ,sym " " (ls-compile y) ")" " && " res)) + (setq x y)) + res)))) + +(define-builtin-comparison > ">") +(define-builtin-comparison < "<") +(define-builtin-comparison >= ">=") +(define-builtin-comparison <= "<=") +(define-builtin-comparison = "==") +(define-builtin-comparison equal "==") +(define-builtin-comparison eq "===") (define-builtin numberp (x) (js!bool (concat "(typeof (" x ") == \"number\")"))) @@ -1640,10 +1653,6 @@ (define-builtin lambda-code (x) (concat "(" x ").toString()")) - -(define-builtin eq (x y) (js!bool (concat "(" x " === " y ")"))) -(define-builtin equal (x y) (js!bool (concat "(" x " == " y ")"))) - (define-builtin char-to-string (x) (type-check (("x" "number" x)) "String.fromCharCode(x)"))