123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- %
- % GLTAIL.PSL.4 18 Feb. 1983
- %
- % FILE OF FUNCTIONS FOR COMPATIBILITY WITH PORTABLE STANDARD LISP (PSL)
- % G. NOVAK 20 OCTOBER 1982
- %
- (DE GETDDD (X)
- (COND ((PAIRP (GETD X)) (CDR (GETD X)))
- (T NIL)))
- (DE PUTDDD (FN DEF) (REMD FN) (PUTD FN 'EXPR DEF))
- (DE LISTGET (L PROP)
- (COND ((NOT (PAIRP L)) NIL)
- ((EQ (CAR L) PROP) (CADR L))
- (T (LISTGET (CDDR L) PROP) )) )
- % NOTE -- THIS VERSION OF NLEFT ONLY WORKS FOR N=2.
- (DE NLEFT (L N)
- (COND ((NOT (EQN N 2)) (ERROR 0 N))
- ((NULL L) NIL)
- ((NULL (CDDR L)) L)
- (T (NLEFT (CDR L) N) )) )
- (DE NLISTP (X) (NOT (PAIRP X)))
- (DF COMMENT (X) NIL)
- % ASSUME EVERYTHING UPPER-CASE FOR PSL.
- (DE U-CASEP (X) T)
- (de glucase (x) x)
- % PARTIAL IMPLEMENTATION OF SUBATOM FOR POSITIVE NUMBERS.
- (DE SUBATOM (ATM N M)
- (PROG (LST SZ)
- (setq sz (flatsize2 atm))
- (cond ((minusp n) (setq n (add1 (plus sz n)))))
- (cond ((minusp m) (setq m (add1 (plus sz m)))))
- (COND ((GREATERP M sz)(RETURN NIL)))
- A (COND ((GREATERP N M)(RETURN (AND LST (IMPLODE (REVERSIP LST))))))
- (SETQ LST (CONS (GLNTHCHAR ATM N) LST))
- (COND ((MEMQ (CAR LST) '(!' !, !!))
- (RPLACD LST (CONS (QUOTE !!) (CDR LST))) ))
- (SETQ N (ADD1 N))
- (GO A) ))
- % FIND THE STRING POSITION IN ATOM ATM WHERE A CHARACTER IN THE
- % BIT TABLE BITTBL OCCURS, STARTING WITH CHARACTER N.
- (DE STRPOSL (BITTBL ATM N)
- (PROG (NC)
- (COND ((NULL N)(SETQ N 1)))
- (SETQ NC (FLATSIZE2 ATM))
- A (COND ((GREATERP N NC)(RETURN NIL))
- ((INDX GLSEPBITTBL (id2int (GLNTHCHAR ATM N)))(RETURN N)))
- (SETQ N (ADD1 N))
- (GO A) ))
- % MAKE A BIT TABLE FROM A LIST OF CHARACTERS.
- (DE MAKEBITTABLE (L)
- (PROG ()
- (SETQ GLSEPBITTBL (MkVect 255))
- (MAPC L (FUNCTION (LAMBDA (X)
- (PutV GLSEPBITTBL (id2int X) T) )))
- (RETURN GLSEPBITTBL) ))
- % Fexpr for defining GLISP functions.
- (df dg (x)
- (put (car x) 'gloriginalexpr (cons 'lambda (cdr x)))
- (glputhook (car x)) )
- % Put the hook macro onto a function to cause auto compilation.
- (df glputhook (x)
- (put x 'glcompiled nil)
- (putd x 'macro '(lambda (gldgform)(glhook gldgform))) )
- % Hook for compiling a GLISP function on its first call.
- (de glhook (gldgform) (glcc (car gldgform)) gldgform)
- % Interlisp-style NTHCHAR.
- (de glnthchar (x n)
- (prog (s l)
- (setq s (id2string x))
- (setq l (size s))
- (cond ((minusp n)(setq n (add1 (plus l n))))
- (t (setq n (sub1 n))))
- (cond ((or (minusp n)(greaterp n l))(return nil)))
- (return (int2id (indx s n)))))
- % FIND FIRST ELEMENT OF A LIST FOR WHICH FN IS TRUE
- (DE SOME (L FN)
- (COND ((NULL L) NIL)
- ((APPLY FN (LIST (CAR L))) L)
- (T (SOME (CDR L) FN))))
- % TEST IF FN IS TRUE FOR EVERY ELEMENT OF A LIST
- % SOME and EVERY switched FN and L
- (DE EVERY (L FN)
- (COND ((NULL L) T)
- ((APPLY FN (LIST (CAR L))) (EVERY (CDR L) FN))
- (T NIL)))
- % SUBSET OF A LIST FOR WHICH FN IS TRUE
- (DE SUBSET (L FN)
- (PROG (RESULT)
- A (COND ((NULL L)(RETURN (REVERSIP RESULT)))
- ((APPLY FN (LIST (CAR L)))
- (SETQ RESULT (CONS (CAR L) RESULT))))
- (SETQ L (CDR L))
- (GO A)))
- (DE REMOVE (X L) (DELETE X L))
- % LIST DIFFERENCE X - Y
- (DE LDIFFERENCE (X Y)
- (MAPCAN X (FUNCTION (LAMBDA (Z)
- (COND ((MEMQ Z Y) NIL)
- (T (CONS Z NIL)))))))
- % FIRST A FEW FUNCTION DEFINITIONS.
- % GET FUNCTION DEFINITION FOR THE GLISP COMPILER.
- (DE GLGETD (FN)
- (OR (and (or (null (get fn 'glcompiled))
- (eq (getddd fn) (get fn 'glcompiled)))
- (GET FN 'GLORIGINALEXPR))
- (GETDDD FN)))
- (DE GLGETDB (FN) (GLGETD FN))
- (DE GLAMBDATRAN (GLEXPR)
- (PROG (NEWEXPR)
- (SETQ GLLASTFNCOMPILED FAULTFN)
- (PUT FAULTFN 'GLORIGINALEXPR GLEXPR)
- (COND ((SETQ NEWEXPR (GLCOMP FAULTFN GLEXPR NIL NIL NIL))
- (putddd FAULTFN NEWEXPR)
- (put faultfn 'glcompiled newexpr) ))
- (RETURN NEWEXPR) ))
- (DE GLERROR (FN MSGLST)
- (PROG ()
- (TERPRI)
- (PRIN2 "GLISP error detected by ")
- (PRIN1 FN)
- (PRIN2 " in function ")
- (PRINT FAULTFN)
- (MAPC MSGLST (FUNCTION (LAMBDA (X) (PRIN1 X)(SPACES 1))))
- (TERPRI)
- (PRIN2 "in expression: ")
- (PRINT (CAR EXPRSTACK))
- (TERPRI)
- (PRIN2 "within expression: ")
- (PRINT (CADR EXPRSTACK))
- (COND (GLBREAKONERROR (ERROR 0 (CAR EXPRSTACK))))
- (RETURN (LIST (LIST 'GLERR (LIST 'QUOTE (CAR EXPRSTACK))))) ))
- % PRINT THE RESULT OF GLISP COMPILATION.
- (DE GLP (FN)
- (PROG ()
- (SETQ FN (OR FN GLLASTFNCOMPILED))
- (TERPRI)
- (PRIN2 "GLRESULTTYPE: ")
- (PRINT (GET FN 'GLRESULTTYPE))
- (PRETTYPRINT (GETDDD FN))
- (RETURN FN)))
- % GLISP STRUCTURE EDITOR
- (DE GLEDS (STRNAME)
- (EDITV (GET STRNAME 'GLSTRUCTURE))
- STRNAME)
- % GLISP PROPERTY-LIST EDITOR
- (DE GLED (ATM) (EDITV (PROP ATM)))
- % GLISP FUNCTION EDITOR
- (DE GLEDF (FNNAME)
- (EDITV (GLGETD FNNAME))
- FNNAME)
- (DE KWOTE (X)
- (COND ((NUMBERP X) X)
- (T (LIST (QUOTE QUOTE) X))) )
- % INITIALIZE
- (SETQ GLBASICTYPES '(ATOM INTEGER REAL NUMBER STRING BOOLEAN
- ANYTHING))
- (SETQ GLTYPENAMES '(CONS LIST RECORD LISTOF ALIST ATOM
- OBJECT ATOMOBJECT LISTOBJECT))
- (SETQ GLLISPDIALECT 'PSL)
- (setq globjectnames nil)
- (GLINIT)
|