| 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 | | ; |
|