1 ;;; ECMAScript for Guile
3 ;; Copyright (C) 2009 Free Software Foundation, Inc.
5 ;; This program is free software; you can redistribute it and/or modify
6 ;; it under the terms of the GNU General Public License as published by
7 ;; the Free Software Foundation; either version 2, or (at your option)
10 ;; This program is distributed in the hope that it will be useful,
11 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
12 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 ;; GNU General Public License for more details.
15 ;; You should have received a copy of the GNU General Public License
16 ;; along with this program; see the file COPYING. If not, write to
17 ;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 ;; Boston, MA 02111-1307, USA.
22 (define-module (language ecmascript impl)
23 #:use-module (oop goops)
24 #:use-module (language ecmascript base)
25 #:use-module (language ecmascript function)
26 #:use-module (language ecmascript array)
27 #:re-export (*undefined* *this* call/this*
28 pget pput pdel has-property?
30 new-object new new-array)
31 #:export (js-init get-this
33 bitwise-not logical-not
39 (define-class <js-global-object> (<js-object>))
40 (define-method (pget (o <js-global-object>) (p <string>))
41 (pget o (string->symbol p)))
42 (define-method (pget (o <js-global-object>) (p <symbol>))
43 (let ((v (module-variable (current-module) p)))
47 (define-method (pput (o <js-global-object>) (p <string>) v)
48 (pput o (string->symbol p) v))
49 (define-method (pput (o <js-global-object>) (p <symbol>) v)
50 (module-define! (current-module) p v))
51 (define-method (prop-attrs (o <js-global-object>) (p <symbol>))
52 (cond ((module-local-variable (current-module) p)
54 ((module-variable (current-module) p)
55 '(DontDelete ReadOnly))
56 (else (next-method))))
57 (define-method (prop-attrs (o <js-global-object>) (p <string>))
58 (prop-attrs o (string->symbol p)))
60 (define (init-js-bindings! mod)
61 (module-define! mod 'NaN +nan.0)
62 (module-define! mod 'Infinity +inf.0)
63 (module-define! mod 'undefined *undefined*)
64 ;; isNAN, isFinite, parseFloat, parseInt, eval
65 ;; decodeURI, decodeURIComponent, encodeURI, encodeURIComponent
66 ;; Object Function Array String Boolean Number Date RegExp Error EvalError
67 ;; RangeError ReferenceError SyntaxError TypeError URIError
68 (module-define! mod 'Object *object-prototype*)
69 (module-define! mod 'Array *array-prototype*))
74 (fluid-set! *this* (make <js-global-object>))
75 (init-js-bindings! (current-module)))))
81 (cond ((eq? x *undefined*) "undefined")
83 ((boolean? x) "boolean")
84 ((number? x) "number")
85 ((string? x) "string")
86 ((procedure? x) "function")
87 ((is-a? x <js-object>) "object")
90 (define bitwise-not lognot)
91 (define (logical-not x)
92 (not (->boolean (->primitive x))))
102 (define-method (+ (a <string>) (b <string>))
105 (define-method (+ (a <string>) b)
106 (string-append a (->string b)))
108 (define-method (+ a (b <string>))
109 (string-append (->string a) b))
111 (define-method (+ a b)
112 (+ (->number a) (->number b)))