dev-assem

Date: 1983
Type: Program
Platform(s): TS 2068

Spectrum assembler from Your Computer November 1983.

Appears on

Library tape from the Sinclair Computer Users Society (SINCUS).

Source Code

    1 CLEAR 54999: BORDER 1: PAPER 6: POKE 23609,10: LET a=2000: GO TO 801: REM                      spectrum assembler from         Your Computer November          1983. Entered by F. Chrysler
    2 DEF FN r(x,y,z$)=(CODE z$>=CODE STR$ x) AND (CODE z$<=CODE STR$ y)
    3 DEF FN a(x)=PEEK x+256*PEEK (x+1)
    4 DEF FN q$(x,y)=q$(ptr+x TO ptr+y)
    5 DEF FN c(x)=CODE q$(ptr+x)
   10 FOR x=k1 TO l-k1: LET a=a+FN c(6): LET ptr=ptr+8+FN c(5)+FN c(6): NEXT x: RETURN 
   20 IF l1>lns OR l1<k1 THEN LET z$="Range error": GO TO 700
   22 PRINT BRIGHT k1;"Inserting": LET l=l1: LET ptr=9: GO SUB 10
   24 GO SUB 100: LET l=l+k1: LET len=LEN p$: IF NOT len THEN GO TO 28
   25 IF last+len>LEN q$ THEN LET z$="No more room": GO TO run
   26 RANDOMIZE last-ptr+k1: LET q$(ptr TO ptr+len-k1)=p$ AND USR insert: LET ptr=ptr+LEN p$: LET mc=mc+LEN m$: LET last=last+len: LET lns=lns+k1: GO TO 24
   28 LET l1=l-10: LET l2=lns: IF l1>lns-32 THEN LET l1=lns-21
   29 IF l1<=k0 OR lns<=22 THEN LET l1=k1
   30 PAUSE k1: LET ptr=9: LET l=l1: GO SUB 10: CLS : IF NOT lns THEN PRINT "Empty": GO TO 701
   32 POKE scc,hi: LET l=FN c(k0): LET l$=("L"+STR$ l) AND l: PRINT l1;TAB 3;L$;TAB 8;FN q$(k1,4);TAB 13;: LET l=FN c(5): PRINT FN q$(8,7+l): LET ptr=ptr+8+l+FN c(6): LET l1=l1+k1: IF l1<=l2 AND INKEY$="" THEN GO TO 32
   34 GO TO 701
   40 IF l1<k1 OR l2>lns OR l1>l2 THEN LET z$="Range error": GO TO run
   42 LET l=l1: LET ptr=9: GO SUB 10: LET p1=ptr: LET l=l2-l1+2: LET a=k0: GO SUB 10: LET len=ptr-p1
   44 FOR x=p1 TO last-len-31 STEP 32: LET y=x+len: LET q$(x TO x+31)=q$(y TO y+31): NEXT x: LET q$(x TO last-len)=q$(x+len TO last): LET mc=mc-a: LET last=last-len: LET lns=lns-l2+l1-k1: LET len=k0: IF z$<>"R" THEN GO TO 28
   45 PRINT "Replacing ";l1;" to ";l2: LET ptr=p1: LET l=l1: IF ptr<last THEN GO TO 24
   50 LET l=lns+k1: GO SUB 100: LET len=LEN p$: IF NOT len THEN GO TO 701
   51 IF last+len>LEN q$ THEN LET z$="No more room": GO TO run
   52 LET q$(last+k1 TO last+len)=p$: LET mc=mc+LEN m$: LET last=last+len: LET lns=lns+k1: GO TO 50
   80 BEEP .1,k0: POKE 23658,8: INPUT "Error"' FLASH (x=1);(l$);TAB 7; FLASH (x=2);(a$);TAB 14; FLASH (x>2);(b$);" ";(c$); FLASH k0;TAB 30; LINE z$: RETURN 
   90 IF x=3 THEN RETURN 
   94 GO SUB 80: IF x>k1 THEN GO TO 104
  100 LET m$="": LET x=k1: INPUT (d$)' LINE l$: IF l$="" THEN LET l1=k0: GO TO 104
  102 IF CODE l$<>CODE "L" OR NOT FN r(k0,9,l$(2 TO )) THEN GO TO error
  103 LET l1=VAL l$(2 TO ): IF STR$ l1<>l$(2 TO ) OR ABS (l1-50)>49 THEN GO TO error
  104 LET b$="": LET c$="": LET len=k0: LET x=2: INPUT (d$)'(l$);TAB 7; LINE a$
  106 IF a$="" THEN LET p$="": RETURN 
  110 LET e$=a$: LET a=2*CODE e$+5*CODE e$(2)+6*CODE e$(3)+4*CODE e$(4): RESTORE a: READ t$: IF t$<>a$ THEN GO TO error
  112 LET d=k0: LET n=k0: LET l2=k0: LET i=k0: READ a: IF NOT a THEN READ b,f: GO TO f
  114 INPUT (d$);" 1st"'(l$);TAB 7;(a$);TAB 14; LINE b$
  115 IF a>k1 THEN INPUT (d$);TAB 15+LEN b$;"2nd"'(l$);TAB 7;(a$);TAB 14;(b$);" "; LINE c$
  116 LET a=(b$<>"")+(c$<>"")
  120 LET x=3: LET i=k0: LET d=k0: LET n=k0: LET l2=k0: READ g: GO TO g
  125 LET b$=b$+("," AND (c$<>""))+c$: PRINT l;TAB 3;l$;TAB 8;a$;TAB 13;b$
  126 LET p$=CHR$ l1+e$+CHR$ LEN b$+CHR$ LEN m$+CHR$ l2+b$+m$
  129 POKE 23658,8
  130 RETURN 
  200 OPEN #2,s$: LET help=780
  202 INPUT "Assemble at ";(adr);". Origin at ?"; LINE z$: LET org=adr: IF z$<>"" THEN LET org=VAL z$
  204 LET dif=adr-org: DIM l(99): LET ptr=9: CLS : PRINT BRIGHT k1;"1st Pass - Labels"
  205 FOR x=k1 TO lns: LET l=FN c(k0): IF l<>k0 THEN LET l(l)=org: POKE scc,hi: PRINT "L";l;TAB 4;" = ";org," line ";x
  207 IF FN q$(k1,4)="DEFS" THEN LET org=org+VAL FN q$(8,7+FN c(5))
  210 LET org=org+FN c(6): LET ptr=ptr+8+FN c(5)+FN c(6): NEXT x
  220 LET org=adr-dif: LET ptr=9: PRINT ' BRIGHT k1;"2nd Pass - Assembly"
  223 FOR x=k1 TO lns: LET l$="": PRINT org;: LET a$=FN q$(k1,4): LET l=FN c(7): LET l1=FN c(5): LET l2=FN c(6): LET m$=FN q$(8+l1,7+l1+l2): IF FN c(k0)<>k0 THEN LET l$="L"+STR$ FN c(k0)
  224 IF org>65535 THEN LET z$="Address too large - Line "+STR$ x: GO TO run
  225 IF INKEY$<>"" THEN GO TO 225
  226 POKE scc,hi: IF l=hi THEN LET n=VAL FN q$(8,7+FN c(5)): LET l=k0: LET n2=INT (n/256): LET n1=n-256*n2: LET n2=n2+256*(n2<k0): IF a$="DEFW" THEN LET m$=CHR$ n1+CHR$ n2
  227 IF a$="DEFL" THEN LET l(FN c(k0))=n
  228 IF a$="DEFS" THEN LET org=org+n
  229 IF a$="DEFB" THEN LET m$=CHR$ n1
  230 PRINT TAB 6;l$;TAB 11;a$;TAB 16;FN q$(8,7+l1);" ";: LET ptr=ptr+8+l1+l2: IF NOT l THEN GO TO 250
  235 LET a=k1: IF l(l)=k0 THEN LET z$="Undefined label - Line "+STR$ x: GO TO run
  240 IF l2=2 THEN LET z$="Jump too far": LET f=l(l)-org-2: IF f>=-127 AND f<=128 THEN LET a=k0: LET f=256*(f<k0)+f: LET m$(2)=CHR$ f
  245 IF l2>2 THEN LET z$="Label too large": LET n2=INT (l(l)/256): LET n1=l(l)-256*n2: IF n2>=k0 AND n2<=hi THEN LET a=k0: LET m$(l2-k1)=CHR$ n1: LET m$(l2)=CHR$ n2
  248 IF a THEN LET z$=z$+" - Line "+STR$ x: GO TO run
  250 LET z$="": FOR y=k1 TO l2: IF b$="B" THEN IF a$<>"TEXT" THEN PRINT TAB 27; BRIGHT 1;CODE m$(y);: LET v=CODE m$(y): LET v=LEN STR$ v: PRINT BRIGHT 1;"    "(1 TO 4-v);
  251 IF b$="H" THEN IF a$<>"TEXT" THEN LET v=CODE m$(y): LET n$=h$(v/16+.5): LET v=v-INT (v/16)*16+.5: LET n$=n$+h$(v): PRINT TAB 28; BRIGHT 1;" ";n$;" ";
  255 POKE org+dif,CODE m$(y): LET org=org+k1: NEXT y: PRINT : NEXT x: LET len=org-adr+dif: PRINT '"  Origin = ";adr;" Len = ";len
  260 PRINT ' BRIGHT 1;"Label values"
  261 FOR z=1 TO 99: IF l(z) THEN PRINT "L";z;TAB 4;" = ";l(z)
  262 NEXT z
  270 GO TO 750
  300 READ v$,g: IF b$=v$ THEN LET s$=c$: GO SUB g: IF NOT x THEN READ b,f: GO TO f
  302 READ b,f: GO TO rd
  310 READ g,g1: LET s$=b$: GO SUB g: IF NOT x THEN LET s$=c$: LET x=3: GO SUB g1: IF NOT x THEN READ b,f: GO TO f
  312 READ b,f: GO TO rd
  320 READ g: IF c$="" THEN LET s$=b$: GO SUB g: IF NOT x THEN READ b,f: GO TO f
  322 READ b,f: GO TO rd
  330 READ v$: IF (b$+c$)=v$ THEN READ b,f: GO TO f
  332 READ b,f: GO TO rd
  340 READ g,v$: IF c$=v$ THEN LET s$=b$: GO SUB g: IF NOT x THEN READ b,f: GO TO f
  342 READ b,f: GO TO rd
  350 RESTORE 817+((LEN b$-5) AND (LEN b$<5)): READ s$: GO TO rd
  360 READ g,g1: LET s$=b$: GO SUB g: IF NOT x THEN LET r1=r: LET s$=c$: LET x=3: GO SUB g1: IF NOT x AND (r1<>6 OR r<>6) THEN READ b,f: GO TO f
  362 READ b,f: GO TO rd
  370 LET x=4: LET org=VAL b$: LET l2=hi: LET m$="": GO TO op
  372 LET x=4: LET n=VAL b$: LET l2=hi: LET m$=" ": GO TO op
  374 LET x=4: LET n=VAL b$: LET l2=hi: LET m$="  ": GO TO op
  376 LET m$=b$: GO TO op
  378 LET x=4: IF l1>k0 AND l1<100 THEN LET n=VAL b$: LET l2=hi: LET m$="": GO TO op
  379 LET x=k1: LET z$="No label": GO TO error
  395 LET x=4: GO TO error
  400 LET r=(s$="B")+(2 AND s$="C")+(3 AND s$="D")+(4 AND s$="E")+(5 AND s$="H")+(6 AND s$="L")+(7 AND s$="(HL)")+(8 AND s$="A"): IF r THEN LET r=r-k1: LET x=k0: RETURN 
  402 IF CODE s$=CODE "(" THEN LET i=221*(s$(2 TO 3)="IX")+253*(s$(2 TO 3)="IY"): IF i THEN LET r=6: LET d=VAL s$: IF d>=-128 AND d<=127 THEN LET d=d+256*(d<k0): LET x=k0: RETURN 
  404 RETURN 
  410 IF CODE s$=CODE """" THEN LET n=CODE s$(2 TO ): LET x=k0: RETURN 
  411 IF CODE s$=CODE "-" OR FN r(0,9,s$) OR CODE s$=196 THEN LET n=VAL s$: IF ABS n<=255 THEN LET n=n+256*(n<k0): LET x=k0: RETURN 
  412 RETURN 
  420 LET r=(s$="BC")+2*(s$="DE")+4*(s$="AF"): IF r THEN LET r=r-k1: LET x=k0: RETURN 
  422 GO TO 440
  430 LET r=(s$="BC")+2*(s$="DE")+4*(s$="SP"): IF r THEN LET r=r-k1: LET x=k0: RETURN 
  440 LET i=(s$="HL")+222*(s$="IX")+254*(s$="IY"): IF i THEN LET r=2: LET i=i-k1: LET x=k0: RETURN 
  442 RETURN 
  450 LET r=(s$="BC")+2*(s$="DE")+3*(s$=b$)+4*(s$="SP"): IF r THEN LET r=r-k1: LET x=k0: RETURN 
  460 LET r=(s$="NZ")+2*(s$="Z")+3*(s$="NC")+4*(s$="C")+5*(s$="PO")+6*(s$="PE")+7*(s$="P")+8*(s$="M"): IF r THEN LET r=r-k1: LET x=k0: RETURN 
  461 RETURN 
  470 IF CODE s$=CODE "-" OR FN r(k0,9,s$) OR CODE s$=196 THEN LET n=VAL s$: IF ABS n<=65535 THEN LET n=n+65536*(n<k0): LET x=k0: RETURN 
  471 IF CODE s$=CODE "L" THEN LET l2=VAL s$(2 TO ): LET x=k0: RETURN 
  472 IF CODE s$=CODE """" THEN LET n=256*CODE s$(2 TO )+CODE s$(3 TO ): LET x=k0: RETURN 
  473 RETURN 
  480 IF FN r(k0,9,b$) THEN LET n=VAL b$: IF n>=k0 AND n<=56 AND 8*INT (n/8)=n THEN LET x=k0: RETURN 
  481 RETURN 
  490 IF FN r(k0,7,b$) AND LEN b$=k1 THEN LET r1=VAL b$: LET x=k0: RETURN 
  491 RETURN 
  500 IF FN r(k0,2,b$) AND LEN b$=k1 THEN LET n=VAL b$: LET n=n+(n>k0): LET x=k0: RETURN 
  501 RETURN 
  510 GO SUB cf: IF NOT x AND r<4 THEN LET x=k0: RETURN 
  511 LET x=3: RETURN 
  520 IF CODE s$=CODE "(" THEN IF CODE s$(LEN s$)=CODE ")" THEN LET s$=s$(2 TO LEN s$-k1): GO TO v2
  521 RETURN 
  530 IF CODE s$=CODE "(" THEN IF CODE s$(LEN s$)=CODE ")" THEN LET s$=s$(2 TO LEN s$-k1): GO TO v1
  531 RETURN 
  600 LET n2=INT (n/256): LET n1=n-256*n2: LET m$=CHR$ 237+CHR$ b+CHR$ n1+CHR$ n2: GO TO op
  602 LET m$=((CHR$ i) AND i)+CHR$ b: GO TO op
  604 LET m$=((CHR$ i) AND i)+CHR$ b+((CHR$ d) AND i): GO TO op
  606 LET m$=((CHR$ i) AND i)+CHR$ 203+((CHR$ d) AND i)+CHR$ b: GO TO op
  608 LET n2=INT (n/256): LET n1=n-256*n2: LET m$=((CHR$ i) AND i)+CHR$ b+CHR$ n1+CHR$ n2: GO TO op
  610 LET m$=CHR$ b+CHR$ n: GO TO op
  612 LET m$=CHR$ b+CHR$ 0: GO TO op
  614 LET m$=CHR$ 237+CHR$ b: GO TO op
  616 LET m$=((CHR$ i) AND i)+CHR$ b+((CHR$ d) AND i)+CHR$ n: GO TO op
  620 STOP 
  699 GO SUB 80: GO TO 701
  700 BEEP .1,30: POKE 23658,8: INPUT "Error"'(z$);TAB 30; LINE z$
  701 OPEN #2,"S": INPUT AT k0,k0;"Append Insert Delete Replace"'"Print  Save   Load   Control "; LINE z$
  705 IF z$="I" THEN INPUT "Before ";l1: GO TO 20
  710 IF z$="A" THEN PRINT BRIGHT k1;"Appending": GO TO 50
  715 IF z$="D" THEN INPUT "From ";l1;" to ";l2: GO TO 40
  717 IF z$="R" THEN INPUT "Replace ";l1;" to ";l2: GO TO 40
  719 IF z$="PR" THEN OPEN #2,"P"
  720 IF z$="P" OR z$="PR" AND lns<23 THEN LET l1=k1: LET l2=lns: GO TO 30
  725 IF z$="P" OR z$="PR" THEN INPUT "From ";l1: LET l2=lns: GO TO 30
  730 IF z$="C" THEN GO TO 780
  737 IF z$="S" THEN INPUT "File name ";a$: RANDOMIZE lns: LET q$(k1)=CHR$ PEEK 23670: LET q$(2)=CHR$ PEEK 23671: RANDOMIZE mc: LET q$(3)=CHR$ PEEK 23670: LET q$(4)=CHR$ PEEK 23671: LET q$(5 TO 8)=STR$ last: SAVE a$ DATA q$(): PRINT FLASH k1;"Verify": VERIFY a$ DATA q$()
  740 IF z$="L" THEN INPUT "File name ";a$: LOAD a$ DATA q$(): LET a$="": LET lns=CODE q$(1)+256*CODE q$(2): LET mc=CODE q$(3)+256*CODE q$(4): LET last=VAL q$(5 TO 8): GO TO 780
  745 GO TO 701
  750 OPEN #2,"S": INPUT "Save Run Control Edit "; LINE z$
  755 IF z$="E" THEN LET l1=k1: LET l2=lns: GO TO 30
  758 IF z$="C" THEN GO TO 780
  760 IF z$="S" AND len THEN INPUT "Name of Mcode ";a$: SAVE a$CODE adr,len
  765 IF z$="R" AND NOT dif AND len THEN INPUT "Origin= ";(adr);". Enter at "; LINE a$: LET org=adr: IF a$<>"" THEN LET org=VAL a$
  766 IF z$="R" AND NOT dif AND len THEN CLS : PRINT #2;AT k0,k0;: RANDOMIZE USR org
  770 GO TO 750
  780 CLS : PRINT BRIGHT K1;" ZX SPECTRUM EDITOR/ASSEMBLER       DAVID HAWKINS  FEB 1983     "'''
  781 PRINT "TEXT FILE"''" LENGTH = ";LEN q$'"   USED = ";last'" UNUSED = ";LEN q$-last'"  LINES = ";lns'"  MCODE = ";mc''"SPARE"''" LENGTH = ";FN a(23730)-FN a(23653)''"CODE"''"  START = ";adr'" LENGTH = ";len
  785 INPUT "EDIT  ASSEMBLE  CODE  RESTART "; LINE z$
  786 IF z$="C" THEN GO TO 750
  788 IF z$="R" THEN GO TO 800
  790 IF z$="A" THEN GO TO 795
  792 IF z$="E" THEN LET l1=k1: LET l2=lns: GO TO 30
  793 IF z$="QUIT" THEN STOP 
  794 GO TO 785
  795 INPUT "Screen or Printer "; LINE s$: IF s$<>"S" AND s$<>"P" THEN GO TO 795
  796 INPUT "Bytes or Nobytes "; LINE b$: IF b$<>"B" AND b$<>"N" AND b$<>"H" THEN GO TO 796
  797 GO TO 200
  800 INPUT AT 0,0;"File Length = ";a;" Code Start = ";z: RANDOMIZE a: CLEAR z-1: LET a=FN a(23670)
  801 DIM q$(a): LET k0=NOT a: LET k1=NOT k0: GO SUB 2000: LET a$="": LET b$="": LET c$="": LET l$="": LET lns=k0: LET last=8: LET mc=k0: LET scc=23692: LET hi=255: LET dif=k0: LET h$="0123456789ABCDEF"
  802 LET adr=FN a(23730)+1: LET len=k0: POKE 23658,8: DIM e$(4): DIM l(99): LET ptr=9: LET rd=120: LET op=125: LET error=90: LET help=699: LET org=adr: LET len=k0
  804 LET r1=k0: LET ps=370: LET ldr=360: LET load=350: LET bv1=530: LET bv=520: LET ix=k0: LET iy=k0: LET sv=300: LET vv=310: LET vn=320: LET ss=330: LET vs=340: LET nn=395: LET ri=400: LET v1=410: LET da=420: LET ds=430: LET di=440: LET dd=450: LET cf=460: LET v2=470: LET ra=480: LET bn=490: LET im=500: LET cs=510
  806 LET run=700: LET f0=600: LET f1=602: LET f2=604: LET f3=606: LET f4=608: LET f5=610: LET f6=612: LET f7=614: LET f8=616: LET d$="Label  Opcode": GO TO 780
  812 DATA "LD",2,load
  813 DATA "",ldr,ri,ri,64+8*r1+r,f2,vv,ri,v1,6+8*r,f8,sv,"A",bv,58,f4,ss,"A(BC)",10,f1,ss,"A(DE)",26,f1,ss,"AI",87,f7,ss,"AR",95,f7,ss,"IA",71,f7,ss,"RA",79,f7,nn
  814 DATA "",sv,"BC",bv,75,f0,sv,"DE",bv,91,f0,vv,di,bv,42,f4,vv,ds,v2,1+16*r,f4,sv,"HL",v2,33,f4,sv,"SP",bv,123,f0,sv,"SP",di,249,f1,nn
  817 DATA "",ss,"(BC)A",2,f1,ss,"(DE)A",18,f1,ldr,ri,ri,64+8*r1+r,f2,vv,ri,v1,6+8*r,f8,vs,bv,"A",50,f4,vv,bv,di,34,f4,vv,bv,ds,67+16*r,f0,nn
  821 DATA "DI",k0,243,f1
  823 DATA "EI",k0,251,f1
  851 DATA "IM",k1,vn,im,70+8*n,f7,nn
  854 DATA "CP",k1,vn,ri,184+r,f2,vn,v1,254,f5,nn
  856 DATA "IN",2,sv,"A",bv1,219,f5,vs,ri,"(C)",64+8*r,f7,nn
  864 DATA "RL",k1,vn,ri,16+r,f3,nn
  868 DATA "JP",2,vv,cf,v2,194+8*r,f4,ss,"(HL)",233,f1,vn,402,233,f1,vn,v2,195,f4,nn
  878 DATA "JR",2,vv,cs,v2,32+8*r,f6,vn,v2,24,f6,nn
  888 DATA "OR",k1,vn,ri,176+r,f2,vn,v1,246,f5,nn
  894 DATA "RR",k1,vn,ri,24+r,f3,nn
  898 DATA "EX",2,sv,"(SP)",di,227,f1,ss,"AFAF'",8,f1,ss,"DEHL",235,f1,nn
  979 DATA "DAA",k0,39,f1
 1000 DATA "ADC",2,sv,"A",ri,136+r,f2,sv,"A",v1,206,f5,sv,"HL",dd,74+16*r,f7,nn
 1006 DATA "ADD",2,sv,"A",ri,128+r,f2,sv,"A",v1,198,f5,vv,di,dd,9+16*r,f1,nn
 1011 DATA "DEC",k1,vn,ri,5+8*r,f2,vn,ds,11+16*r,f1,nn
 1017 DATA "CCF",k0,63,f1
 1026 DATA "SBC",2,sv,"A",ri,152+r,f2,sv,"~",v1,222,f5,sv,"HL",dd,66+16*r,f7,nn
 1028 DATA "LDD",k0,168,f7
 1049 DATA "SCF",k0,55,f1
 1055 DATA "NEG",k0,68,f7
 1056 DATA "AND",k1,vn,ri,160+r,f2,vn,v1,230,f5,nn
 1058 DATA "LDI",k0,160,f7
 1062 DATA "RLA",k0,23,f1
 1064 DATA "SLA",k1,vn,ri,32+r,f3,nn
 1066 DATA "INC",k1,vn,ri,4+8*r,f2,vn,ds,3+16*r,f1,nn
 1070 DATA "CPD",k0,169,f7
 1072 DATA "IND",k0,170,f7
 1074 DATA "RLC",k1,vn,ri,r,f3,nn
 1080 DATA "RLD",k0,111,f7
 1092 DATA "RRA",k0,31,f1
 1094 DATA "SRA",k1,vn,ri,40+r,f3,nn
 1096 DATA "TRA",k1,op
 1099 DATA "REM",k1,op
 1100 DATA "CPI",k0,161,f7
 1102 DATA "INI",k0,162,f7
 1104 DATA "RRC",k1,vn,ri,8+r,f3,nn
 1110 DATA "RRD",k0,103,f7
 1115 DATA "SUB",k1,vn,ri,144+r,f2,vn,v1,214,f5,nn
 1118 DATA "CPL",k0,47,f1
 1129 DATA "BIT",2,vv,bn,ri,64+8*r1+r,f3,nn
 1135 DATA "RES",2,vv,bn,ri,128+8*r1+r,f3,nn
 1141 DATA "RET",k1,ss,"",201,f1,vn,cf,192+8*r,f1,nn
 1143 DATA "SET",2,vv,bn,ri,192+8*r1+r,f3,nn
 1159 DATA "NOP",k0,k0,f1
 1160 DATA "SRL",k1,vn,ri,56+r,f3,nn
 1163 DATA "POP",k1,vn,da,193+16*r,f1,nn
 1165 DATA "DEFB",k1,ps+2
 1191 DATA "XOR",k1,vn,ri,168+r,f2,vn,v1,238,f5,nn
 1205 DATA "DEFL",k1,ps+8
 1206 DATA "RLCA",k0,7,f1
 1211 DATA "RST",k1,vn,ra,199+n,f1,nn
 1215 DATA "OUT",2,vs,bv1,"A",211,f5,sv,"(C)",ri,65+8*r,f7,nn
 1219 DATA "CALL",2,vv,cf,v2,196+8*r,f4,vn,v2,205,f4,nn
 1228 DATA "LDDR",k0,184,f7
 1233 DATA "DEFS",k1,ps
 1234 DATA "EXX",k0,217,f1
 1236 DATA "RRCA",k0,15,f1
 1249 DATA "DEFW",k1,ps+4
 1258 DATA "LDIR",k0,176,f7
 1261 DATA "HALT",k0,118,f1
 1270 DATA "CPDR",k0,185,f7
 1272 DATA "INDR",k0,186,f7
 1300 DATA "CPIR",k0,177,f7
 1302 DATA "INIR",k0,178,f7
 1305 DATA "RETI",k0,77,f7
 1314 DATA "OTDR",k0,187,f7
 1325 DATA "RETN",k0,69,f7
 1334 DATA "DJNZ",k1,vn,v2,16,f6,nn
 1344 DATA "OTIR",k0,179,f7
 1359 DATA "OUTD",k0,171,f7
 1371 DATA "PUSH",k1,vn,da,197+16*r,f1,nn
 1377 DATA "TEXT",k1,ps+6
 1379 DATA "OUTI",k0,163,f7
 2000 LET insert=FN a(23637)+5
 2001 REM GO SUB Kv\\*M\\+ FOR *r\\ FOR GO SUB LN <>x
 2004 RESTORE 2006: FOR z=insert TO insert+18: READ a: POKE z,a: NEXT z
 2005 RETURN 
 2006 DATA 237,75,118,92,42,77,92,9,43,235,42,114,92,25,235,237,184,3,201
 9998 CLEAR : SAVE "DEV-Assem" LINE 1: BEEP .2,0: PRINT FLASH 1;"VERIFY": VERIFY "": BEEP .2,0: PRINT "OK"

People

No people associated with this content.

Scroll to Top