include "hdr1.html"; ?>
Line | Address | Object Code | Label | F1 | N1 | B | F2 | N2 | Comments | Check |
---|---|---|---|---|---|---|---|---|---|---|
1 | 0 | ; tape2/iosupp.t2 | ||||||||
2 | 0 | ;---------------- | ||||||||
3 | 0 | ; digits(n) set number of digits in printed integers | ||||||||
4 | 0 | ; | ||||||||
5 | 0 | =7462 | ||||||||
6 | 7462 | Digits:: | ; | |||||||
7 | 7462 | Digits: | ; | |||||||
8 | 7462 | 0600016 | lod | arg1 | ; | @7462 | ||||
9 | 7462+ | 1136450 | jn | .1 | ;<0, error | |||||
10 | 7463 | 1156450 | jz | .1 | ;=0, error | @7463 | ||||
11 | 7463+ | 0136214 | sub | K13 | ;=13 | |||||
12 | 7464 | 1136451 | jn | .2 | ;<13, OK | @7464 | ||||
13 | 7464+ | .1: | ; | |||||||
14 | 7464+ | 0056223 | o02 | K4 | ;=4+1=>5 | |||||
15 | 7465 | 0020000 | neg | 0 | ;=-5 | @7465 | ||||
16 | 7465+ | .2: | ; | |||||||
17 | 7465+ | 0116214 | add | K13 | ;=13 | |||||
18 | 7466 | 0400075 | sto | Ndigits | ;store new setting | @7466 | ||||
19 | 7466+ | 1016043 | jmp | RetClr | ;and return | |||||
20 | 7467 | ;-------------------------------------------------------------------- | ||||||||
21 | 7467 | Scaled: | ; | |||||||
22 | 7467 | calln | , | ;check arg1 OK | @7467 | |||||
22+1 | 7467 | 7300101016462 | lnk | arg3 | : | jmp | chkrfmt | |||
23 | 7468 | 0040000 | o02 | 0 | ;=1 | @7468 | ||||
24 | 7468+ | 1320024 | sll | 20 | ; | |||||
25 | 7469 | 0100016 | add | arg1 | ; | @7469 | ||||
26 | 7469+ | 0116227 | add | Signbit | ;=04000000000000 (sign bit) | |||||
27 | 7470 | setrfmt: | ; | |||||||
28 | 7470 | 0400074 | sto | Rfmt | ; | @7470 | ||||
29 | 7470+ | 1016043 | jmp | RetClr | ;return | |||||
30 | 7471 | ;-------------------------------------------------------------------- | ||||||||
31 | 7471 | ; sameline, suppress CR,LF before each print item | ||||||||
32 | 7471 | ; set prefix string pointer to 1, non-zero, but effectively a | ||||||||
33 | 7471 | ; Null string | ||||||||
34 | 7471 | ; | ||||||||
35 | 7471 | Sameline: | ; | |||||||
36 | 7471 | 0040000 | o02 | 0 | ;=1 special value for prefix | @7471 | ||||
37 | 7471+ | setprefix: | ; | |||||||
38 | 7471+ | 1320024 | sll | 20 | ;shift to N1 position | |||||
39 | 7472 | 0200076 | exa | prtfmt | ;present setting | @7472 | ||||
40 | 7472+ | 0076505 | and | W7493 | ;=<77 0 / 77 8191> mask out N1 | |||||
41 | 7473 | 0500076 | ads | prtfmt | ;combine with new flag | @7473 | ||||
42 | 7473+ | 1016043 | jmp | RetClr | ;and return | |||||
43 | 7474 | ;-------------------------------------------------------------------- | ||||||||
44 | 7474 | ; check arg1 is OK for real formats | ||||||||
45 | 7474 | ; | ||||||||
46 | 7474 | chkrfmt: | ; | |||||||
47 | 7474 | 0600016 | lod | arg1 | ;get value | @7474 | ||||
48 | 7474+ | 1056466 | jz | errfmt | ;=0, error | |||||
49 | 7475 | 1036466 | jn | errfmt | ;<0, error | @7475 | ||||
50 | 7475+ | 0176211 | bus | K10a | ;=10 | |||||
51 | 7476 | 0116210 | add | N1 | ;=-1 | @7476 | ||||
52 | 7476+ | 1036466 | jn | errfmt | ;>11, error | |||||
53 | 7477 | 0000103000001 | o00 | arg3 | / | jmp | 1 | ;back to caller | @7477 | |
54 | 7478 | ; | ||||||||
55 | 7478 | errfmt: | ; | |||||||
56 | 7478 | 0615154 | lod | W6764 | ;=<10 8:00 8> | @7478 | ||||
57 | 7478+ | 0400074 | sto | Rfmt | ;set default format | |||||
58 | 7479 | 1016043 | jmp | RetClr | ; | @7479 | ||||
59 | 7479+ | ;-------------------------------------------------------------------- | ||||||||
60 | 7479+ | ; prefix(str) - set string to print before each number | ||||||||
61 | 7479+ | ; argument is address of string | ||||||||
62 | 7479+ | ; | ||||||||
63 | 7479+ | Prefix: | ; | |||||||
64 | 7479+ | 0600016 | lod | arg1 | ;get argument value | |||||
65 | 7480 | 0076202 | and | K8191 | ;=8191 mask address to 13 bits | @7480 | ||||
66 | 7480+ | 1116457 | jmp | setprefix | ;join with Sameline code | |||||
67 | 7481 | ;-------------------------------------------------------------------- | ||||||||
68 | 7481 | ; freepoint(n) - set floating point format | ||||||||
69 | 7481 | ; set digits before=digits after=n | ||||||||
70 | 7481 | ; | ||||||||
71 | 7481 | Freepoint: | ; | |||||||
72 | 7481 | calln | , | ;check arg1 OK | @7481 | |||||
72+1 | 7481 | 7300101016462 | lnk | arg3 | : | jmp | chkrfmt | |||
73 | 7482 | 0600016 | lod | arg1 | ; | @7482 | ||||
74 | 7482+ | 1320024 | sll | 20 | ;shift n to N1 position | |||||
75 | 7483 | L7483: | ; | |||||||
76 | 7483 | 0116545 | add | W7525 | ;=<10 0:00 0> | @7483 | ||||
77 | 7483+ | 0100016 | add | arg1 | ;+arg1 | |||||
78 | 7484 | 1016456 | jmp | setrfmt | ; | @7484 | ||||
79 | 7484+ | ;-------------------------------------------------------------------- | ||||||||
80 | 7484+ | ; aligned(b,a) - b digits before point, a after. (reals only) | ||||||||
81 | 7484+ | ; | ||||||||
82 | 7484+ | Aligned:: | ; | |||||||
83 | 7484+ | Aligned: | ; | |||||||
84 | 7484+ | 0600017 | lod | arg2 | ;check for b<0 | |||||
85 | 7485 | 1036466 | jn | errfmt | ;error, freepoint(8) | @7485 | ||||
86 | 7485+ | 0700016 | las | arg1 | ;check a<0, add b | |||||
87 | 7486 | 1036466 | jn | errfmt | ;error, freepoint(8) | @7486 | ||||
88 | 7486+ | 0200016 | exa | arg1 | ;get total (a+b), arg1:=a | |||||
89 | 7487 | 0176220 | bus | K15a | ;=15 | @7487 | ||||
90 | 7487+ | 1036466 | jn | errfmt | ;a+b>15, error | |||||
91 | 7488 | 0176220 | bus | K15a | ;get a+b back | @7488 | ||||
92 | 7488+ | 1016506 | jmp | .1 | ;-> to patch | |||||
93 | 7489 | ; | ||||||||
94 | 7489 | ; | ||||||||
95 | 7489 | =7494 | ||||||||
96 | 7494 | .1: | ; | |||||||
97 | 7494 | 0200016 | exa | arg1 | ;digits before point (a) | @7494 | ||||
98 | 7494+ | 1320024 | sll | 20 | ;shift to N1 | |||||
99 | 7495 | 0116545 | add | W7525 | ;=<10 0:00 0> | @7495 | ||||
100 | 7495+ | 1016473 | jmp | L7483 | ;common with freepoint above | |||||
101 | 7496 | =7489 | ||||||||
102 | 7489 | ;-------------------------------------------------------------------- | ||||||||
103 | 7489 | ; leadzero(str) | ||||||||
104 | 7489 | ; | ||||||||
105 | 7489 | LeadZero:: | ; | |||||||
106 | 7489 | LeadZero: | ; | |||||||
107 | 7489 | 0000072600000 | o00 | arg1 | / | lod | 0 | ;get 1st word of string | @7489 | |
108 | 7490 | 1220036 | srl | 30 | ;shift first char | @7490 | ||||
109 | 7490+ | 0076212 | and | K63 | ;=63 and mask off sign etc. | |||||
110 | 7491 | 1015761 | jmp | .1 | ;-> to patch | @7491 | ||||
111 | 7491+ | =7153 | ||||||||
112 | 7153 | .1: | ; | |||||||
113 | 7153 | 1055762 | jz | .2 | ;character is null | @7153 | ||||
114 | 7153+ | 1115762 | jmp | .3 | ;character OK | |||||
115 | 7154 | ; | ||||||||
116 | 7154 | .2: | ; | |||||||
117 | 7154 | 0616215 | lod | K27 | ;=27 use fig shift | @7154 | ||||
118 | 7154+ | .3: | ; | |||||||
119 | 7154+ | 0700076 | las | prtfmt | ;load old value, add new char | |||||
120 | 7155 | 1116503 | jmp | .4 | ;-->> | @7155 | ||||
121 | 7155+ | ; | ||||||||
122 | 7155+ | =7491+ | ||||||||
123 | 7491+ | .4: | ; | |||||||
124 | 7491+ | 0076212 | and | K63 | ;=63 mask old leadzero char | |||||
125 | 7492 | 0560076 | o27 | prtfmt | ;subtract from store | @7492 | ||||
126 | 7492+ | 1016043 | jmp | RetClr | ;and return | |||||
127 | 7493 | ; | ||||||||
128 | 7493 | 7700003777777 | W7493: | +07700003777777 | ;o77 0 / o77 8191 | @7493 | ||||
129 | 7494 | ;-------------------------------------------------------------------- | ||||||||
130 | 7494 | =7496 | ||||||||
131 | 7496 | ;-------------------------------------------------------------------- | ||||||||
132 | 7496 | ; grouping(n) | ||||||||
133 | 7496 | ; | ||||||||
134 | 7496 | Grouping:: | ; | |||||||
135 | 7496 | Grouping: | ; | |||||||
136 | 7496 | 0616515 | lod | W7501 | ;=<77 8191/00 8191> | @7496 | ||||
137 | 7496+ | 0460076 | ans | prtfmt | ;remove previous grouping | |||||
138 | 7497 | 0600016 | lod | arg1 | ;check value given | @7497 | ||||
139 | 7497+ | 1036514 | jn | .errfmt | ;bad value | |||||
140 | 7498 | 1056514 | jz | .errfmt | ;bad value | @7498 | ||||
141 | 7498+ | 1320015 | sll | 13 | ;OK, shift to F2 position | |||||
142 | 7499 | 0500076 | ads | prtfmt | ;and add to format | @7499 | ||||
143 | 7499+ | 1016043 | jmp | RetClr | ;then return | |||||
144 | 7500 | ; | ||||||||
145 | 7500 | .errfmt: | ; | |||||||
146 | 7500 | 0540076 | cls | prtfmt | ;set default format | @7500 | ||||
147 | 7500+ | 1016043 | jmp | RetClr | ;then return | |||||
148 | 7501 | ; | ||||||||
149 | 7501 | 7777776017777 | W7501: | +07777776017777 | ;o77 8191 / o00 8191 | @7501 | ||||
150 | 7502 | ;-------------------------------------------------------------------- | ||||||||
151 | 7502 | ; special(n) | ||||||||
152 | 7502 | ; n=1 suppress space before positive number on output | ||||||||
153 | 7502 | ; n=2 replace space with '+' before positive number | ||||||||
154 | 7502 | ; n=3 don't float the sign | ||||||||
155 | 7502 | ; n=4 ignore spaces on input | ||||||||
156 | 7502 | ; | ||||||||
157 | 7502 | Special:: | ; | |||||||
158 | 7502 | Special: | ; | |||||||
159 | 7502 | 0600016 | lod | arg1 | ;get argument | @7502 | ||||
160 | 7502+ | 1036546 | jn | .err | ;<0, error | |||||
161 | 7503 | 1056546 | jz | .err | ;=0, error | @7503 | ||||
162 | 7503+ | 0136223 | sub | K4 | ;=4 | |||||
163 | 7504 | 1136521 | jn | .1 | ;1-3, OK | @7504 | ||||
164 | 7504+ | 1056526 | jz | .4 | ;4, OK, but different | |||||
165 | 7505 | 1016546 | jmp | .err | ;>4, error | @7505 | ||||
166 | 7505+ | =7526 | ||||||||
167 | 7526 | .err: | ; | |||||||
168 | 7526 | 0616230 | lod | MaxInt | ;=03777777777777 (maxint) | @7526 | ||||
169 | 7526+ | 0460025 | ans | indev | ;remove possible sign bit | |||||
170 | 7527 | 1016514 | jmp | Grouping.errfmt | ;reset standard format | @7527 | ||||
171 | 7527+ | ; | ||||||||
172 | 7527+ | 0000000 | o00 | 0 | ; | |||||
173 | 7528 | =7505+ | ||||||||
174 | 7505+ | ; | ||||||||
175 | 7505+ | ; cases 1-3, affect printing | ||||||||
176 | 7505+ | ; | ||||||||
177 | 7505+ | .1: | ; | |||||||
178 | 7505+ | 0600076 | lod | prtfmt | ;check if specified bit already set | |||||
179 | 7506 | 0000073317777 | o00 | arg1 | / | sll | -1 | ;shift it top top place | @7506 | |
180 | 7507 | 1036043 | jn | RetClr | ;bit set, return | @7507 | ||||
181 | 7507+ | 1016550 | jmp | .11 | ;not set, set it | |||||
182 | 7508 | =7528 | ||||||||
183 | 7528 | ; | ||||||||
184 | 7528 | .11: | ; | |||||||
185 | 7528 | 0600076 | lod | prtfmt | ; | @7528 | ||||
186 | 7528+ | 1036555 | jn | .14 | ;special(1) already set, clear it | |||||
187 | 7529 | 0040000 | o02 | 0 | ;=1 | @7529 | ||||
188 | 7529+ | 0120016 | sub | arg1 | ; | |||||
189 | 7530 | 1036554 | jn | .13 | ;2,3 | @7530 | ||||
190 | 7530+ | 0616230 | lod | MaxInt | ;=03777777777777, 1 cancels 2&3 | |||||
191 | 7531 | 1220002 | srl | 2 | ;shift mask to clear 1,2&3 | @7531 | ||||
192 | 7531+ | .12: | ; | |||||||
193 | 7531+ | 0460076 | ans | prtfmt | ;clear excluded bits | |||||
194 | 7532 | .13: | ; | |||||||
195 | 7532 | 0616227 | lod | Signbit | ;=04000000000000 | @7532 | ||||
196 | 7532+ | 1016524 | jmp | .2 | ; | |||||
197 | 7533 | ; | ||||||||
198 | 7533 | .14: | ; | |||||||
199 | 7533 | 0616230 | lod | MaxInt | ;=03777777777777 | @7533 | ||||
200 | 7533+ | 1116553 | jmp | .12 | ; | |||||
201 | 7534 | ; | ||||||||
202 | 7534 | =7508 | ||||||||
203 | 7508 | .2: | ; | |||||||
204 | 7508 | 0000073217777 | o00 | arg1 | / | srl | -1 | ; | @7508 | |
205 | 7509 | 0500076 | ads | prtfmt | ; | @7509 | ||||
206 | 7509+ | 1016043 | jmp | RetClr | ||||||
207 | 7510 | ; | ||||||||
208 | 7510 | ; case 4, affects reading | ||||||||
209 | 7510 | ; | ||||||||
210 | 7510 | .4: | ; | |||||||
211 | 7510 | 0600025 | lod | indev | ; | @7510 | ||||
212 | 7510+ | 1036043 | jn | RetClr | ;already set | |||||
213 | 7511 | .5: | ; | |||||||
214 | 7511 | 0616227 | lod | Signbit | ;=04000000000000 (sign bit) | @7511 | ||||
215 | 7511+ | 0500025 | ads | indev | ;set sign bit to indicate special(4) | |||||
216 | 7512 | 1016043 | jmp | RetClr | ;and return | @7512 | ||||
217 | 7512+ | ;-------------------------------------------------------------------- | ||||||||
218 | 7512+ | ; reader(n) - set input device (1 or 2) | ||||||||
219 | 7512+ | ; 3 seems to be allowed! | ||||||||
220 | 7512+ | ; | ||||||||
221 | 7512+ | Reader:: | ; | |||||||
222 | 7512+ | Reader: | ; | |||||||
223 | 7512+ | 0600016 | lod | arg1 | ;device number | |||||
224 | 7513 | 1036533 | jn | .err | ;error, <0 | @7513 | ||||
225 | 7513+ | 1056533 | jz | .err | ;error, =0 | |||||
226 | 7514 | 0136223 | sub | K4 | ;=4 | @7514 | ||||
227 | 7514+ | 1036534 | jn | .1 | ;1-3, OK | |||||
228 | 7515 | .err: | ; | |||||||
229 | 7515 | 0540025 | cls | indev | ;input device = reader 1 | @7515 | ||||
230 | 7515+ | 1016043 | jmp | RetClr | ; | |||||
231 | 7516 | ; | ||||||||
232 | 7516 | .1: | ; | |||||||
233 | 7516 | 0600016 | lod | arg1 | ;reload argument | @7516 | ||||
234 | 7516+ | 0116210 | add | N1 | ;=-1 | |||||
235 | 7517 | 1320013 | sll | 11 | ;shift for H/W | @7517 | ||||
236 | 7517+ | 0200025 | exa | indev | ;set device, check previous | |||||
237 | 7518 | 1036527 | jn | Special.5 | ; | @7518 | ||||
238 | 7518+ | 1016043 | jmp | RetClr | ; | |||||
239 | 7519 | ;-------------------------------------------------------------------- | ||||||||
240 | 7519 | ; punch(n) - set output device, n = 1-3 | ||||||||
241 | 7519 | ; | ||||||||
242 | 7519 | Punch:: | ; | |||||||
243 | 7519 | Punch: | ; | |||||||
244 | 7519 | 0600016 | lod | arg1 | ;get argument | @7519 | ||||
245 | 7519+ | 1136541 | jn | .p1 | ;<0, error, set 0 | |||||
246 | 7520 | 1156541 | jz | .p1 | ;=0, OK, set 0 | @7520 | ||||
247 | 7520+ | 0136223 | sub | K4 | ;=4 | |||||
248 | 7521 | 1136542 | jn | .p2 | ;1-3 | @7521 | ||||
249 | 7521+ | .p1: | ; | |||||||
250 | 7521+ | 0540077 | cls | outdev | ;set output device = punch 1 | |||||
251 | 7522 | 1016043 | jmp | RetClr | ; | @7522 | ||||
252 | 7522+ | ; | ||||||||
253 | 7522+ | .p2: | ; | |||||||
254 | 7522+ | 0600016 | lod | arg1 | ;reload argument | |||||
255 | 7523 | 0116210 | add | N1 | ;=-1 | @7523 | ||||
256 | 7523+ | 1320013 | sll | 11 | ;shift into position | |||||
257 | 7524 | 0400077 | sto | outdev | ;and store | @7524 | ||||
258 | 7524+ | 1016043 | jmp | RetClr | ;return to caller | |||||
259 | 7525 | ;-------------------------------------------------------------------- | ||||||||
260 | 7525 | ; | ||||||||
261 | 7525 | 1000000000000 | W7525: | +01000000000000 | ; | @7525 | ||||
262 | 7526 | ; |