1 ;;; -*- Mode: Lisp; Package: Maxima; Syntax: Common-Lisp; Base: 10 -*- ;;;;
2 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3 ;;; The data in this file contains enhancments. ;;;;;
5 ;;; Copyright (c) 1984,1987 by William Schelter,University of Texas ;;;;;
6 ;;; All rights reserved ;;;;;
7 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
8 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
9 ;;; Macros for TRANSL source compilation. ;;;
10 ;;; (c) Copyright 1980 Massachusetts Institute of Technology ;;;
11 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
15 (macsyma-module transm macro
)
17 (defmacro def%tr
(name lambda-list
&body body
&aux definition
)
19 (if (and (null body
) (symbolp lambda-list
))
20 `(def-same%tr
,name
,lambda-list
)
21 `(defun-prop (,name translate
) ,lambda-list
,@body
)))
22 `(eval-when (:compile-toplevel
:execute
:load-toplevel
)
25 (defmacro def-same%tr
(name same-as
)
26 ;; right now MUST be used in the SAME file.
28 (or (get ',same-as
'translate
)
29 (maxima-error "DEF-SAME%TR: ~a has no TRANSLATE property, so I can't make an alias." ',same-as
))
32 ;;; declarations for the TRANSL PACKAGE.
35 ;; The warning and error subsystem.
36 (special tr-abort
; set this T if you want to abort.
37 *translation-msgs-files
*) ; the stream to print messages to.
39 (special *pre-transl-forms
* ; push onto this, gets output first into the transl file.
40 *warned-un-declared-vars
*
43 warned-undefined-variables
48 *untranslated-functions-called
*))
50 (defmacro bind-transl-state
(&rest forms
)
51 ;; this binds all transl state variables to NIL.
52 ;; and binds user-settable variables to themselves.
53 ;; $TR_NUMER for example can be set to TRUE while translating
54 ;; a file, yet will only affect that file.
55 ;; Called in 3 places, for compactness maybe this should be a PROGV
56 ;; which references a list of variables?
57 `(let (*warned-un-declared-vars
*
60 warned-undefined-variables
72 (defun tr-format (sstring &rest argl
&aux strs
)
73 (if (consp *translation-msgs-files
*)
74 (setq strs
*translation-msgs-files
*)
75 (setq strs
(list *translation-msgs-files
*)))
77 do
(apply #'mformat v sstring argl
)))
79 ;; to use in mixing maxima and lisp
84 (bind-transl-state (translate-macexpr-toplevel (second u
)))))
86 (defmacro maset
(val ar
&rest inds
)
87 (if (or (eq ar
'mqapply
)
88 (and (consp ar
) (member 'mqapply ar
:test
#'eq
)))
89 `(marrayset ,val
,(car inds
) ,@(cdr inds
))
92 (setf ,ar
(make-equal-hash-table ,(if (cdr inds
) t nil
))))
93 (maset1 ,val
,ar
,@inds
))))
95 (defmacro maref
(ar &rest inds
)
96 (cond ((or (eql ar
'mqapply
)(and (consp ar
) (member 'mqapply ar
:test
#'eq
)))
97 `(marrayref ,(first inds
) ,@(cdr inds
)))
98 ((consp ar
)`(marrayref ,ar
,(first inds
) ,@(cdr inds
)))
100 `(maref1 ,ar
,@inds
))))