summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Andreas Benkard <matthias@benkard.de>2008-08-03 13:23:53 +0200
committerMatthias Andreas Benkard <matthias@benkard.de>2008-08-03 13:23:53 +0200
commit444eb2efc8c0991e0f08dad7eb38dc0b9d679861 (patch)
treed223385b09573ac8a4f40ba4f455e340603520a9
parent59cb2fc72f27a81e8d40f70e36bf3795caaf0e6d (diff)
Add DECLAIM and PROCLAIM.
-rw-r--r--evaluation.lisp30
-rw-r--r--init.lisp2
2 files changed, 32 insertions, 0 deletions
diff --git a/evaluation.lisp b/evaluation.lisp
new file mode 100644
index 0000000..f59e268
--- /dev/null
+++ b/evaluation.lisp
@@ -0,0 +1,30 @@
+;;; -*- mode: lisp; coding: utf-8 -*-
+;;; Étoilisp/Mulklisp, a Common Lisp subset for the Étoilé runtime.
+;;; Copyright (C) 2008 Matthias Andreas Benkard.
+;;;
+;;; This program is free software: you can redistribute it and/or modify
+;;; it under the terms of the GNU General Public License as published by
+;;; the Free Software Foundation, either version 3 of the License, or (at
+;;; your option) any later version.
+;;;
+;;; This program is distributed in the hope that it will be useful, but
+;;; WITHOUT ANY WARRANTY; without even the implied warranty of
+;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+;;; General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+
+(in-package #:common-lisp)
+
+
+(defmacro declaim (&rest declarations &environment env)
+ `(eval-when (:compile-toplevel :load-toplevel :execute)
+ (proclaim ,@(mapcar (lambda (x) `(quote ,x)) declarations))))
+
+(defun proclaim (&rest declarations)
+ (let ((context (send-by-name (find-objc-class "MLKLexicalContext")
+ "globalContext")))
+ (dolist (x declarations)
+ (send-by-name context "addDeclaration:" x))))
diff --git a/init.lisp b/init.lisp
index 08319d3..cb527fc 100644
--- a/init.lisp
+++ b/init.lisp
@@ -30,6 +30,8 @@
(load "types.lisp")
(load "list-functions-2.lisp")
+(load "evaluation.lisp")
+
(setq *system-initialised-p* t)
(in-package #:common-lisp-user)