home *** CD-ROM | disk | FTP | other *** search
/ ftp.barnyard.co.uk / 2015.02.ftp.barnyard.co.uk.tar / ftp.barnyard.co.uk / cpm / walnut-creek-CDROM / SIMTEL / CPMUG / CPMUG051.ARK / STG2.FLB < prev    next >
Text File  |  1984-04-29  |  48KB  |  991 lines

  1. BEGIN STAGE2.
  2. FLG I = 0.                   SET UP MACRO CHANNEL.
  3. VAL I = 1 + 0.
  4. PTR I = 0 + 0.
  5. READ NEXT I.                 GRAB THE FLAG LINE.
  6. TO 98 IF FLG I NE 0.         QUIT UNLESS ALL IS OK.
  7. VAL A = CHAR.                SOURCE EOL.
  8. PTR A = 8 + 0.               SET UP A VOID TEMPLATE TREE.
  9. STO A = I.                   SAVE THE MACRO CHANNEL SPEC.
  10. FLG B = 2.                   PHASE FLAG.
  11. VAL B = CHAR.                SOURCE PARAMETER FLAG.
  12. VAL C = CHAR.                MCT EOL.
  13. PTR C = 9 + 0.               INITIAL TEXT POINTER.
  14. VAL D = CHAR.                MCT PARAMETER FLAG.
  15. VAL E = CHAR.                ZERO CHARACTER.
  16. PTR E = VAL E.               PREPARE FOR NORMALIZATIONS.
  17. VAL F = CHAR.                SPACE CHARACTER.
  18. PTR F = A + 7.               SET UP A VOID SYMBOL TREE.
  19. STO F = 0.
  20. VAL G = 0 + 0.               RESET THE DIGIT COUNT FOR NUMBER CONVERSION
  21. PTR H = 5 * 7.               10*DESCRIPTOR LENGTH.
  22. FLG J = 1.                   FLAG TO TERMINATE CREATED SYMBOL.
  23. PTR J = 0 + 0.
  24. FLG L = 1.                   END-OF-LINE INDICATOR.
  25. VAL L = 0 - 1.               CARRIAGE RETURN IS -1.
  26. PTR L = 0 + 0.               LOCATION COUNTER.
  27. VAL M = CHAR.                LEFT PARENTHESIS.
  28. PTR M = 0 + 0.               RESET THE SKIP COUNT.
  29. FLG N = 0.                   SET EXPRESSION SIGN POSITIVE.
  30. VAL N = CHAR.                ADDITION OPERATOR.
  31. FLG O = 0.
  32. VAL O = CHAR.                SUBTRACTION OPERATOR.
  33. VAL P = CHAR.                MULTIPLICATION OPERATOR.
  34. VAL Q = CHAR.                DIVISION OPERATOR.
  35. VAL R = CHAR.                RIGHT PARENTHESIS.
  36. PTR R = 0 + 0.               SET NO REPETITION IN PROGRESS.
  37. PTR 4 = 7 + 7.               LENGTH OF TWO DESCRIPTORS.
  38. PTR 8 = F + 7.               POINT TO THE FIRST AVAILABLE SPACE.
  39. TO 01 BY D.                  START WORKING IN EARNEST.
  40. LOC 01.                      ROUTINE TO READ FROM THE INPUT.
  41. GET I = A.                   RECALL THE CHANNEL SPEC.
  42. READ NEXT I.                 GRAB A LINE.
  43. TO 98 IF FLG I NE 0.         GET OUT UNLESS ALL IS OK.
  44. PTR I = C + 0.
  45. VAL Y = 0 + 0.
  46. PTR Y = C + 0.
  47. TO 02 IF PTR M = 0.          SHOULD THIS LINE BE SKIPPED, NO.
  48. PTR M = M - 1.               YES, DROP THE SKIP COUNT
  49. TO 01.                       TRY AGAIN.
  50. LOC 02.                      READING LOOP.
  51. PTR 9 = I + 0.               ADVANCE THE SPACE POINTER.
  52. VAL I = CHAR.                READ THE NEXT CHARACTER.
  53. PTR I = 9 - 7.               POINT TO THE NEXT CHARACTER SPACE.
  54. TO 97 IF PTR 8 GE I.         HAVE WE OVERRUN THE AREA, YES.
  55. STO 9 = I.                   PUT AWAY THE CHARACTER.
  56. TO 04 IF VAL I = L.          WAS THIS A CARRIAGE RETURN, YES.
  57. TO 03 IF VAL I = A.          HAVE WE COMPLETED THE READ, YES.
  58. VAL Y = Y + 1.               BUMP THE INPUT STRING LENGTH.
  59. TO 02 IF VAL I NE B.         NO, IS THIS A PARAMETER FLAG, NO.
  60. PTR B = I + 0.               YES, SET THE PARAMETER POINTER AND
  61. STO 9 = B.                   STORE IT WITH THE PHASE FLAG.
  62. TO 02.
  63. LOC 03.                      READ THE REMAINDER OF THE LINE.
  64. PTR 9 = I + 0.               POINT TO THE FIRST FREE SPACE.
  65. VAL I = CHAR.                GRAB ANOTHER CHARACTER.
  66. PTR I = 9 - 7.               SET A POINTER TO THE NEXT CHARACTER.
  67. STO 9 = I.
  68. TO 97 IF PTR 8 GE I.         HAVE WE RUN OUT OF SPACE, YES.
  69. TO 03 IF VAL I NE L.         WAS THIS A CARRIAGE RETURN, NO.
  70. LOC 04.                      SCANNER.
  71. PTR U = 9 - 7.               SET ALL PARAMETERS UNDEFINED.
  72. STO U = 3.
  73. PTR U = U - 7.
  74. STO U = 3.
  75. PTR U = U - 7.
  76. STO U = 3.
  77. PTR U = U - 7.
  78. STO U = 3.
  79. PTR U = U - 7.
  80. STO U = 3.
  81. PTR U = U - 7.
  82. STO U = 3.
  83. PTR U = U - 7.
  84. STO U = 3.
  85. PTR U = U - 7.
  86. STO U = 3.
  87. PTR V = U - 7.
  88. STO V = 3.
  89. PTR U = V - 7.
  90. PTR 9 = U + 0.               FREE SPACE POINTER.
  91. TO 97 IF PTR 8 GE 9.
  92. GET W = A.                   SET UP THE TEMPLATE TREE POINTER.
  93. GET X = Y.                   GRAB THE FIRST INPUT CHARACTER.
  94. FLG Y = 0.                   SET THE STRING UNDEFINED.
  95. PTR Z = A + 0.               SET THE TREE POINTER TO THE TEMPLATE ROOT.
  96. TO 58 BY B.                  CALL THE SCANNER.
  97. TO 50 IF FLG B = 2.          IS THIS THE DEFINITION PHASE, YES.
  98. TO 56 IF FLG Y = 0.          WAS THERE A DEFINITION, NO.
  99. STO 9 = 1.                   INITIALLY NO CREATED SYMBOLS FOR THIS MACRO
  100. PTR 9 = 9 - H.               SPACE FOR THE CREATED SYMBOLS.
  101. STO 9 = J.                   PREVIOUS PARAMTER POINTER.
  102. PTR J = 9 + H.               SET THE CURRENT PARAMETER POINTER.
  103. PTR 9 = 9 - 7.
  104. STO 9 = C.                   PREVIOUS TEXT POINTER.
  105. PTR 9 = 9 - 7.
  106. STO 9 = D.                   SAVE THE OLD RETURN ADDRESS.
  107. PTR 9 = 9 - 7.
  108. STO 9 = K.                   SAVE THE CURRENT TEXT POINTER.
  109. PTR K = U + 0.               SET UP THE NEW TEXT POINTER.
  110. PTR 9 = 9 - 7.
  111. STO 9 = R.                   SAVE THE OLD REPETITION POINTER.
  112. PTR R = 0 + 0.               SET NO REPETITION IN PROGRESS.
  113. PTR C = 9 - 7.               NEW TEXT POINTER.
  114. TO 97 IF PTR 8 GE C.         IS THE SPACE FULL ALREADY, YES.
  115. TO 05 BY D.                  GO PROCESS THE MCT
  116. LOC 05.                      SUBSTITUTE PARAMETERS IN ONE LINE.
  117. PTR 9 = C + 0.               DISCARD ANY JUNK.
  118. PTR Y = 0 + 0.               RESET THE LOOP COUNTER.
  119. LOC 06.
  120. TO 07 IF PTR M = 0.          SHOULD WE SKIP LINES, NO.
  121. PTR Z = K + 7.               RETAIN THE CODE BODY POSITION.
  122. GET K = K.                   SKIP A LINE.
  123. GET I = K.                   GRAB THE TERMINATOR.
  124. TO 08 IF VAL I = 1.          CHECK FOR THE END OF THE MACRO.
  125. PTR M = M - 1.               DECREMENT THE SKIP COUNT.
  126. GET Z = Z.                   GRAB THE FIRST SKIPPED ELEMENT.
  127. TO 06 IF FLG Z NE 3.         IGNORE NON FUNCTION CALLS.
  128. PTR Y = Y + 1.               BUMP THE COUNT OF LOOPS ENTERED.
  129. TO 06 IF VAL Z = 7.          LEAVE THE INCREM VALUE IF LOOP ENTERED.
  130. PTR Y = Y - 1.               ELSE DROP IT BACK.
  131. TO 06 IF VAL Z NE 8.         NO CHANGE IF NOT LOOP END.
  132. PTR Y = Y - 1.               ELSE DECREMANT THE COUNT
  133. TO 06 IF PTR Y GE 0.         AND GO ON IF SKIPPING AN ENTIRE LOOP.
  134. TO 06 IF PTR R = 0.          OR IF THERE IS NO CURRENT LOOP.
  135. PTR U = R - 7.               ELSE TERMINATE THE LOOP.
  136. GET Y = U.
  137. TO 49 IF FLG Y NE 1.         IS IT COUNT CONTROLLED, NO.
  138. PTR C = R + 0.               YES, RESET THE LINE SPACE POINTER.
  139. GET R = R.                   RESTORE ITERATION POINTER.
  140. TO 05.                       IF NOT, CONTINUE.
  141. LOC 07.                      CHARACTER PROCESSING LOOP.
  142. PTR K = K + 7.               ADVANCE THE POINTER AND
  143. GET I = K.                   FETCH THE NEXT CHARACTER
  144. TO 09 IF FLG I = 2.          IS THIS A PARAMETER CALL, YES.
  145. TO 22 IF FLG I = 3.          NO, IS IT A COMPILER SWITCH, YES.
  146. PTR I = 9 - 7.               NO, SET THE POINTER TO THE NEXT SPACE.
  147. STO 9 = I.                   PUT THE CHARACTER IN THE PSEUDO-INPUT.
  148. PTR 9 = I + 0.               ADVANCE THE SPACE POINTER.
  149. TO 97 IF PTR 8 GE 9.         IS THE SPACE EXHAUSTED, YES.
  150. TO 07 IF FLG I = 0.          WAS THAT THE LAST CHARACTER, NO.
  151. PTR Y = C - 9.               SET THE PSEUDO-INPUT LENGTH.
  152. PTR Y = Y / 7.
  153. PTR Y = Y - 1.
  154. VAL Y = PTR Y.
  155. PTR Y = C + 0.
  156. TO 04 IF VAL I NE 1.         WAS THAT THE END OF THE CODE BODY, NO.
  157. LOC 08.
  158. PTR 9 = J - H.               RESTORE FROM THE CURRENT RECURSION.
  159. GET J = 9.                   PARAMETER POINTER.
  160. PTR 9 = 9 - 7.
  161. GET C = 9.                   TEXT SPACE POINTER.
  162. PTR 9 = 9 - 7.
  163. GET D = 9.                   RETURN ADDRESS.
  164. PTR 9 = 9 - 7.
  165. GET K = 9.                   CODE BODY POINTER.
  166. PTR 9 = 9 - 7.
  167. GET R = 9.                   ITERATION POINTER.
  168. RETURN BY D.
  169. LOC 09.                      DO PARAMETER CONVERSION.
  170. PTR V = J + I.               NO, FIND THE PARAMETER POINTER.
  171. TO 21 IF VAL I = 6.          SET A PARAMETER.
  172. GET Y = V.                   AND LOAD IT.
  173. TO 45 IF VAL I = 7.          INITIATE REPETITION OVER AN ARGUMENT LIST.
  174. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  175. GET X = Y.                   GET THE FIRST CHARACTER.
  176. TO 11 IF VAL I = 0.          COPY CONVERSION.
  177. TO 10 IF VAL I = 1.          SYMBOL REFERENCE.
  178. TO 12 IF VAL I = 2.          LOCATION SYMBOL DEFINITION.
  179. TO 15 IF VAL I = 4.          REQUEST FOR EXPRESSION CONVERSION.
  180. PTR X = Y + 0.
  181. TO 20 IF VAL I = 3.          REQUEST THE BREAK CHARACTER.
  182. PTR N = VAL Y.
  183. TO 18 IF VAL I = 5.          REQUEST FOR PARAMETER LENGTH.
  184. TO 23 IF VAL Y NE 1.         IF NOT ONE CHARACTER, SIGNAL ERROR.
  185. PTR N = VAL X.
  186. TO 18 IF VAL I = 8.          REQUEST FOR INTERNAL REPRESENTATION.
  187. MESSAGE CONV TO 4.           THE CONVERSION DIGIT IS UNAVAILABLE.
  188. TO 94 BY B.                  CALL ERROR TRACEBACK.
  189. TO 07.                       CONTINUE WITH THE LINE.
  190. LOC 10.                      DEAL WITH A LOCATION SYMBOL.
  191. PTR V = 9 + 7.               STACK POINTER FOR SCANNER.
  192. GET W = F.                   SET UP THE SYMBOL TREE.
  193. PTR Z = F + 0.               SET THE TREE POINTER TO THE SYMBOL ROOT.
  194. TO 58 BY B.                  CALL ON THE SCANNER.
  195. TO 07 IF FLG Y NE 1.         WAS THE SYMBOL DEFINED, NO.
  196. FLG I = 0.                   PREPARE TO COPY OVER THE SYMBOL VALUE.
  197. GET X = Y.                   NO, GRAB THE FIRST CHARACTER.
  198. LOC 11.                      COPY A PARAMETER TO THE PSEUDO-INPUT.
  199. TO 07 IF VAL Y = 0.          IS THE PARAMETER VOID, YES.
  200. GET I = X.                   FETCH THE NEXT CHARACTER.
  201. PTR X = 9 - 7.               SET THE POINTER
  202. STO 9 = X.                   AND PUT IT IN THE PSEUDO-INPUT.
  203. PTR 9 = X + 0.               POINT TO THE NEXT FREE SPACE.
  204. VAL Y = Y - 1.               DECREMENT THE CHARACTER COUNT.
  205. TO 07 IF VAL Y = 0.          ARE WE DONE, YES.
  206. GET X = I.                   NO, GET THE NEXT CHARACTER.
  207. PTR I = 9 - 7.               SET ITS POINTER.
  208. STO 9 = I.                   PUT AWAY THE COPY.
  209. PTR 9 = I + 0.               POINT TO THE NEXT FREE SPACE.
  210. TO 97 IF PTR 8 GE 9.         HAVE WE EXHAUSTED THE SPACE, YES.
  211. VAL Y = Y - 1.               NO, DROP THE COUNT OF CHARACTERS.
  212. TO 11.
  213. LOC 12.                      MOVE A DEFINITION TO THE OUTPUT.
  214. FLG B = 2.                   ALLOW SYMBOL DEFINITION.
  215. GET W = F.                   SET UP THE SYMBOL TREE.
  216. PTR Z = F + 0.               SET THE TREE POINTER TO THE SYMBOL ROOT.
  217. TO 58 BY B.                  CALL ON THE SCANNER.
  218. FLG B = 0.                   EXIT THE DEFINITION PHASE.
  219. GET X = Y.
  220. TO 11 IF FLG Y = 1.          IS THIS A NEW SYMBOL, NO.
  221. PTR Y = 8 + 0.               YES, SET UP THE DEFINITION POINTER.
  222. FLG Y = 1.                   MARK IT AS HAVING BEEN DEFINED.
  223. PTR L = L + 1.               BUMP THE LOCATION COUNTER
  224. PTR X = L + 0.               AND INSERT IT AS THE DEFINITION.
  225. PTR W = 9 + 7.               USE STORE AT THE TOP AS TEMPORARY.
  226. VAL Y = 0 + 0.               COUNT THE DIGITS.
  227. LOC 13.                      CONVERT ONE DIGIT AT A TIME.
  228. PTR V = X / 5.               GET THE QUOTIENT BY INTEGER DIVISION.
  229. PTR Z = V * 5.               THE REMAINDER MUST BE FOUND BY MULTIPLYING
  230. PTR X = X - Z.               AND THEN SUBTRACTING.
  231. VAL X = PTR X.               MOVE THE RESULT TO THE VALUE FIELD.
  232. PTR X = V + 0.               THE QUOTIENT IS TO BE OPERATED ON NEXT.
  233. PTR W = W - 7.               ADVANCE THE TEMPORARY STORAGE POINTER.
  234. STO W = X.                   AND SALT AWAY THE RESULT.
  235. VAL Y = Y + 1.               BUMP THE DIGIT COUNT.
  236. TO 97 IF PTR 8 GE W.         HAVE WE RUN OUT OF ROOM, YES.
  237. TO 13 IF PTR X NE 0.         NO, MUST WE GO ON, YES.
  238. LOC 14.                      MOVE THE DIGITS TO THEIR DESTINATION.
  239. GET X = W.                   RECOVER A POSSIBLE DIGIT.
  240. PTR W = W + 7.               MOVE THE DIGIT POINTER BACK.
  241. VAL X = X + E.               MAKE THE DIGITS INTO CHARACTERS
  242. PTR X = 8 + 7.               SET UP A POINTER TO THE NEXT SPACE.
  243. STO 8 = X.                   PUT AWAY THE CHARACTER.
  244. PTR 8 = X + 0.               BUMP THE SPACE POINTER.
  245. TO 14 IF PTR 9 GE W.         DID WE REALLY HAVE ANOTHER DIGIT, YES.
  246. STO 8 = 0.                   PUT IN THE TERMINATOR.
  247. PTR 8 = 8 + 7.               ADVANCE THE SPACE POINTER.
  248. TO 97 IF PTR 8 GE 9.
  249. STO U = Y.                   PUT AWAY THE POINTER TO THE DEFINITION.
  250. GET X = Y.                   PICK UP THE FIRST CHAR OF THE DEFINITION.
  251. FLG I = 0.                   CLEAN OUT THE INPUT BUFFER.
  252. TO 11.                       COPY OUT THE VALUE.
  253. LOC 15.                      PROCESS AN EXPRESSION PARAMETER.
  254. TO 74 BY P.                  EVALUATE THE EXPRESSION.
  255. TO 18 IF PTR N GE 0.         AND TEST FOR NON-NEGATIVE.
  256. PTR O = 9 - 7.               IF NEGATIVE, INSERT A MINUS SIGN.
  257. TO 97 IF PTR 8 GE O.
  258. STO 9 = O.
  259. PTR 9 = O + 0.
  260. PTR N = 0 - N.               MAKE THE NUMBER POSITIVE AND
  261. TO 18.                       STORE DOWN.
  262. LOC 16.                      CONVERSION OF PARAMETER ZERO (LOC. CNTR.)
  263. GET Y = V.                   GRAB THE NEXT CREATED SYMBOL.
  264. TO 17 IF FLG Y = 1.          IS THIS A SYMBOL, NO.
  265. PTR V = V - 7.               YES, ADVANCE THE CREATED SYMBOL POINTER.
  266. TO 16 IF VAL Y NE I.         IS THIS THE RIGHT SYMBOL, NO.
  267. PTR N = Y + 0.               YES, SET UP ITS VALUE
  268. TO 18.                       AND INSERT IT IN THE LINE
  269. LOC 17.                      CREATE A NEW SYMBOL.
  270. PTR Y = V + H.               CHECK THAT THERE IS ROOM FOR IT.
  271. TO 23 IF PTR Y = J.          IF NOT, TREAT AS A CONVERSION ERROR.
  272. PTR L = L + 1.               BUMP THE LOCATION COUNTER.
  273. PTR I = L + 0.               SAVE THE NEW VALUE IN THE NEXT SPACE.
  274. STO V = I.
  275. PTR V = V - 7.               FLAG THE NEXT ENTRY AS NO SYMBOL.
  276. GET Y = V.
  277. FLG Y = 1.
  278. STO V = Y.
  279. PTR N = L + 0.               SET UP THE NUMBER TO BE CONVERTED.
  280. LOC 18.                      CONVERT PTR X TO CHARACTERS, STORE DOWN.
  281. PTR Y = N / 5.               GET THE QUOTIENT BY INTEGER DIVISION.
  282. PTR Z = Y * 5.               THE REMAINDER MUST BE FOUND BY MULTIPLYING
  283. PTR X = N - Z.               AND THEN SUBTRACTING.
  284. FLG X = 0.
  285. VAL X = PTR X.               MOVE THE RESULT TO THE VALUE FIELD.
  286. PTR N = Y + 0.               THE QUOTIENT IS TO BE OPERATED ON NEXT.
  287. VAL G = G + 1.               ADVANCE THE TEMPORARY STORAGE COUNT.
  288. PTR 8 = 8 + 7.
  289. STO 8 = X.                   AND SALT AWAY THE RESULT.
  290. TO 18 IF PTR N NE 0.         NO, MUST WE GO ON, YES.
  291. LOC 19.                      MOVE THE DIGITS TO THEIR DESTINATION.
  292. GET X = 8.                   RECOVER A POSSIBLE DIGIT.
  293. PTR 8 = 8 - 7.               MOVE THE DIGIT POINTER BACK.
  294. VAL G = G - 1.
  295. VAL X = X + E.               MAKE THE DIGITS INTO CHARACTERS.
  296. PTR X = 9 - 7.               SET UP A POINTER TO THE NEXT SPACE.
  297. STO 9 = X.                   PUT AWAY THE CHARACTER.
  298. PTR 9 = X + 0.               DROP THE SPACE POINTER.
  299. TO 19 IF VAL G NE 0.         DID WE REALLY HAVE ANOTHER DIGIT, YES.
  300. TO 07.                       NO, GO BACK TO THE LINE PROCESSOR.
  301. LOC 20.                      ADVANCE TO A BREAK CHARACTER.
  302. GET X = X.                   GET THE NEXT CHARACTER
  303. VAL Y = Y - 1.               AND DROP THE NUMBER REMAINING.
  304. TO 20 IF VAL Y NE L.         WAS THAT THE BREAK, NO.
  305. TO 07 IF FLG X = 1.          END-OF-LINE IS THE NULL BREAK.
  306. PTR X = 9 - 7.               SET THE POINTER
  307. TO 97 IF PTR 8 GE X.
  308. STO 9 = X.                   AND PUT AWAY THE BREAK CHARACTER.
  309. PTR 9 = X + 0.
  310. TO 07.
  311. LOC 21.                      SET A PARAMETER.
  312. STO 9 = L.                   TERMINATE THE CURRENT LINE.
  313. PTR K = K + 7.               BYPASS THE NEXT CHARACTER.
  314. PTR Y = C - 9.               SET UP THE SPECIFICATION OF THE
  315. PTR Y = Y / 7.               CURRENT STRING.
  316. FLG Y = 0.
  317. VAL Y = PTR Y.               LENGTH IN CHARACTERS.
  318. PTR Y = C + 0.               POINTER TO THE FIRST CHARACTER.
  319. STO V = Y.                   SET THE PARAMETER STORE.
  320. PTR C = 9 - 7.               NEXT EMPTY SPACE FOR NEW LINE.
  321. TO 05.
  322. LOC 22.                      DECODE COMPILER SWITCHES.
  323. PTR V = J + 0.               SET A PARAMETER POINTER.
  324. TO 16 IF PTR I = 0.          IS THIS A CALL ON PARAMETER ZERO, YES.
  325. TO 08 IF VAL I = 9.          ESCAPE FROM THE CURRENT MACRO.
  326. PTR V = V + 7.               ADVANCE THE PARAMETER POINTER.
  327. PTR K = K + 7.               BYPASS THE CHARACTER FOLLOWING THE SWITCH.
  328. TO 32 IF VAL I = 1.          OUTPUT A LINE WITHOUT RESCANNING.
  329. TO 32 IF VAL I = 2.          CHANGE I/O UNITS AND COPY.
  330. TO 33 IF VAL I = 3.          REDEFINE A SYMBOL.
  331. TO 42 IF VAL I = 4.          SKIP ARG 1 LINES UNCONDITIONALLY.
  332. TO 36 IF VAL I = 5.          COMPARE ARG 1 AND ARG 2 AS STRINGS.
  333. TO 39 IF VAL I = 6.          COMPARE ARG 1 AND ARG 2 AS EXPRESSIONS.
  334. TO 43 IF VAL I = 7.          INITIATE A REPETITION UNDER COUNT CONTROL.
  335. TO 47 IF VAL I = 8.          ADVANCE TO THE NEXT MEMBER OF THE LIST.
  336. TO 23 IF VAL I NE 0.         IF NOT A REQUEST FOR TERMINATION, COMPLAIN
  337. STOP.                        ELSE TERMINATE NORMALLY.
  338. LOC 23.                      ERROR IN CONVERSION DIGIT.
  339. MESSAGE CONV TO 4.           PUT OUT THE MESSAGE.
  340. TO 94 BY B.                  PRODUCE A TRACEBACK
  341. TO 07.                       AND THEN CONTINUE.
  342. LOC 32.                      CHECK FOR ALTERNATE OUTPUT UNIT.
  343. GET X = K.                   THIS MIGHT BE A CHANNEL NUMBER.
  344. VAL W = 3 + 0.               THE DEFAULT OUTPUT CHANNEL IS 3.
  345. TO 24 IF FLG X = 1.          IF NO CHANNEL NUMBER, TAKE THE DEFAULT.
  346. PTR K = K + 7.               ELSE ADVANCE THE CODE BODY POINTER.
  347. VAL W = X - E.               CONVERT THE DIGIT TO AN INTEGER.
  348. GET X = K.                   CHECK FOR REWIND REQUEST.
  349. TO 24 IF FLG X = 1.          IF NONE, CONTINUE.
  350. REWIND W.                    ELSE REWIND THE OUTPUT CHANNEL.
  351. PTR K = K + 7.               AND ADVANCE THE CODE BODY POINTER.
  352. LOC 24.
  353. TO 31 IF VAL I = 2.          INITIATE BLOCK COPYING.
  354. STO 9 = L.                   TERMINATE THE CURRENT LINE.
  355. PTR X = C + 0.               POINT TO THE START OF THE LINE.
  356. TO 57 IF PTR C NE 9.         PUNCH IT IF IT EXISTS.
  357. PTR K = K + 7.
  358. GET I = K.                   GET THE NEXT COLUMN.
  359. TO 25 IF FLG I NE 1.         CONTINUE IF THIS LINE IS VALID.
  360. PTR K = K - 7.               ELSE BACKSPACE THE CODE BODY
  361. TO 23.                       AND ISSUE AN ERROR MESSAGE.
  362. LOC 25.
  363. PTR Z = VAL I.
  364. PTR Z = Z - E.               SUBTRACT THE CHARACTER ZERO.
  365. TO 28 IF PTR Z GE 5.         CHECK FOR DIGIT.
  366. TO 28 IF PTR 0 GE Z.
  367. VAL X = I + 0.               IF SO, SAVE FOR FUTURE REFERENCE.
  368. PTR Z = Z * 7.               COMPUTE THE PARAMETER LOCATION
  369. PTR Y = J + Z.               AND GRAB ITS SPECIFICATION.
  370. GET Y = Y.
  371. TO 27 IF FLG Y = 3.          TREAT AN UNDEFINED PARAMETER AS VOID.
  372. GET Z = Y.                   PICK UP THE FIRST CHARACTER.
  373. LOC 26.
  374. TO 27 IF VAL Y = 0.          IS THE PARAMETER VOID, YES.
  375. CHAR = VAL Z.                NO, OUTPUT A CHARACTER.
  376. GET Z = Z.                   PICK UP THE NEXT CHARACTER OF THE PARAMETER
  377. VAL Y = Y - 1.               AND DROP THE NUMBER REMAINING.
  378. PTR K = K + 7.               ADVANCE THE POINTER.
  379. GET I = K.                   GRAB THE NEXT CHARACTER OF THE CODE BODY
  380. TO 26 IF VAL I = X.          IS IT THE SAME DIGIT, YES.
  381. TO 25.
  382. LOC 27.                      FILL A FIELD WITH SPACES.
  383. CHAR = VAL F.
  384. PTR K = K + 7.
  385. GET I = K.
  386. TO 27 IF VAL I = X.
  387. TO 25.
  388. LOC 28.                      COPY A NON-PARAMETER TO THE OUTPUT.
  389. TO 57 IF FLG I = 1.          QUIT AT THE END OF THE LINE.
  390. CHAR = VAL I.
  391. PTR K = K + 7.               ELSE ADVANCE ALONG THE CODE BODY.
  392. GET I = K.
  393. TO 25.
  394. LOC 31.                      CHECK FOR ALTERNATE INPUT UNIT.
  395. GET I = A.                   RECALL THE CHANNEL SPEC.
  396. TO 29 IF PTR C = 9.          IF NO ALTERNATE INPUT UNIT, CONTINUE.
  397. GET X = C.                   ELSE GRAB THE UNIT NUMBER
  398. VAL I = X - E.               AND CONVERT IT TO AN INTEGER.
  399. STO A = I.                   CHANGE THE CURRENT UNIT IN STORE.
  400. TO 29 IF PTR X = 9.          IF NO REWIND REQUEST, CONTINUE.
  401. REWIND I.                    ELSE PERFORM THE REWIND
  402. TO 98 IF FLG I NE 0.         AND QUIT UNLESS IT WAS ALL OK.
  403. LOC 29.                      BLOCK COPY FROM INPUT TO OUTPUT.
  404. GET X = V.                   PICK UP THE PARAMETER SPECIFICATION.
  405. TO 05 IF VAL X = 0.          NO COPYING IF PARAMETER IS VOID.
  406. TO 05 IF FLG X = 3.          OR UNDEFINED.
  407. PTR Y = X + 0.               ELSE SET UP THE ADDRESS OF THE FIRST CHAR.
  408. READ NEXT I.                 GET THE NEXT LINE.
  409. TO 05 IF FLG I = 1.          QUIT ON ENDFILE
  410. TO 98 IF FLG I NE 0.         GET OUT UNLESS ALL IS OK.
  411. LOC 30.                      CHECK FOR THE TERMINATOR.
  412. TO 05 IF VAL X = 0.          RETURN IF THE MATCH IS COMPLETE.
  413. VAL X = X - 1.               ELSE DECREMENT THE CHARACTER COUNT
  414. GET Y = Y.                   PICK UP THE NEXT TERMINATOR CHARACTER.
  415. VAL Z = CHAR.                AND INPUT CHARACTER.
  416. TO 30 IF VAL Y = Z.          IF WE ARE STILL MATCHING, GO ON.
  417. WRITE NEXT W.                ELSE WRITE THE LINE
  418. TO 29 IF FLG W = 0.          AND KEEP LOOKING FOR THE TERMINATOR IF OK.
  419. TO 98.                       ELSE I/O ERROR MESSAGE AND QUIT
  420. LOC 33.                      REDEFINE A SYMBOL.
  421. GET Y = V.                   NAME OF THE SYMBOL TO BE REDEFINED.
  422. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  423. TO 05 IF VAL Y = 0.          IGNORE THE NULL SYMBOL.
  424. GET X = Y.                   PICK UP THE FIRST CHARACTER.
  425. FLG B = 2.                   ALLOW SYMBOL ENTRY.
  426. GET W = F.                   SET UP THE SYMBOL TREE.
  427. PTR Z = F + 0.               SET THE TREE POINTER TO THE SYMBOL ROOT.
  428. TO 58 BY B.                  CALL ON THE SCANNER.
  429. FLG B = 0.                   RESET PHASE FLAG.
  430. FLG W = Y.                   SAVE THE DEFINITION FLAG.
  431. PTR W = U + 0.               POINT TO THE DEFINITION POINTER.
  432. PTR Z = Y + 0.               SET THE SYMBOL POINTER
  433. PTR V = V + 7.               GET THE NEW DEFINITION OF THE SYMBOL.
  434. GET Y = V.
  435. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  436. PTR X = Y + 0.               POINT TO THE FIRST CHARACTER OF THE
  437. FLG Z = 1.                   NEW DEFINITION.  CLEAR OUT THE TEMPORARY
  438. VAL Z = Y + 0.               SET THE NEW SYMBOL LENGTH.
  439. TO 35 IF FLG W NE 1.         WAS THERE A DEFINITION, NO.
  440. STO W = Z.                   YES, STORE THE NEW SYMBOL LENGTH.
  441. TO 05 IF VAL Y = 0.          IS THE DEFINITION VOID, NO.
  442. LOC 34.                      INSERT THE NEW DEFINITION IN THE OLD SPACE.
  443. GET X = X.                   GET THE NEXT DEFINITION CHARACTER.
  444. PTR W = Z + 0.               POINT TO THE NEXT SPACE.
  445. GET Z = W.                   GRAB THE OLD CONTENTS OF THE SPACE.
  446. VAL Z = X + 0.               MOVE THE CHARACTER INTO THE SPACE,
  447. STO W = Z.                   RETAINING THE OLD POINTER VALUE.
  448. VAL Y = Y - 1.               DECREMENT THE CHARACTER COUNT.
  449. TO 35 IF PTR Z = 0.          IS THERE MORE SPACE AVAILABLE, NO.
  450. TO 34 IF VAL Y NE 0.         YES, IS THERE MORE DEFINITION, YES.
  451. TO 05.
  452. LOC 35.                      CREATE NEW SPACE FOR THE DEFINITION.
  453. PTR Z = 8 + 0.               POINT TO THE NEXT AVAILABLE SPACE.
  454. STO W = Z.                   PUT AWAY THE CHARACTER.
  455. PTR 8 = 8 + 7.               ADVANCE THE POINTER
  456. TO 97 IF PTR 8 GE 9.         AND TEST FOR SPACE OVERFILL.
  457. PTR W = Z + 0.               ADVANCE THE CHARACTER POINTER.
  458. GET Z = X.                   GRAB THE NEXT DEFINITION CHARACTER.
  459. PTR X = Z + 0.               ADVANCE THE DEFINITION POINTER.
  460. VAL Y = Y - 1.               DECREMENT THE CHARACTER COUNT.
  461. TO 35 IF VAL Y NE L.         CHECK FOR TERMINATION OF THE DEFINITION.
  462. STO W = 0.                   STORE THE TERMINATOR IF THERE IS NO MORE.
  463. TO 05.
  464. LOC 36.                      COMPARE TWO STRINGS.
  465. GET I = K.                   PICK UP THE CONDITION CODE.
  466. TO 23 IF FLG I NE 0.         COMPLAIN IF ILLEGAL CONDITION CODE
  467. PTR K = K + 7.               BYPASS THE NEXT CHARACTER.
  468. GET Y = V.
  469. PTR V = V + 7.
  470. GET Z = V.
  471. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  472. TO 23 IF FLG Z = 3.
  473. PTR V = V + 7.               OTHERWISE PICK UP THE THIRD ARGUMENT
  474. TO 41 IF VAL Y NE Z.         COULD THEY BE EQUAL, NO.
  475. TO 38 IF VAL Y = 0.          TWO NULL STRINGS ARE EQUAL.
  476. PTR X = Z + 0.               POINT X TO THE SECOND STRING.
  477. LOC 37.                      COMPARE THE STRINGS CHARACTER BY CHARACTER.
  478. GET X = X.                   GRAB THE NEXT CHARACTER OF EACH STRING.
  479. GET Y = Y.
  480. TO 41 IF VAL X NE Y.         ARE THEY EQUAL, NO.
  481. VAL Z = Z - 1.               YES, DROP THE NUMBER REMAINING.
  482. TO 37 IF VAL Z NE 0.         ARE WE DONE, NO.
  483. LOC 38.                      THE STRINGS ARE EQUAL.
  484. TO 05 IF VAL I NE E.         IS THE CONDITON CODE EQ, NO.
  485. TO 42.
  486. LOC 39.                      COMPARE TWO EXPRESSIONS.
  487. GET I = K.                   PICK UP THE CONDITION CODE.
  488. TO 23 IF FLG I NE 0.         COMPLAIN IF ILLEGAL CONDITION CODE
  489. PTR K = K + 7.               BYPASS THE NEXT CHARACTER.
  490. GET Y = V.                   FIRST ARGUMENT SPECIFICATION.
  491. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  492. TO 74 BY P.                  EVALUATE THE FIRST PARAMETER.
  493. PTR I = N + 0.               SAVE THE VALUE OF THE FIRST EXPRESSION.
  494. PTR V = J + 4.
  495. GET Y = V.                   SET UP THE SECOND PARAMETER.
  496. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  497. TO 74 BY P.                  EVALUATE IT.
  498. PTR V = J + 4.
  499. PTR V = V + 7.
  500. PTR N = N - I.               COMPUTE THE DIFFERENCE.
  501. TO 38 IF PTR N = 0.          WERE THE PARAMETERS EQUAL, YES.
  502. TO 40 IF PTR N GE 0.         NO, WAS THE SECOND LARGER, YES.
  503. TO 05 IF VAL I = O.          NO, WAS THE CONDITION LT, YES.
  504. TO 41.
  505. LOC 40.                      PARAMETER 1 LT PARAMETER 2.
  506. TO 05 IF VAL I = N.           WAS THE CONDITION GT, YES.
  507. LOC 41.                      THE STRINGS ARE NOT EQUAL.
  508. TO 05 IF VAL I = E.          IS THE CONDITION CODE EQ, YES.
  509. LOC 42.                      SET UP THE SKIP COUNTER.
  510. GET Y = V.
  511. TO 23 IF FLG Y = 3.          ERROR IF PARAMETER IS UNDEFINED.
  512. TO 05 IF VAL Y = 0.          IS IT VOID, YES.
  513. TO 74 BY P.                  CONVERT A POSSIBLE EXPRESSION.
  514. PTR M = N + 0.               SET THE COUNT.
  515. TO 05.
  516. LOC 43.                      ITERATE UNDER COUNT CONTROL.
  517. PTR Y = C - 9.               SET UP THE SPECIFICATION OF THE
  518. PTR Y = Y / 7.               CURRENT STRING.
  519. VAL Y = PTR Y.               LENGTH IN CHARACTERS.
  520. TO 07 IF VAL Y = 0.          IF NULL, IGNORE IT.
  521. PTR Y = C + 0.               POINTER TO THE FIRST CHARACTER.
  522. TO 74 BY P.                  EVALUATE THE LINE AS AN EXPRESSION.
  523. FLG Y = 1.                   SET UP THE RESULT AS AN ITERATION COUNT.
  524. VAL Y = 0 + 0.
  525. PTR Y = N + 1.
  526. STO C = R.                   SAVE THE CURRENT ITERATION POINTER.
  527. PTR Z = R + 0.               PREPARE TO RESTORE IT.
  528. PTR R = C + 0.               SET A NEW ONE.
  529. PTR C = C - 4.
  530. STO C = K.                   SAVE THE CURRENT CODE BODY POINTER.
  531. LOC 44.                      RE-ENTRY FOR ANOTHER ITERATION.
  532. PTR C = R + 0.               RESET THE TEXT POINTER.
  533. PTR R = Z + 0.               RESET THE ITERATION POINTER.
  534. PTR Y = Y - 1.               DECREMENT THE ITERATION COUNT.
  535. TO 05 IF PTR 0 GE Y.         GET OUT IF NO MORE ARE NEEDED.
  536. PTR R = C + 0.               ELSE RESET THE ITERATION POINTER.
  537. PTR C = C - 7.
  538. STO C = Y.                   SAVE THE CURRENT COUNT.
  539. PTR C = C - 7.
  540. GET K = C.                   RESTORE THE CODE BODY POINTER.
  541. PTR C = C - 7.               NEW SPACE FOR THE NEXT TEXT LINE.
  542. TO 05.
  543. LOC 45.                      ITERATE UNDER CONTEXT CONTROL.
  544. STO 9 = L.                   TERMINATE THE PARAMETER STRING.
  545. PTR W = C - 9.               SPECIFY THE CURRENT STRING.
  546. PTR W = W / 7.               COMPUTE ITS LENGTH IN CHARACTERS.
  547. FLG W = 0.                   FLAG FOR CONTEXT-CONTROLLED ITERATION.
  548. VAL W = PTR W.               LENGTH IN CHARACTERS.
  549. PTR W = C + 0.               POINTER TO THE FIRST CHARACTER.
  550. PTR 9 = 9 - 7.
  551. FLG B = 2.                   CONSTRUCT THE TREE FOR ARGUMENT SCANNING.
  552. PTR B = 0 + 0.               SET UP THE PARAMETER.
  553. FLG U = 0.                   SET UP THE RIGHT PAREN.
  554. VAL U = R + 0.
  555. PTR U = 7 + 0.
  556. FLG Z = 1.                   END-OF-LINE.
  557. VAL Z = 0 + 0.               INITIALIZE BREAK COUNT.
  558. PTR Z = 0 + 0.
  559. PTR X = 9 - 7.
  560. LOC 46.                      ADD BREAK CHARACTERS TO THE TREE.
  561. VAL Z = Z + 1.               BUMP THE BREAK COUNT.
  562. STO 9 = Z.                   END-OF-LINE.
  563. PTR 9 = 9 - 7.
  564. STO 9 = U.                   RIGHT PAREN.
  565. PTR 9 = 9 - 7.
  566. STO 9 = B.                   PARAMETER FLAG.
  567. PTR 9 = 9 - 7.
  568. PTR K = K + 7.
  569. GET I = K.                   GRAB THE NEXT BREAK.
  570. PTR I = X - 9.               POINT TO THE ALTERNATIVE.
  571. STO 9 = I.                   CURRENT BREAK CHARACTER.
  572. PTR X = 9 + 0.               SAVE THE CURRENT POSITION FOR AN ALTERNATE.
  573. PTR 9 = 9 - 7.
  574. TO 97 IF PTR 8 GE 9.
  575. TO 46 IF FLG I NE 1.
  576. STO 9 = B.                   ANOTHER PARAMETER FLAG.
  577. FLG B = 0.                   RESET THE PHASE FLAG.
  578. PTR Z = 9 + 0.               SET UP A POINTER TO THE ROOT LOCATION.
  579. PTR 9 = 9 - 7.
  580. VAL U = M + 0.               SET UP A LEFT PAREN.
  581. STO 9 = U.                   TREE ROOT.
  582. PTR 9 = 9 - 7.
  583. STO 9 = R.                   PREVIOUS ROOT POINTER.
  584. PTR 9 = 9 - 7.
  585. STO 9 = C.                   PREVIOUS TEXT POINTER.
  586. PTR 9 = 9 - 7.
  587. STO 9 = V.                   POINTER TO PARAMETER STORE.
  588. PTR 9 = 9 - 7.
  589. STO 9 = Y.                   ORIGINAL PARAMETER SPEC.
  590. PTR R = 9 - 7.               NEW REPETITION POINTER.
  591. STO R = Z.                   NEW ROOT POINTER.
  592. PTR 9 = R - 7.
  593. STO 9 = W.                   PARAMETER REMAINDER.
  594. PTR 9 = 9 - 4.
  595. STO 9 = K.                   CURRENT TEXT POINTER.
  596. PTR Z = Z - 7.               FIRST TIME ROOT POINTER.
  597. TO 48.
  598. LOC 47.                      RE-ENTER FOR NEXT REPETITION.
  599. TO 05 IF PTR R = 0.          IF THERE IS NO REPETITION, GET OUT.
  600. GET Z = R.                   ELSE POINT THE SCANNER TO THE ROOT.
  601. LOC 48.                      FIRST TIME ENTRY POINT.
  602. PTR U = R - 7.               REMAINDER OF THE LIST.
  603. GET Y = U.
  604. TO 44 IF FLG Y = 1.          IS THIS ITERATION UNDER COUNT CONTROL, YES.
  605. TO 49 IF FLG Y = 3.          TERMINATE ON AN UNDEFINED PARAMETER.
  606. TO 49 IF VAL Y = 0.          TERMINATE THE ITERATION ON A NULL REMAINDER
  607. STO U = 0.                   ELSE SET UP ANOTHER SCAN.
  608. PTR U = U - 4.
  609. GET K = U.                   RESET THE CODE BODY POINTER.
  610. PTR V = U + 0.               SET UP THE STACK POINTER.
  611. PTR 9 = U - 7.
  612. PTR C = 9 + 0.               RESET THE TEXT ORIGIN.
  613. GET X = Y.                   GRAB THE FIRST CHARACTER AND
  614. TO 99 BY B.                  GO CHECK FOR SINGLE-CHARACTER BREAKOUT.
  615. PTR Y = R + 4.               GET THE ADDRESS OF THE PARAMETER
  616. GET W = Y.                   TO BE FIDDLED.
  617. PTR Y = R - 4.               GET THE NEW VALUE OF THE SPECIFICATION.
  618. TO 97 IF PTR 8 GE Y.
  619. GET Y = Y.
  620. STO W = Y.                   AND PUT IT IN THE PARAMETER SPACE.
  621. TO 05.                       CONTINUE WITH THE CODE BODY.
  622. LOC 99.                      CHECK AND SERVICE SINGLE-CHARACTER SPLITS.
  623. TO 60 IF VAL Z NE 1.         IF BREAK CHARACTERS USED, GO TO THE SCANNER
  624. FLG X = 0.                   ELSE PICK OFF A SINGLE CHARACTER.
  625. VAL X = Y - 1.               DROP THE LENGTH OF THE PARAMETER.
  626. VAL Y = 1 + 0.               SET THE NEW PARAMETER LENGTH TO 1.
  627. PTR U = U + 7.               SAVE THE NEW PARAMETER SPECIFICATION.
  628. STO U = Y.
  629. PTR U = U + 7.               ALSO SAVE THE REMAINDER OF THE STRING.
  630. STO U = X.
  631. RETURN BY B.                 RETURN AS THOUGH FROM THE SCANNER.
  632. LOC 49.                      TERMINATE THE ITERATION.
  633. TO 44 IF FLG Y = 1.          IS THIS ITERATION UNDER COUNT CONTROL, YES.
  634. PTR R = R + 7.
  635. GET Y = R.                   RESTORE THE ORIGINAL VALUE OF THE
  636. PTR R = R + 7.               PARAMETER SPECIFICATION.
  637. GET W = R.
  638. STO W = Y.
  639. PTR R = R + 7.
  640. GET C = R.                   RESTORE THE TEXT POINTER.
  641. PTR R = R + 7.
  642. GET R = R.
  643. TO 05.
  644. LOC 50.                      DEFINE A MACRO.
  645. FLG Y = 1.                   MARK IT AS DEFINED.
  646. VAL Y = L + 0.               LINE TERMINATOR.
  647. PTR 8 = 8 - 7.               PREPARE FOR A SPURIOUS ADVANCE.
  648. TO 54.                       GO GET THE MCT.
  649. LOC 51.                      DEAL WITH AN ESCAPE CHARACTER.
  650. VAL I = CHAR.                PICK UP THE NEXT CHARACTER.
  651. STO 8 = I.                   ASSUME THAT IT IS A SPECIAL TO BE SAVED.
  652. TO 52 IF VAL I = C.          IF IT REALLY IS AN MCT PARAMETER OR END-
  653. TO 52 IF VAL I = D.          OF-LINE FLAG, THEN GO ON TO THE NEXT CHAR.
  654. VAL I = I - E.               ELSE CONVERT A POSSIBLE DIGIT CHARACTER.
  655. FLG Z = 3.                   ASSUME THAT IT IS A FUNCTION CALL.
  656. VAL Z = CHAR.                GET THE PARAMETER CONVERSION OR FUNCTION.
  657. VAL Z = Z - E.               CONVERT FROM A CHARACTER TO AN INTEGER.
  658. PTR Z = VAL I.               PUT AWAY THE SPEC.
  659. STO 8 = Z.
  660. TO 52 IF PTR 0 GE Z.         IF IT IS REALLY A FUNCTION, GO ON.
  661. TO 52 IF PTR Z GE 5.
  662. FLG Z = 2.                   OTHERWISE MAKE IT A PARAMETER CONVERSION.
  663. PTR Z = Z * 7.               SET UP THE RELATIVE ADDR OF THE PARAMETER.
  664. STO 8 = Z.
  665. LOC 52.                      PROCESS AN MCT LINE.
  666. PTR 8 = 8 + 7.               ADVANCE THE SPACE POINTER.
  667. TO 97 IF PTR 8 GE 9.         HAVE WE RUN OUT OF ROOM, YES.
  668. VAL I = CHAR.                READ THE NEXT CHARACTER.
  669. STO 8 = I.                   STORE IT.
  670. TO 51 IF VAL I = D.          IS THIS AN ESCAPE CHARACTER, YES.
  671. TO 53 IF VAL I = L.          RECOGNIZE A CARRIAGE CONTROL.
  672. TO 52 IF VAL I NE C.         NO, WAS IT AN MCT END-OF-LINE, NO.
  673. LOC 53.
  674. PTR Y = 8 + 0.               POINT TO THE CURRENT LINE TERMINATOR.
  675. STO U = Y.                   SET UP THE PREVIOUS TERMINATOR.
  676. PTR U = 8 + 0.               UPDATE THE TERMINATOR ADDRESS.
  677. LOC 54.                      READ AND STORE A NEW MCT LINE.
  678. GET I = A.                   RECALL THE CHANNEL SPECIFIER.
  679. READ NEXT I.                 GRAB THE NEXT LINE.
  680. TO 98 IF FLG I NE 0.         GET OUT UNLESS ALL IS OK.
  681. VAL I = CHAR.                READ THE FIRST CHARACTER OF A LINE.
  682. PTR I = 0 + 0.               CLEAN OUT THE INPUT REGISTER.
  683. PTR 8 = 8 + 7.               ADVANCE THE SPACE POINTER.
  684. STO 8 = I.                   PUT IT AWAY.
  685. TO 51 IF VAL I = D.          WAS IT A PARAMETER FLAG, YES.
  686. TO 52 IF VAL I NE C.         WAS IT AN END-OF-LINE, NO.
  687. PTR Y = 8 + 0.               FILL IN THE PREVIOUS TERMINATOR.
  688. STO U = Y.
  689. STO 8 = 1.
  690. PTR 8 = 8 + 7.               ADVANCE THE SPACE POINTER.
  691. TO 97 IF PTR 8 GE 9.         HAVE WE OVERRUN THE AREA, YES.
  692. VAL I = CHAR.                GET THE NEXT CHARACTER.
  693. TO 55 IF VAL I NE C.         DID THAT CLOSE THE DEFINITION PHASE, NO.
  694. FLG B = 0.                   YES, RESET THE PHASE FLAG.
  695. TRAP.                               END OF MACROS
  696. LOC 55.                      COMMON SYSTEM RETURN POINT.
  697. RETURN BY D.                 REGISTER D IS THE RETURN ADDRESS.
  698. LOC 56.                      PUNCH AN UNRECOGNIZED LINE.
  699. VAL W = 3 + 0.               CHANNEL 3 USED WHEN A LINE IS NOT MATCHED.
  700. PTR X = C + 0.               ADDRESS THE FIRST CHARACTER.
  701. LOC 57.                      LOOP TO PUT OUT THE CHARACTERS.
  702. GET X = X.                   GET THE NEXT ONE.
  703. CHAR = VAL X.                MOVE IT INTO THE LINE BUFFER.
  704. TO 57 IF FLG X NE 1.         HAVE WE REACHED THE END, NO.
  705. WRITE NEXT W.                YES, PUT IT OUT ON THE DESIGNATED CHANNEL.
  706. TO 98 IF FLG W NE 0.         TREAT ANY ERROR AS FATAL.
  707. TO 55 IF VAL X = L.          ELSE IF THE LINE IS COMPLETE, RETURN.
  708. CHAR = VAL X.                ELSE REPRINT THE LAST CHARACTER
  709. TO 57.                       AND CONTINUE.
  710. LOC 58.                      TRY FOR AN ALTERNATIVE MATCH.
  711. PTR Z = W + Z.               GET THE POINTER TO THE ALTERNATIVE.
  712. TO 60 IF PTR W NE 0.         WAS THERE ONE AFTER ALL, YES.
  713. TO 71 IF FLG B = 2.          NO, ARE WE DEFINING, YES.
  714. LOC 59.                      TRY EXTENDING THE PREVIOUS PARAMETER.
  715. TO 70 IF PTR V GE 9.         IS THERE ONE TO EXTEND, NO.
  716. GET Z = V.                   RECALL THE MACRO POINTER.
  717. GET Y = Q.                   YES, RECALL THE INPUT POINTER
  718. GET X = Y.                   AND THE CURRENT CHARACTER
  719. TO 63 IF FLG Z = 2.          IS THIS THE FIRST TIME FOR A PARAMETER, YES
  720. TO 64 IF FLG Z = 3.          NO, IS IT A PARAMETER EXTENSION, YES.
  721. PTR V = Q + 7.               ABANDON THE STACK ENTRY.
  722. PTR Q = V + 7.
  723. LOC 60.                      TRY AN ALTERNATIVE.
  724. GET W = Z.                   GRAB THE MACRO CHARACTER.
  725. TO 69 IF FLG W = 1.          IS THIS THE END OF THE MACRO, YES.
  726. TO 62 IF FLG W = 2.          NO, IS IT A PARAMETER, YES.
  727. TO 58 IF VAL Y = 0.          NO, IS THIS THE END OF THE INPUT LINE, YES.
  728. TO 58 IF VAL X NE W.         NO, DOES THE CHARACTER MATCH, NO.
  729. TO 61 IF PTR W = 0.          IS THERE AN ALTERNATIVE, NO.
  730. TO 61 IF FLG X = 3.          DO NOT STACK ALTERNATIVES FOLLOWING A PARAM
  731. TO 61 IF FLG B = 2.          DO NOT STACK ALTERNATIVES DURING DEFINITION
  732. PTR Q = V - 7.
  733. PTR V = Q - 7.
  734. TO 97 IF PTR 8 GE V.
  735. STO Q = Y.                   SAVE THE INPUT POINTER
  736. PTR W = W + Z.               GET THE ADDRESS OF THE ALTERNATIVE.
  737. STO V = W.
  738. LOC 61.
  739. VAL Y = Y - 1.
  740. PTR Y = X + 0.
  741. GET X = X.                   ADVANCE THE INPUT POINTER
  742. PTR Z = Z + 7.               ADVANCE THE MACRO POINTER.
  743. TO 60.                       CONTINUE MATCHING.
  744. LOC 62.                      SET UP A PARAMETER IF POSSIBLE.
  745. TO 61 IF FLG X = 2.          IS THIS A PARAMETER DEFINITION, YES.
  746. TO 58 IF FLG B = 2.          NO, COULD WE NEED A PARAMETER, NO.
  747. PTR Q = V - 7.               CREATE AN ENTRY FOR THE PARAMETER.
  748. PTR V = Q - 7.
  749. TO 97 IF PTR 8 GE V.
  750. STO Q = Y.
  751. FLG Z = 2.                   SET UP THE PARAMETER POINTER.
  752. STO V = Z.
  753. FLG X = 3.                   DONT STACK FURTHER ALTERNATIVES.
  754. TO 58.
  755. LOC 63.                      FIRST TIME ENTRY FOR PARAMETERS.
  756. FLG Z = 3.                   SET FOR PARAMETER EXTENSION.
  757. PTR Z = Z + 7.
  758. STO V = Z.
  759. PTR U = U + 7.               ADVANCE THE PARAM STORE POINTER.
  760. FLG W = 0.
  761. VAL W = 0 + 0.               SET THE PARAMETER LENGTH TO ZERO.
  762. PTR W = Y + 0.               POINT IT TO THE CURRENT INPUT CHARACTER.
  763. STO U = W.
  764. TO 60.
  765. LOC 64.                      EXTEND THE CURRENT PARAMETER.
  766. TO 68 IF VAL Y = 0.          CAN IT BE EXTENDED, NO.
  767. TO 68 IF VAL X = R.          FAIL ON AN UNMATCHED CLOSING PAREN.
  768. GET W = U.                   INCREASE THE PARAMETER LENGTH.
  769. VAL W = W + 1.
  770. VAL Y = Y - 1.
  771. PTR Y = X + 0.
  772. TO 67 IF VAL X NE M.         IS THIS AN OPEN PAREN, NO.
  773. VAL Z = 0 + 0.               YES, ZERO THE PAREN COUNT.
  774. LOC 65.                      OBTAIN A BALANCED STRING.
  775. VAL Z = Z + 1.               BUMP THE PARENTHESIS COUNT.
  776. LOC 66.
  777. TO 68 IF VAL Y = 0.          FAIL IF THIS IS THE END.
  778. GET X = X.                   GRAB THE NEXT INPUT CHARACTER.
  779. VAL Y = Y - 1.
  780. PTR Y = X + 0.
  781. VAL W = W + 1.               ELSE BUMP THE PARAMETER LENGTH.
  782. TO 65 IF VAL X = M.          IS IT ANOTHER OPEN PAREN, YES.
  783. TO 66 IF VAL X NE R.         NO, IS IT A CLOSE PAREN, NO.
  784. VAL Z = Z - 1.               YES, DROP THE PAREN COUNT.
  785. TO 66 IF VAL Z NE 0.         CONTINUE IF THE COUNT IS NONZERO.
  786. LOC 67.                      CONTINUE THE SCAN.
  787. GET X = X.                   GET THE NEXT INPUT CHARACTER.
  788. STO Q = Y.                   INCREMENT THE INPUT POINTER.
  789. STO U = W.
  790. TO 60.
  791. LOC 68.                      ABANDON THE CURRENT PARAMETER.
  792. STO U = 3.                   SET THE PARAMETER UNDEFINED.
  793. PTR U = U - 7.               DROP THE PARAMETER STORE POINTER BACK.
  794. PTR V = Q + 7.               ABANDON THE STACK ENTRY.
  795. PTR Q = V + 7.
  796. TO 59.                       SEE IF THERE ARE OTHERS TO FALL BACK ON.
  797. LOC 69.
  798. TO 58 IF VAL Y NE 0.         IS THIS A FINAL MATCH, NO.
  799. PTR U = Z + 7.               YES, POINT TO THE DEFINITION SPEC.
  800. GET Y = U.
  801. LOC 70.
  802. RETURN BY B.                 COMMON RETURN POINT FOR PTR B RETURNS.
  803. LOC 71.                      ROUTINE TO ADD MACRO DEFINITIONS.
  804. PTR W = 8 - Z.               CREATE THE ALTERNATE POINTER.
  805. STO Z = W.                   CHANGE THE CURRENT ALTERNATE.
  806. TO 73 IF VAL Y = 0.          TERMINATE THE BRANCH IF THIS IS THE END.
  807. LOC 72.                      READ THE REMAINDER OF THE TEMPLATE LINE.
  808. VAL Y = Y - 1.
  809. PTR Y = X + 0.
  810. PTR X = 0 + 0.               RESET THE POINTER OF THE CURRENT CHARACTER.
  811. STO 8 = X.                   PUT IT AWAY.
  812. PTR 8 = 8 + 7.               ADVANCE THE SPACE POINTER.
  813. TO 97 IF PTR 8 GE 9.         HAVE WE OVERRUN THE AREA, YES.
  814. GET X = Y.                   GRAB THE NEXT CHARACTER.
  815. TO 72 IF VAL Y NE 0.         WAS THAT THE LAST, NO.
  816. LOC 73.                      TERMINATE A TREE BRANCH.
  817. FLG X = 1.                   SET THE MACRO TERMINATOR.
  818. PTR X = 0 + 0.               SET FOR NO ALTERNATIVE.
  819. STO 8 = X.
  820. PTR U = 8 + 7.               SET UP A DEFINITION POINTER.
  821. FLG Y = 0.
  822. PTR Y = U + 0.
  823. STO U = Y.
  824. PTR 8 = U + 7.               POINT TO THE FIRST EMPTY SPACE.
  825. TO 97 IF PTR 8 GE 9.
  826. RETURN BY B.
  827. LOC 74.                      EXPRESSION PROCESSOR.
  828. PTR O = 9 + 0.               SAVE THE CURRENT TOP OF FREE SPACE.
  829. VAL S = Y + 0.               SET UP THE STRING SPECIFIER.
  830. PTR S = Y + 0.
  831. PTR T = 0 + 0.               INITIAL VALUE OF THE EXPRESSION IS ZERO.
  832. TO 75 IF VAL Y NE 0.         IS THE EXPRESSION VOID, NO.
  833. PTR N = 0 + 0.               YES, ITS VALUE IS ZERO.
  834. RETURN BY P.
  835. LOC 75.
  836. VAL T = M + 0.               STACK A LEFT PAREN.
  837. LOC 76.
  838. TO 93 IF VAL S = 0.
  839. GET X = S.                   ELSE GRAB THE NEXT.
  840. PTR Y = S + 0.               POINT TO A POSSIBLE SECTION START.
  841. VAL Y = 0 + 0.               THE STRING IS INITIALLY EMPTY.
  842. TO 77 IF VAL X NE M.         IS THE CHARACTER A LEFT PAREN, NO.
  843. STO 9 = T.                   YES, PUSH THE STACK.
  844. PTR 9 = 9 - 7.
  845. TO 97 IF PTR 8 GE 9.
  846. VAL S = S - 1.               DROP THE STRING LENGTH REMAINING.
  847. PTR S = X + 0.               BUMP THE POINTER.
  848. TO 75.
  849. LOC 77.                      SPECIFIY A SECTION.
  850. TO 78 IF VAL X = N.          IS THIS A PLUS, YES.
  851. TO 78 IF VAL X = O.          MINUS.
  852. TO 78 IF VAL X = P.          TIMES.
  853. TO 78 IF VAL X = Q.          DIVIDE.
  854. TO 78 IF VAL X = R.          RIGHT PAREN.
  855. VAL Y = Y + 1.               NOT AN OPERATOR. BUMP SECTION LENGTH.
  856. GET X = X.                   GRAB THE NEXT CHARACTER.
  857. TO 77 IF VAL S NE Y.         IS THE STRING EXHAUSTED, NO.
  858. VAL X = R + 0.               YES, SET UP A RIGHT PAREN.
  859. VAL S = S + 1.               PRETEND THAT IT WAS IN THE INPUT STRING.
  860. LOC 78.
  861. VAL J = X + 0.               SET UP THE SECTION OPERATOR.
  862. PTR N = 0 + 0.               ZERO THE ACCUMULATOR.
  863. VAL S = S - Y.               UPDATE THE STRING POINTER.
  864. VAL S = S - 1.
  865. PTR S = X + 0.
  866. TO 83 IF VAL Y = 0.          A NULL STRING HAS THE VALUE ZERO.
  867. GET X = Y.                   GRAB FIRST CHARACTER OF NON-NULL STRING.
  868. PTR U = VAL X.               CHECK FOR A DIGIT.
  869. PTR U = U - E.
  870. TO 79 IF PTR U GE 5.
  871. TO 81 IF PTR U GE 0.
  872. LOC 79.                      IF FIRST CHARACTER IS NOT A DIGIT, LOOK UP.
  873. PTR V = 9 + 7.               STACK POINTER FOR SCANNER.
  874. GET W = F.                   SET UP THE SYMBOL TREE.
  875. FLG Y = 0.                   SET THE RESULTING SYMBOL UNDEFINED.
  876. PTR Z = F + 0.               SET THE TREE POINTER TO THE SYMBOL ROOT.
  877. TO 58 BY B.                  LOOK UP THE SYMBOL VALUE.
  878. TO 83 IF FLG Y NE 1.         AN UNDEFINED SYMBOL HAS THE VALUE ZERO.
  879. TO 83 IF VAL Y = 0.          A NULL STRING HAS THE VALUE ZERO.
  880. GET X = Y.                   GRAB FIRST CHARACTER OF NON-NULL STRING.
  881. FLG N = 1.                   ASSUME IT IS A MINUS SIGN
  882. TO 82 IF VAL X = O.          AND IF IT IS GO ON TO THE NEXT DIGIT.
  883. FLG N = 0.                   ELSE RESET THE SIGN TO PLUS.
  884. PTR X = Y + 0.               PREPARE FOR A SPURIOUS FETCH.
  885. LOC 80.                      CHECK THE NEXT CHARACTER FOR DIGIT.
  886. GET X = X.                   NO, GRAB THE NEXT CHARACTER.
  887. PTR U = VAL X.               CHECK FOR A DIGIT.
  888. PTR U = U - E.
  889. TO 81 IF PTR U = 0.
  890. TO 93 IF PTR U GE 5.
  891. TO 93 IF PTR 0 GE U.
  892. LOC 81.                      INCORPORATE A DIGIT INTO THE SECTION VALUE.
  893. PTR N = N * 5.               MULTIPLY ACCUMULATOR BY 10.
  894. PTR N = N + U.               ADD CURRENT DIGIT.
  895. LOC 82.
  896. VAL Y = Y - 1.               DROP THE REMAINING LENGTH.
  897. TO 80 IF VAL Y NE 0.         ARE WE DONE, NO.
  898. TO 83 IF FLG N = 0.          IS THE ACCUMULATOR NEGATIVE, NO.
  899. FLG N = 0.                   YES, RESET THE SIGN BIT.
  900. PTR N = 0 - N.               NEGATE THE CONTENTS.
  901. LOC 83.                      EVALUATE THE CURRENT SECTION.
  902. TO 92 IF VAL J = R.          IS THE SECTION OPERATOR A RIGHT PAREN, YES.
  903. TO 90 IF VAL T = M.          NO, IS THE STACK OPERATOR A LEFT PAREN, YES
  904. TO 89 IF VAL J = P.          NO, IS THE SECTION OPERATOR A TIMES, YES.
  905. TO 89 IF VAL J = Q.          NO, IS IT A DIVIDE, YES.
  906. LOC 84.                      PERFORM A PENDING OPERATION.
  907. TO 87 IF VAL T = Q.          IS THE OPERATOR A DIVIDE, YES.
  908. TO 86 IF VAL T = P.          NO, IS IT A TIMES, YES.
  909. TO 85 IF VAL T = O.          NO, IS IT A MINUS, YES.
  910. PTR T = T + N.               PLUS.
  911. TO 88.
  912. LOC 85.
  913. PTR T = T - N.
  914. TO 88.
  915. LOC 86.
  916. PTR T = T * N.
  917. TO 88.
  918. LOC 87.
  919. PTR T = T / N.
  920. LOC 88.
  921. VAL T = J + 0.               RESET THE STACK OPERATOR.
  922. TO 76 IF VAL J NE R.         WAS THE SECTION OPERATOR A RIGHT PAREN, NO.
  923. PTR N = T + 0.               YES, KEEP EVALUATING.
  924. PTR 9 = 9 + 7.               POP THE STACK.
  925. GET T = 9.
  926. TO 92.
  927. LOC 89.                      CHECK PRECEDENCE OF STACK OPERATORS.
  928. TO 86 IF VAL T = P.          EVALUATE IF THE STACK OPERATOR IS TIMES
  929. TO 87 IF VAL T = Q.          OR DIVIDE.
  930. LOC 90.                      STACK A SECTION.
  931. STO 9 = T.                   PUSH THE STACK.
  932. PTR 9 = 9 - 7.
  933. TO 97 IF PTR 8 GE 9.
  934. VAL T = J + 0.               SET THE OPERATOR
  935. PTR T = N + 0.               AND OPERAND ONTO THE STACK.
  936. TO 76.
  937. LOC 91.                      STACK IS EMPTY.
  938. TO 93 IF VAL S NE 0.         IS THE EXPRESSION EMPTY, NO.
  939. RETURN BY P.                 YES, CORRECT RETURN.
  940. LOC 92.
  941. TO 84 IF VAL T NE M.         IS THE STACK OPERATOR A LEFT PAREN, NO.
  942. TO 91 IF PTR 9 = O.          YES, IS THE STACK EMPTY, YES.
  943. PTR 9 = 9 + 7.               NO, POP IT UP.
  944. GET T = 9.
  945. TO 92 IF VAL S = 0.          IS THERE MORE IN THE EXPRESSION, NO.
  946. GET X = S.                   YES, GRAB THE NEXT CHARACTER.
  947. VAL S = S - 1.
  948. PTR S = X + 0.
  949. VAL J = X + 0.
  950. TO 92 IF VAL J = R.          IS THE SECTION OPERATOR A RIGHT PAREN, YES.
  951. TO 83 IF VAL J = N.          NO, IS IT A PLUS, YES.
  952. TO 83 IF VAL J = O.          NO, MINUS, YES.
  953. TO 83 IF VAL J = P.          NO, TIMES, YES.
  954. TO 83 IF VAL J = Q.          NO, DIVIDE, YES.
  955. LOC 93.                      ERROR IN ARITHMETIC EXPRESSION.
  956. MESSAGE EXPR TO 4.           ISSUE AN ERROR MESSAGE.
  957. PTR N = 0 + 0.               ZERO OUT A POSSIBLE SKIP COUNT.
  958. PTR 9 = O + 0.               RESET THE FREE SPACE POINTER.
  959. TO 94 BY B.                  CALL ERROR TRACEBACK.
  960. RETURN BY P.                 CONTINUE WITH THE LINE.
  961. LOC 94.                      PROVIDE TRACEBACK FROM ERROR.
  962. PTR X = C + 0.               FIRST CHARACTER OF THE STRING BEING BUILT.
  963. PTR Y = J + 0.               CURRENT PARAMETER POINTER.
  964. TO 96 IF PTR 9 GE C.         IS THERE A LINE BEING CONSTRUCTED, NO.
  965. STO 9 = L.                   YES, TERMINATE IT.
  966. LOC 95.                      PRINTING LOOP.
  967. GET X = X.                   GRAB THE NEXT CHARACTER.
  968. CHAR = VAL X.                MOVE IT TO THE LINE BUFFER.
  969. TO 95 IF FLG X = 0.          ARE WE DONE WITH THIS LINE, NO.
  970. WRITE NEXT 4.                YES, WRITE IT OUT.
  971. TO 98 IF FLG 4 NE 0.         TREAT AN ERROR AS FATAL.
  972. TO 96 IF VAL X = L.          IF THE LINE ENDED, FINE.
  973. CHAR = VAL X.                OTHERWISE RE-ISSUE THE LAST CHARACTER
  974. TO 95.                       AND KEEP OUTPUTTING.
  975. LOC 96.
  976. TO 70 IF PTR Y = 0.          ARE THERE MORE, NO.
  977. PTR Y = Y - H.               YES, MOVE BACK UP THE CHAIN.
  978. PTR X = Y - 7.
  979. GET Y = Y.                   PREVIOUS PARAMETER POINTER.
  980. GET X = X.                   CURRENT TEXT POINTER.
  981. TO 95.
  982. LOC 97.                      THE WORKING AREA HAS BEEN OVERFILLED.
  983. MESSAGE FULL TO 4.           ISSUE AN ERROR MESSAGE.
  984. TO 94 BY B.                  CALL ERROR TRACEBACK.
  985. STOP.
  986. LOC 98.                      AN I/O ERROR HAS OCCURRED
  987. MESSAGE IOCH TO 4.           ISSUE THE CHANNEL ERROR MESSAGE
  988. TO 94 BY B.                  AND PROVIDE A TRACEBACK.
  989. STOP.
  990. END PROGRAM.
  991.