syslisp-syntax.red 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. %
  2. % SYSLISP-SYNTAX.RED - SMacros and redefinition of arithmetic operators
  3. % and other syslisp syntax
  4. %
  5. % Author: Eric Benson and M. L. griss
  6. % Symbolic Computation Group
  7. % Computer Science Dept.
  8. % University of Utah
  9. % Date: 11 July 1981
  10. % Copyright (c) 1981 University of Utah
  11. %
  12. % <PSL.COMP>SYSLISP-SYNTAX.RED.2, 30-Mar-83 11:05:36, Edit by KENDZIERSKI
  13. % Included the text from syslisp-syntax.build at the beginning of this file.
  14. % The file names w/extensions were too large for the VAX to deal with.
  15. % <PSL.COMP>SYSLISP-SYNTAX.RED.3, 5-May-82 11:33:48, Edit by BENSON
  16. % Wrapped if GetD 'BEGIN1 around parser calls
  17. CompileTime << off UserMode; >>;
  18. fluid '(!*SYSLISP);
  19. % New WDECLARE constructs
  20. % Modify ***** [] vector syntax for PREFIX and INFIX forms
  21. % At lower prec
  22. SYMBOLIC PROCEDURE ParseLVEC(VNAME,VEXPR);
  23. IF OP EQ '!*RVEC!* THEN <<OP :=SCAN(); LIST('INDX,VNAME,VEXPR)>>
  24. ELSE PARERR("Missing ] in index expression ");
  25. % Use normal parsing, then CLEAN
  26. SYMBOLIC PROCEDURE ParseWDEC0(FN,DMODES,DLIST);
  27. BEGIN SCALAR PLIST;
  28. IF EQCAR(DLIST,'!*COMMA!*) THEN DLIST:=REVERSE CDR DLIST
  29. ELSE DLIST:=LIST DLIST;
  30. PLIST:=FOR EACH DEC IN DLIST COLLECT ParseWDEC1(FN,DEC);
  31. RETURN ('WDECLARE . DMODES . FN . REVERSE PLIST);
  32. END;
  33. SYMBOLIC PROCEDURE ParseWDEC1(FN,DEC);
  34. % Process each WDEC to check legal modes
  35. if EqCar(DEC,'EQUAL) THEN
  36. AConc(ParseWDEC2(FN,CADR DEC), ParseWDEC3(FN,CADDR DEC))
  37. ELSE AConc(ParseWDEC2(FN,DEC), NIL);
  38. SYMBOLIC PROCEDURE ParseWDEC2(FN,X);
  39. % Remove INDXs from LHS of =
  40. IF IDP X THEN list(X, NIL)
  41. ELSE IF EQCAR(X,'INDX) THEN LIST(CADR X,CADDR X)
  42. ELSE PARERR "Only [] allowed on LHS of WDECLARATION";
  43. SYMBOLIC PROCEDURE ParseWDEC3(FN,X);
  44. % Remove INDX's from RHS of =
  45. IF IDP X THEN X
  46. ELSE IF EQCAR(X,'INDX)
  47. THEN (IF CADR X EQ '!*PREFIXVECT!*
  48. THEN REMCOM(CADDR X)
  49. ELSE PARERR("Only [...] is legal INIT in WDECLARE"))
  50. ELSE X;
  51. if not FUnBoundP 'BEGIN1 then << % kludge #+Rlisp
  52. DEFINEBOP('!*LVEC!*,121,5,ParseLVEC);
  53. DEFINEROP('!*LVEC!*,5,ParseLVEC('!*PREFIXVECT!*,X));
  54. DEFINEBOP('!*RVEC!*,4,5);
  55. DEFINEROP('WCONST,1,ParseWDEC0('WCONST,'DEFAULT,X));
  56. DEFINEROP('WVAR,1,ParseWDEC0('WVAR,'DEFAULT,X));
  57. DEFINEROP('WARRAY,1,ParseWDEC0('WARRAY,'DEFAULT,X));
  58. DEFINEROP('WSTRING,1,ParseWDEC0('WSTRING,'DEFAULT,X));
  59. DEFINEBOP('WCONST,1,1,ParseWDEC0('WCONST,X,Y));
  60. DEFINEBOP('WVAR,1,1,ParseWDEC0('WVAR,X,Y));
  61. DEFINEBOP('WARRAY,1,1,ParseWDEC0('WARRAY,X,Y));
  62. DEFINEBOP('WSTRING,1,1,ParseWDEC0('WSTRING,X,Y));
  63. % Operators @ for GetMem, & for Loc
  64. put('!@, 'NewNam, 'GetMem);
  65. put('!&, 'NewNam, 'Loc);
  66. >>;
  67. % SysName hooks for REFORM
  68. REMFLAG('(REFORM),'LOSE);
  69. SYMBOLIC PROCEDURE REFORM U;
  70. IF ATOM U OR CAR U MEMQ '(QUOTE WCONST)
  71. THEN U
  72. ELSE IF CAR U EQ 'COND THEN 'COND . REFORM CDR U
  73. ELSE IF CAR U EQ 'PROG
  74. THEN PROGN(RPLCDX(CDR U,REFORMLIS CDDR U),U)
  75. ELSE IF CAR U EQ 'LAMBDA
  76. THEN PROGN(RPLACA(CDDR U,REFORM CADDR U),U)
  77. ELSE IF CAR U EQ 'FUNCTION AND ATOM CADR U
  78. THEN BEGIN SCALAR X;
  79. IF NULL !*CREF AND (X:= GET(CADR U,'SMACRO))
  80. THEN RETURN LIST('FUNCTION,X)
  81. ELSE IF GET(CADR U,'NMACRO) OR MACROP CADR U
  82. THEN REDERR "MACRO USED AS FUNCTION"
  83. ELSE RETURN U END
  84. % ELSE IF CAR U EQ 'MAT THEN RPLCDX(U,MAPC2(CDR U,FUNCTION REFORM))
  85. ELSE IF ATOM CAR U
  86. THEN BEGIN SCALAR X,Y,FN;
  87. FN := CAR U;
  88. IF (Y := GETD FN) AND CAR Y EQ 'MACRO
  89. AND EXPANDQ FN
  90. THEN RETURN REFORM APPLY(CDR Y,LIST U);
  91. X := REFORMLIS CDR U;
  92. IF NULL IDP FN THEN RETURN(FN . X);
  93. IF !*SYSLISP AND (Y:=GET(FN,'SYSNAME)) THEN <<FN:=Y;U:=FN.CDR U>>;
  94. IF (NULL !*CREF OR EXPANDQ FN)
  95. AND (Y:= GET(FN,'NMACRO))
  96. THEN RETURN
  97. APPLY(Y,IF FLAGP(FN,'NOSPREAD) THEN LIST X ELSE X)
  98. ELSE IF (NULL !*CREF OR EXPANDQ FN)
  99. AND (Y:= GET(FN,'SMACRO))
  100. THEN RETURN SUBLIS(PAIR(CADR Y,X),CADDR Y)
  101. %we could use an atom SUBLIS here (eg, SUBLA);
  102. ELSE RETURN PROGN(RPLCDX(U,X),U)
  103. END
  104. ELSE REFORM CAR U . REFORMLIS CDR U;
  105. RemFlag('(Plus Times), 'NARY)$
  106. DefList('((Plus WPlus2)
  107. (Plus2 WPlus2)
  108. (Minus WMinus)
  109. (Difference WDifference)
  110. (Times WTimes2)
  111. (Times2 WTimes2)
  112. (Quotient WQuotient)
  113. (Remainder WRemainder)
  114. (Mod WRemainder)
  115. (Land WAnd)
  116. (Lor WOr)
  117. (Lxor WXor)
  118. (Lnot WNot)
  119. (LShift WShift)
  120. (LSH WShift)), 'SysName);
  121. DefList('((Neq WNeq)
  122. (Equal WEq)
  123. (Eqn WEq)
  124. (Eq WEq)
  125. (Greaterp WGreaterp)
  126. (Lessp WLessp)
  127. (Geq WGeq)
  128. (Leq WLeq)
  129. (Getv WGetv)
  130. (Indx WGetv)
  131. (Putv WPutv)
  132. (SetIndx WPutv)), 'SysName);
  133. % modification to arithmetic FOR loop for SysLisp
  134. LISP PROCEDURE MKSYSFOR U;
  135. BEGIN SCALAR ACTION,BODY,EXP,INCR,LAB1,LAB2,RESULT,TAIL,VAR,X;
  136. VAR := second second U;
  137. INCR := cddr second U;
  138. if FixP third Incr or WConstEvaluable third Incr then return
  139. ConstantIncrementFor U;
  140. ACTION := first third U;
  141. BODY := second third U;
  142. RESULT := LIST LIST('SETQ,VAR,CAR INCR);
  143. INCR := CDR INCR;
  144. X := LIST('WDIFFERENCE,first INCR,VAR);
  145. IF second INCR NEQ 1 THEN X := LIST('WTIMES2,second INCR,X);
  146. IF NOT ACTION EQ 'DO THEN
  147. REDERR "Only do expected in SysLisp FOR";
  148. LAB1 := GENSYM();
  149. LAB2 := GENSYM();
  150. RESULT := NCONC(RESULT,
  151. LAB1 .
  152. LIST('COND,LIST(LIST('WLESSP,X,0),LIST('GO,LAB2))) .
  153. BODY .
  154. LIST('SETQ,VAR,LIST('WPLUS2,VAR,second INCR)) .
  155. LIST('GO,LAB1) .
  156. LAB2 .
  157. TAIL);
  158. RETURN MKPROG(VAR . EXP,RESULT)
  159. END;
  160. LISP PROCEDURE ConstantIncrementFor U;
  161. BEGIN SCALAR ACTION,BODY,EXP,INCR,LAB1,RESULT,VAR,X,
  162. StepValue, Limit;
  163. VAR := second second U;
  164. INCR := cddr second U;
  165. ACTION := first third U;
  166. BODY := second third U;
  167. RESULT := LIST LIST('SETQ,VAR,CAR INCR);
  168. INCR := CDR INCR;
  169. StepValue := if FixP second Incr then second Incr
  170. else WConstEvaluable second Incr;
  171. Limit := first Incr;
  172. IF NOT ACTION EQ 'DO THEN
  173. REDERR "Only do expected in SysLisp FOR";
  174. LAB1 := GENSYM();
  175. RESULT := NCONC(RESULT,
  176. LAB1 .
  177. LIST('COND,LIST(LIST(if MinusP StepValue then 'WLessP
  178. else 'WGreaterP,
  179. Var,
  180. Limit),'(return 0))) .
  181. BODY .
  182. LIST('SETQ,VAR,LIST('WPLUS2,VAR,StepValue)) .
  183. LIST('GO,LAB1) .
  184. NIL);
  185. RETURN MKPROG(VAR . EXP,RESULT)
  186. END;
  187. LISP PROCEDURE MKFOR1 U;
  188. IF !*SYSLISP THEN MKSYSFOR U ELSE MKLISPFOR U;
  189. PUTD('MKLISPFOR,'EXPR,CDR GETD 'FOR); % grab old FOR definition
  190. macro procedure For U; MkFor1 U; % redefine FOR
  191. END;