"$Header$"
#define em_bsize	2	/* must be equal to EM_BSIZE */
#define	ND	!defined($1)
#define	D	defined($1)
#define	BASE	240
#define MIN	(0-BASE)
#define MAX	(254-em_bsize-BASE)
#define IN(x)	(x>=MIN && x<=MAX)
#define IND(x)	(x>=MIN && x<=(MAX-2))

/*****************************************************\
****						   ****
****     6 5 0 0   B A C K   E N D   T A B L E	   ****
****						   ****
\*****************************************************/


/*
 *   INTEGER SIZE:   16 bits
 *   POINTER SIZE:   16 bits
 *   NO FLOATS
 */


EM_WSIZE = 2
EM_PSIZE = 2
EM_BSIZE = 2



/*********************\
*  R E G I S T E R S  *
\*********************/

REGISTERS:
AA = ("a",1), REG.
XX = ("x",1), REG.
AX = ("<dummy>",2,AA,XX), R16.

/* AX is a registerpair, A contains the highbyte of a word and
 * X contains the lowbyte
 */


/***************\
*  T O K E N S  *
\***************/

TOKENS:
IMMEDIATE 	= {INT off;} 1  "#%[off]" /* a fake token the
					   * cgg needs one
					   */



/***********************************\
*  T O K E N E X P R E S S I O N S  *
\***********************************/

TOKENEXPRESSIONS:
AAA = IMMEDIATE		/* a fake tokenexpression
			 * the cgg needs one
			 */


/***********\
*  C O D E  *
\***********/

CODE:

/* GROUP 1 - LOAD */

loc ($1%256)==($1/256)	| |
		allocate(R16)
		"lda #[$1].l"
		"tax"
					| %[a] | |
loc	 | |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
					| %[a] | |
ldc highw(1)==loww(1) && (loww(1)%256)==(loww(1)/256) | |
		allocate(R16)
		"lda #[%(loww(1)%)].l"
		"tax"
		"jsr Push"
					| %[a] | |
ldc	 | |
		allocate(R16)
		"lda #[%(highw(1)%)].h"
		"ldx #[%(highw(1)%)].l"
		"jsr Push"
		"lda #[%(loww(1)%)].h"
		"ldx #[%(loww(1)%)].l"
					| %[a] | |
lol IN($1)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"tax"
		"iny"
		"lda (LBl),y"
					| %[a] | |
lol 	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Lol"
					| %[a] | |
loe	| |
		allocate(R16)
		"lda $1+1"
		"ldx $1"
					| %[a] | |
lil IN($1)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"tax"
		"iny"
		"lda (LBl),y"
		"jsr Loi"
					| %[a] | |
lil 	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Lol"
		"jsr Loi"
					| %[a] | |
lof $1==0	| R16 |
		"jsr Loi"
					| %[1] | |
lof    | |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Adi2"
		"jsr Loi"
					| %[a] | |
lal	| |
		allocate(R16)
		"clc"
		"lda #[$1].l"
		"adc LB"
		"tax"
		"lda #[$1].h"
		"adc LB+1"
					| %[a] | |
lae 	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
					| %[a] | |
lxl $1==0	| |
		allocate(R16)
		"lda LB+1"
		"ldx LB"
					| %[a] | |
lxl $1<=255	| |		/* n restricted to a max of 255 */
		allocate(R16)
		"ldx #[$1].l"
		"jsr Lxl"
					| %[a] | |
lxa $1==0	| |
		allocate(R16)
		"jsr Lxa1"
					| %[a] | |
lxa $1<=255	| |		/* n restricted to a max of 255 */
		allocate(R16)
		"ldx #[$1].l"
		"jsr Lxa2"
					| %[a] | |
loi $1==1	| R16 |
		"jsr Loi1"
					| %[1] | |
loi $1==2	| R16 |
		"jsr Loi"
					| %[1] | |
loi $1==4	| R16 |
		"jsr Ldi"
					| | |
loi D		| R16 |
		"ldy #[$1].h"
		"sty NBYTES+1"
		"ldy #[$1].l"
		"jsr Loil"
					| | |
los $1==2	| R16 |
		"jsr Los"
					| | |
ldl IND($1)	| |
		allocate(R16)
		"ldy #BASE+$1+3"
		"lda (LBl),y"
		"pha"
		"dey"
		"lda (LBl),y"
		"tax"
		"pla"
		"jsr Push"
		"dey"
		"lda (LBl),y"
		"pha"
		"dey"
		"lda (LBl),y"
		"tax"
		"pla"
					| %[a] | |
ldl	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Locaddr"
		"jsr Ldo"
					| | |
lde	| |
		allocate(R16)
		"lda $1+3"
		"ldx $1+2"
		"jsr Push"
		"lda $1+1"
		"ldx $1"
					| %[a] | |
ldf $1==0	| R16 |
		"jsr Ldi"
					| | |
ldf	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Adi2"
		"jsr Ldi"
					| | |
lpi 	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
					| %[a] | |


/* GROUP 2 - STORE */

stl IN($1)	| R16 |
		"ldy #BASE+1+$1"
		"sta (LBl),y"
		"txa"
		"dey"
		"sta (LBl),y"
					| | |
stl	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Stl"
					| | |
ste	| R16 |
		"sta $1+1"
		"stx $1"
					| | |
sil IN($1)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"tax"
		"iny"
		"lda (LBl),y"
		"jsr Sti"
					| | |
sil	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Lol"
		"jsr Sti"
					| | |
stf $1==0	| R16 |
		"jsr Sti"
					| | |
stf	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Adi2"
		"jsr Sti"
					| | |
sti $1==1	| R16 |
		"jsr Sti1"
					| | |
sti $1==2	| R16 |
		"jsr Sti"
					| | |
sti $1==4	| R16 |
		"jsr Sdi"
					| | |
sti D	| R16 |
		"ldy #[$1].h"
		"sty NBYTES+1"
		"ldy #[$1].l"
		"jsr Stil"
					| | |
sts $1==2	| R16 |
		"jsr Sts"
					| | |
sdl IND($1)	| R16 |
		"ldy #BASE+$1"
		"pha"
		"txa"
		"sta (LBl),y"
		"iny"
		"pla"
		"sta (LBl),y"
		"jsr Pop"
		"iny"
		"pha"
		"txa"
		"sta (LBl),y"
		"iny"
		"pla"
		"sta (LBl),y"
					| | |
sdl	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Locaddr"
		"jsr Sdo"
					| | |
sde	| R16 |
		"sta $1+1"
		"stx $1"
		"jsr Pop"
		"sta $1+3"
		"stx $1+2"
					| | |
sdf $1==0	| R16 |
		"jsr Sdi"
					| | |
sdf	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Adi2"
		"jsr Sdi"
					| | |


/* GROUP 3 - INTEGER ARITHMETIC */

loc lol adi (IN($2) && $3==2)	| |
		allocate(R16)
		"ldy #BASE+$2"
		"clc"
		"lda #[$1].l"
		"adc (LBl),y"
		"tax"
		"iny"
		"lda #[$1].h"
		"adc (LBl),y"
					| %[a] | |
lol loc adi	| | | | loc $2 lol $1 adi $3 |
lol lol adi (IN($1) && IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1+1"
		"lda (LBl),y"
		"pha"
		"dey"
		"lda (LBl),y"
		"ldy #BASE+$2"
		"clc"
		"adc (LBl),y"
		"tax"
		"iny"
		"pla"
		"adc (LBl),y"
					| %[a] | |
lol loe adi (IN($1) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"clc"
		"lda (LBl),y"
		"adc $2"
		"tax"
		"iny"
		"lda (LBl),y"
		"adc $2+1"
					| %[a] | |
loe lol adi	| | | | lol $2 loe $1 adi $3 |
loe loe adi $3==2	| |
		allocate(R16)
		"clc"
		"lda $1"
		"adc $2"
		"tax"
		"lda $1+1"
		"adc $2+1"
					| %[a] | |
loc loe adi $3==2	| |
		allocate(R16)
		"clc"
		"lda #[$1].l"
		"adc $2"
		"tax"
		"lda #[$1].h"
		"adc $2+1"
					| %[a] | |
loe loc adi 	| | | | loc $2 loe $1 adi $3 |
ldl adi IND($1) && $2==2	| |
		allocate(R16)
		"ldy #BASE+$1"
		"clc"
		"lda (LBl),y"
		"iny"
		"iny"
		"adc (LBl),y"
		"tax"
		"dey"
		"lda (LBl),y"
		"iny"
		"iny"
		"adc (LBl),y"
					| %[a] | |
lde adi $2==2	| |
		allocate(R16)
		"clc"
		"lda $1"
		"adc $1+2"
		"tax"
		"lda $1+1"
		"adc $1+3"
					| %[a] | |
loc adi $2==2 | R16 |
		"pha"
		"txa"
		"clc"
		"adc #[$1].l"
		"tax"
		"pla"
		"adc #[$1].h"
					| %[1] | |
lol adi IN($1) && $2==2 | R16 |
		"pha"
		"ldy #BASE+$1"
		"clc"
		"txa"
		"adc (LBl),y"
		"tax"
		"iny"
		"pla"
		"adc (LBl),y"
					| %[1] | |
loe adi $2==2	| R16 |
		"pha"
		"clc"
		"txa"
		"adc $1"
		"tax"
		"pla"
		"adc $1+1"
					| %[1] | |
lol lol adi IN($1) && !IN($2) && $3==2
		| | | | lol $2 lol $1 adi $3 |
adi $1==2	| R16 |
		"jsr Adi2"
					| %[1] | |
adi $1==4	| |
		allocate(R16)
		"jsr Adi4"
					| | |
adi ND	| R16 |
		"jsr Test2"
		"jsr Adi2"
					| %[1] | |
loc lol sbi (IN($2) && $3==2)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"sec"
		"lda #[$1].l"
		"sbc (LBl),y"
		"tax"
		"iny"
		"lda #[$1].h"
 		"sbc (LBl),y"
 					| %[a] | |
lol loc sbi	| | | | lol $1 loc 0-$2 adi $3 |
lol lol sbi (IN($1) && IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1+1"
		"lda (LBl),y"
		"pha"
		"dey"
		"lda (LBl),y"
		"ldy #BASE+$2"
		"sec"
		"sbc (LBl),y"
		"tax"
		"iny"
		"pla"
		"sbc (LBl),y"
					| %[a] | |
lol loe sbi (IN($1) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"sec"
		"lda (LBl),y"
		"sbc $2"
		"tax"
		"iny"
		"lda (LBl),y"
		"sbc $2+1"
					| %[a] | |
loe lol sbi (IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"sec"
		"lda $2"
		"sbc (LBl),y"
		"tax"
		"iny"
		"lda $2+1"
		"sbc (LBl),y"
					| %[a] | |
loe loe sbi $3==2	| |
		allocate(R16)
		"sec"
		"lda $1"
		"sbc $2"
		"tax"
		"lda $1+1"
		"sbc $2+1"
					| %[a] | |
loc loe sbi $3==2	| |
		allocate(R16)
		"sec"
		"lda #[$1].l"
		"sbc $2"
		"tax"
		"lda #[$1].h"
		"sbc $2+1"
					| %[a] | |
loe loc sbi 	| | | | loe $1 loc 0-$2 adi $3 |
ldl sbi IND($1) && $2==2	| |
		allocate(R16)
		"ldy #BASE+$1+2"
		"sec"
		"lda (LBl),y"
		"dey"
		"dey"
		"sbc (LBl),y"
		"tax"
		"ldy #BASE+$1+3"
		"lda (LBl),y"
		"dey"
		"dey"
		"sbc (LBl),y"
					| %[a] | |
lde sbi $2==2	| |
		allocate(R16)
		"sec"
		"lda $1+2"
		"sbc $1"
		"tax"
		"lda $1+3"
		"sbc $1"
					| %[a] | |
loc sbi $2==2	| R16 |
		"pha"
		"txa"
		"sec"
		"sbc #[$1].l"
		"tax"
		"pla"
		"sbc #[$1].h"
					| %[1] | |
lol sbi IN($1) && $2==2 | R16 |
		"pha"
		"ldy #BASE+$1"
		"sec"
		"txa"
		"sbc (LBl),y"
		"tax"
		"iny"
		"pla"
		"sbc #[$1].h"
					| %[1] | |
loe sbi $2==2 | R16 |
		"pha"
		"sec"
		"txa"
		"sbc $1"
		"tax"
		"pla"
		"sbc $1+1"
					| %[1] | |
sbi $1==2	| R16 |
		"jsr Sbi2"
					| %[1] | |
sbi $1==4	| |
		allocate(R16)
		"jsr Sbi4"
					| | |
sbi ND	| R16 |
		"jsr Test2"
		"jsr Sbi2"
					| %[1] | |
loc lol mli (IN($2) && $3==2)	| |
		allocate(R16)
		"lda #[$1].l"
		"sta ARTH"
		"lda #[$1].h"
		"sta ARTH+1"
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"jsr Mlinp"
 					| %[a] | |
lol loc mli	| | | | loc $2 lol $1 mli $3 |
lol lol mli (IN($1) && IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[a] | |
lol loe mli (IN($1) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[a] | |
loe lol mli (IN($2) && $3==2) | | | | lol $2 loe $1 mli $3 |
loe loe mli $3==2	| |
		allocate(R16)
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[a] | |
loc loe mli $3==2	| |
		allocate(R16)
		"lda #[$1].l"
		"sta ARTH"
		"lda #[$1].h"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[a] | |
loe loc mli 	| | | | loc $2 loe $1 mli $3 |
ldl mli IND($1) && $2==2	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"iny"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[a] | |
lde mli $2==2	| |
		allocate(R16)
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"lda $1+2"
		"sta ARTH+2"
		"lda $1+3"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[a] | |
loc mli $2==2 | R16 |
		"stx ARTH"
		"sta ARTH+1"
		"lda #[$1].l"
		"sta ARTH+2"
		"lda #[$1].h"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[1] | |
lol mli IN($1) && $2==2 | R16 |
		"stx ARTH"
		"sta ARTH+1"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[1] | |
loe mli $2==2	| R16 |
		"stx ARTH"
		"sta ARTH+1"
		"lda $1"
		"sta ARTH+2"
		"lda $1+1"
		"sta ARTH+3"
		"jsr Mlinp"
					| %[1] | |
lol lol mli IN($1) && !IN($2) && $3==2
		| | | | lol $2 lol $1 mli $3 |
mli $1==2	| R16 |
		"jsr Mli2"
					| %[1] | |
mli $1==4	| |
		allocate(R16)
		"jsr Mli4"
					| | |
mli ND	| R16 |
		"jsr Test2"
		"jsr Mli2"
					| %[1] | |
loc lol dvi (IN($2) && $3==2)	| |
		allocate(R16)
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"lda #[$1].l"
		"sta ARTH+2"
		"lda #[$1].h"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
 					| %[a] | |
lol loc dvi (IN($1) && $3==2)	| |
		allocate(R16)
		"lda #[$2].l"
		"sta ARTH"
		"lda #[$2].h"
		"sta ARTH+1"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
 					| %[a] | |
lol lol dvi (IN($1) && IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
lol loe dvi (IN($1) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"lda $2"
		"sta ARTH"
		"lda $2+1"
		"sta ARTH+1"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
loe lol dvi (IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
loe loe dvi $3==2	| |
		allocate(R16)
		"lda $2"
		"sta ARTH"
		"lda $2+1"
		"sta ARTH+1"
		"lda $1"
		"sta ARTH+2"
		"lda $1+1"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
loc loe dvi $3==2	| |
		allocate(R16)
		"lda #[$1].l"
		"sta ARTH+2"
		"lda #[$1].h"
		"sta ARTH+3"
		"lda $2"
		"sta ARTH"
		"lda $2+1"
		"sta ARTH+1"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
loe loc dvi $3==2	| |
		allocate(R16)
		"lda #[$2].l"
		"sta ARTH"
		"lda #[$2].h"
		"sta ARTH+1"
		"lda $1"
		"sta ARTH+2"
		"lda $1+1"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
ldl dvi IND($1) && $2==2	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"iny"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
lde dvi $2==2	| |
		allocate(R16)
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"lda $1+2"
		"sta ARTH+2"
		"lda $1+3"
		"sta ARTH+3"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[a] | |
loc dvi $2==2 | R16 |
		"stx ARTH+2"
		"sta ARTH+3"
		"lda #[$1].l"
		"sta ARTH"
		"lda #[$1].h"
		"sta ARTH+1"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[1] | |
lol dvi IN($1) && $2==2 | R16 |
		"stx ARTH+2"
		"sta ARTH+3"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[1] | |
loe dvi $2==2	| R16 |
		"stx ARTH+2"
		"sta ARTH+3"
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"ldy #1"
		"sty UNSIGN"
		"jsr Div"
					| %[1] | |
dvi $1==2	| R16 |
		"jsr Dvi2"
					| %[1] | |
dvi $1==4	| |
		allocate(R16)
		"jsr Dvi4"
					| | |
dvi ND	| R16 |
		"jsr Test2"
		"jsr Dvi2"
					| %[1] | |
rmi $1==2	| R16 |
		"jsr Rmi2"
					| %[1] | |
rmi $1==4	| |
		allocate(R16)
		"jsr Rmi4"
					| | |
rmi ND	| R16 |
		"jsr Test2"
		"jsr Rmi2"
					| %[1] | |
ngi $1==2	| R16 |
		"jsr Ngi2"
					| %[1] | |
ngi $1==4	| |
		allocate(R16)
		"lda SP+1"
		"ldx SP+2"
		"jsr Ngi4"
					| | |
ngi ND	| R16 |
		"jsr Test2"
		"jsr Ngi2"
					| %[1] | |
sli $1==2	| R16 |
		"jsr Sli2"
					| %[1] | |
sli $1==4	| R16 |
		"jsr Sli4"
					| | |
sli ND	| R16 |
		"jsr Test2"
		"jsr Sli2"
					| %[1] | |
sri $1==2	| R16 |
		"jsr Sri2"
					| %[1] | |
sri $1==4	| R16 |
		"jsr Sri4"
					| | |
sri ND	| R16 |
		"jsr Test2"
		"jsr Sri2"
					| %[1] | |


/* GROUP 4 - UNSIGNED ARITHMETIC */

loc lol adu	| | | | loc $1 lol $2 adi $3 |
lol loc adu	| | | | lol $1 loc $2 adi $3 |
lol lol adu	| | | | lol $1 lol $2 adi $3 |
lol loe adu	| | | | lol $1 loe $2 adi $3 |
loe lol adu	| | | | loe $1 lol $2 adi $3 |
loe loe adu	| | | | loe $1 loe $2 adi $3 |
loc loe adu	| | | | loc $1 loe $2 adi $3 |
loe loc adu	| | | | loe $1 loc $2 adi $3 |
ldl adu		| | | | ldl $1 adi $2 |
lde adu		| | | | lde $1 adi $2 |
loc adu		| | | | loc $1 adi $2 |
lol adu		| | | | lol $1 adi $2 |
loe adu		| | | | loe $1 adi $2 |
adu		| | | | adi $1 |

loc lol sbu	| | | | loc $1 lol $2 sbi $3 |
lol loc sbu	| | | | lol $1 loc $2 sbi $3 |
lol lol sbu	| | | | lol $1 lol $2 sbi $3 |
lol loe sbu	| | | | lol $1 loe $2 sbi $3 |
loe lol sbu	| | | | loe $1 lol $2 sbi $3 |
loe loe sbu	| | | | loe $1 loe $2 sbi $3 |
loc loe sbu	| | | | loc $1 loe $2 sbi $3 |
loe loc sbu	| | | | loe $1 loc $2 sbi $3 |
ldl sbu		| | | | ldl $1 sbi $2 |
lde sbu		| | | | lde $1 sbi $2 |
loc sbu		| | | | loc $1 sbi $2 |
lol sbu		| | | | lol $1 sbi $2 |
loe sbu		| | | | loe $1 sbi $2 |
sbu		| | | | sbi $1 |

loc lol mlu (IN($2) && $3==2)	| |
		allocate(R16)
		"lda #[$1].l"
		"sta ARTH"
		"lda #[$1].h"
		"sta ARTH+1"
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
 					| %[a] | |
lol loc mlu	| | | | loc $2 lol $1 mlu $3 |
lol lol mlu (IN($1) && IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[a] | |
lol loe mlu (IN($1) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[a] | |
loe lol mlu (IN($2) && $3==2) | | | | lol $2 loe $1 mlu $3 |
loe loe mlu $3==2	| |
		allocate(R16)
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[a] | |
loc loe mlu $3==2	| |
		allocate(R16)
		"lda #[$1].l"
		"sta ARTH"
		"lda #[$1].h"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[a] | |
loe loc mlu 	| | | | loc $2 loe $1 mlu $3 |
ldl mlu IND($1) && $2==2	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"iny"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[a] | |
lde mlu $2==2	| |
		allocate(R16)
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"lda $1+2"
		"sta ARTH+2"
		"lda $1+3"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[a] | |
loc mlu $2==2 | R16 |
		"stx ARTH"
		"sta ARTH+1"
		"lda #[$1].l"
		"sta ARTH+2"
		"lda #[$1].h"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[1] | |
lol mlu IN($1) && $2==2 | R16 |
		"stx ARTH"
		"sta ARTH+1"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[1] | |
loe mlu $2==2	| R16 |
		"stx ARTH"
		"sta ARTH+1"
		"lda $1"
		"sta ARTH+2"
		"lda $1+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Mul"
					| %[1] | |
lol lol mlu IN($1) && !IN($2) && $3==2
		| | | | lol $2 lol $1 mlu $3 |
mlu $1==2	| R16 |
		"jsr Mlu2"
					| %[1] | |
mlu $1==4	| |
		allocate(R16)
		"jsr Mlu4"
					| | |
mlu ND	| R16 |
		"jsr Test2"
		"jsr Mlu2"
					| %[1] | |

loc lol dvu (IN($2) && $3==2)	| |
		allocate(R16)
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"lda #[$1].l"
		"sta ARTH+2"
		"lda #[$1].h"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
 					| %[a] | |
lol loc dvu (IN($1) && $3==2)	| |
		allocate(R16)
		"lda #[$2].l"
		"sta ARTH"
		"lda #[$2].h"
		"sta ARTH+1"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
 					| %[a] | |
lol lol dvu (IN($1) && IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
lol loe dvu (IN($1) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"lda $2"
		"sta ARTH"
		"lda $2+1"
		"sta ARTH+1"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
loe lol dvu (IN($2) && $3==2) | |
		allocate(R16)
		"ldy #BASE+$2"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"lda $2"
		"sta ARTH+2"
		"lda $2+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
loe loe dvu $3==2	| |
		allocate(R16)
		"lda $2"
		"sta ARTH"
		"lda $2+1"
		"sta ARTH+1"
		"lda $1"
		"sta ARTH+2"
		"lda $1+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
loc loe dvu $3==2	| |
		allocate(R16)
		"lda #[$1].l"
		"sta ARTH+2"
		"lda #[$1].h"
		"sta ARTH+3"
		"lda $2"
		"sta ARTH"
		"lda $2+1"
		"sta ARTH+1"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
loe loc dvu $3==2	| |
		allocate(R16)
		"lda #[$2].l"
		"sta ARTH"
		"lda #[$2].h"
		"sta ARTH+1"
		"lda $1"
		"sta ARTH+2"
		"lda $1+1"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
ldl dvu IND($1) && $2==2	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"iny"
		"lda (LBl),y"
		"sta ARTH+2"
		"iny"
		"lda (LBl),y"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
lde dvu $2==2	| |
		allocate(R16)
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"lda $1+2"
		"sta ARTH+2"
		"lda $1+3"
		"sta ARTH+3"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[a] | |
loc dvu $2==2 | R16 |
		"stx ARTH+2"
		"sta ARTH+3"
		"lda #[$1].l"
		"sta ARTH"
		"lda #[$1].h"
		"sta ARTH+1"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[1] | |
lol dvu IN($1) && $2==2 | R16 |
		"stx ARTH+2"
		"sta ARTH+3"
		"ldy #BASE+$1"
		"lda (LBl),y"
		"sta ARTH"
		"iny"
		"lda (LBl),y"
		"sta ARTH+1"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[1] | |
loe dvu $2==2	| R16 |
		"stx ARTH+2"
		"sta ARTH+3"
		"lda $1"
		"sta ARTH"
		"lda $1+1"
		"sta ARTH+1"
		"ldy #0"
		"sty UNSIGN"
		"jsr Duv"
					| %[1] | |
dvu $1==2	| R16 |
		"jsr Dvu2"
					| %[1] | |
dvu $1==4	| |
		allocate(R16)
		"jsr Dvu4"
					| | |
dvu ND	| R16 |
		"jsr Test2"
		"jsr Dvu2"
					| %[1] | |

rmu $1==2	| R16 |
		"jsr Rmu2"
					| %[1] | |
rmu $1==4	| |
		allocate(R16)
		"jsr Rmu4"
					| | |
slu	| | | | sli $1 |
sru $1==2	| R16 |
		"jsr Sru2"
					| %[1] | |
sru $1==4	| R16 |
		"jsr Sru4"
					| | |
sru ND	| R16 |
		"jsr Test2"
		"jsr Sru2"
					| %[1] | |


/* GROUP 6 - POINTER ARITHMETIC */

adp $1==0	| | | | |
adp	| | | | loc $1 adi 2 |
ads $1==2	| R16 |
		"jsr Adi2"
					| %[1] | |
ads ND 	| R16 |
		"jsr Test2"
		"jsr Adi2"
					| %[1] | |
sbs $1==2	| R16 |
		"jsr Sbi2"
					| %[1] | |
sbs ND	| R16 |
		"jsr Test2"
		"jsr Sbi2"
					| %[1] | |


/* GROUP 7 INCREMENT/DECREMENT/ZERO */

inc	| R16 |
		"inx"
		"bne 1f"
		"clc"
		"adc #1\n1:"
					| %[1] | |
inl IN($1)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"clc"
		"lda (LBl),y"
		"adc #1"
		"sta (LBl),y"
		"bcc 1f"
		"iny"
		"lda (LBl),y"
		"adc #0"
		"sta (LBl),y\n1:"
					| | |
inl D	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Lol"
		"inx"
		"bne 1f"
		"clc"
		"adc #1"
		"1: jsr Stii"
					| | |
ine	| |
		"inc $1"
		"bne 1f"
		"inc $1+1\n1:"
					| | |
dec	| R16 |
		"cpx #0"
		"bne 1f"
		"sec"
		"sbc #1"
		"1: dex"
					| %[1] | |
del IN($1)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"sec"
		"lda (LBl),y"
		"sbc #1"
		"sta (LBl),y"
		"bcs 1f"
		"iny"
		"lda (LBl),y"
		"sbc #0"
		"sta (LBl),y\n1:"
					| | |
del	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Lol"
		"cpx #0"
		"bne 1f"
		"sec"
		"sbc #1"
		"1: dex"
		"jsr Stii"
					| | |
dee 	| |
		"ldy $1"
		"bne 1f"
		"dec $1+1"
		"1: dey"
		"sty $1"
					| | |
zrl IN($1)	| |
		allocate(R16)
		"ldy #BASE+$1"
		"lda #0"
		"sta (LBl),y"
		"iny"
		"sta (LBl),y"
					| | |
zrl	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Zrl"
					| | |
zre	| |
		"ldy #0"
		"sty $1"
		"sty $1+1"
					| | |
zer $1==2	| |
		allocate(R16)
		"lda #0"
		"tax"
					| %[a] | |
zer $1==4	| |
		allocate(R16)
		"lda #0"
		"tax"
		"jsr Push"
					| %[a] | |
zer $1>0 && $1<=256	| |
		allocate(R16)
		"ldy #$1-1"
		"jsr Zer"
					| | |


/* GROUP 8 - CONVERT (stack: source, source size, dest. size (top)) */

loc loc cii $1==1 && $2==2	| R16 |
		"txa"
		"bpl 1f"
		"lda #0xff"
		"bne 2f"
		"1:  lda #0\n2:"
					| %[1] | |
cii 	| R16 |
		"jsr Cii"
					| | |
cui 	| | | | cii |
ciu	| | | | cii |
cuu 	| | | | cii |
loc loc cui $1==$2	| | | | |
loc loc ciu $1==$2	| | | | |
loc loc cuu $1==2 && $2==4 | | | | loc 0 |


/* GROUP 9 - LOGICAL */

and $1==2	| R16 |
		"sta ARTH+1"
		"stx ARTH"
		"jsr Pop"
		"and ARTH+1"
		"pha"
		"txa"
		"and ARTH"
		"tax"
		"pla"
					| %[1] | |
and $1<=254	| |
		allocate(R16)
		"ldy #[$1].l"
		"jsr And"
					| | |
and ND	| R16 |
		"jsr TestFFh"
		"jsr Pop"
		"iny"
		"jsr And"
					| | |
ior $1==2	| R16 |
		"sta ARTH+1"
		"stx ARTH"
		"jsr Pop"
		"ora ARTH+1"
		"pha"
		"txa"
		"ora ARTH"
		"tax"
		"pla"
					| %[1] | |
ior $1<=254	| |
		allocate(R16)
		"ldy #[$1].l"
		"jsr Ior"
					| | |
ior ND	| R16 |
		"jsr TestFFh"
		"jsr Pop"
		"iny"
		"jsr Ior"
					| | |
xor $1==2	| R16 |
		"sta ARTH+1"
		"stx ARTH"
		"jsr Pop"
		"eor ARTH+1"
		"pha"
		"txa"
		"eor ARTH"
		"tax"
		"pla"
					| %[1] | |
xor $1<=254	| |
		allocate(R16)
		"ldy #[$1].l"
		"jsr Xor"
					| | |
xor ND	| R16 |
		"jsr TestFFh"
		"jsr Pop"
		"iny"
		"jsr Xor"
					| | |
com $1==2	| R16 |
		"eor #0xff"
		"pha"
		"txa"
		"eor #0xff"
		"tax"
		"pla"
					| %[1] | |
com $1<=254	| |
		allocate(R16)
		"ldy #[$1].l"
		"jsr Com"
					| | |
com ND	| R16 |
		"jsr TestFFh"
		"jsr Pop"
		"iny"
		"jsr Com"
					| | |
rol $1==2	| R16 |
		"jsr Rol"
					| %[1] | |
rol $1==4	| R16 |
		"jsr Rol4"
					| | |
rol ND	| R16 |
		"jsr Test2"
		"jsr Rolw"
					| %[1] | |
ror $1==2	| R16 |
		"jsr Ror"
					| %[1] | |
ror $1==4	| R16 |
		"jsr Ror4"
					| | |
ror ND	| R16 |
		"jsr Test2"
		"jsr Rorw"
					| %[1] | |


/* GROUP 10 - SETS */

loc inn $1<0 && $2==2	| R16 |
		"lda #0"
		"tax"
					| %[1] | |
loc inn	$2==2 && $1==0	| R16 |
		"txa"
		"and #1"
		"tax"
		"lda #0"
					| %[1] | |
loc inn	$2==2 && $1>0 && $1<16	| R16 |
		"ldy #$1"
		"stx ARTH"
		"1: lsr a"
		"ror ARTH"
		"dey"
		"bne 1b"
		"lda ARTH"
		"and #1"
		"tax"
		"lda #0"
					| %[1] | |
loc inn zeq $1>0 && $1<16 && $2==2	| R16 |
		"ldy #$1+1"
		"stx ARTH"
		"1: lsr a"
		"ror ARTH"
		"dey"
		"bne 1b"
		"bcc $1"
					| | |
loc inn zne $1>0 && $1<16 && $2==2	| R16 |
		"ldy #$1+1"
		"stx ARTH"
		"1: lsr a"
		"ror ARTH"
		"dey"
		"bne 1b"
		"bcs $1"
					| | |
inn $1==2	| R16 |
		"txa"
		"tay"
		"jsr Pop"
		"stx ARTH"
		"1: lsr a"
		"ror ARTH"
		"dey"
		"bne 1b"
		"lda ARTH"
		"and #1"
		"tax"
		"lda #0"
				| %[1] | |
inn zeq $1==2	| R16 |
		"txa"
		"tay"
		"jsr Pop"
		"stx ARTH"
		"1: lsr a"
		"ror ARTH"
		"dey"
		"bpl 1b"
		"lda ARTH"
		"bcc $2"
				| %[1] | |
inn zne $1==2	| R16 |
		"txa"
		"tay"
		"jsr Pop"
		"stx ARTH"
		"1: lsr a"
		"ror ARTH"
		"dey"
		"bpl 1b"
		"bcs $2"
				| %[1] | |
inn $1<=256	| R16 |
		"ldy #$1-1"
		"jsr Inn"
					| %[1] | |
inn ND	| R16 |
		"jsr TestFFh"
		"jsr Pop"
		"jsr Inn"
					| %[1] | |
loc set $2==2 && $1>=0 && $1<16	| |
		allocate(R16)
		"ldy #$1"
		"lda #0"
		"sta ARTH"
		"sec"
		"1: rol ARTH"
		"rol a"
		"dey"
		"bpl 1b"
		"ldx ARTH"
					| %[a] | |
set $1==2	| R16 |
		"txa"
		"tay"
		"lda #0"
		"sta ARTH"
		"sec"
		"1: rol ARTH"
		"rol a"
		"bpl 1b"
		"ldx ARTH"
					| %[1] | |
set $1<=256	| R16 |
		"ldy #$1-1"
		"jsr Set"
					| | |
set ND	| R16 |
		"jsr TestFFh"
		"jsr Pop"
		"jsr Set"
					| | |


/* GROUP 11 - ARRAY */

lae lar defined(rom(1,3)) | | | | lae $1 aar $2 loi rom(1,3) |
lar $1==2	| R16 |
		"jsr Lar"
					| | |
lar ND	| R16 |
		"jsr Test2"
		"jsr Lar"
					| | |
lae sar defined(rom(1,3)) | | | | lae $1 aar $2 sti rom(1,3) |
sar $1==2	| R16 |
		"jsr Sar"
					| | |
sar ND	| R16 |
		"jsr Test2"
		"jsr Sar"
					| | |
lae aar $2==2 && rom(1,3)==1 && rom(1,1)==0 | | | | adi 2 |
lae aar $2==2 && rom(1,3)==1 && rom(1,1)!=0 | |
				    | | adi 2 adp 0-rom(1,1) |
lae aar $2==2 && rom(1,3)==2 && rom(1,1)==0 | R16 |
		"pha"
		"txa"
		"asl a"
		"tax"
		"pla"
		"rol a"
					| %[1] | adi 2 |
lae aar $2==2 && rom(1,3)==2 && rom(1,1)!=0 | R16 |
		"pha"
		"txa"
		"asl a"
		"tax"
		"pla"
		"rol a"
				    | %[1] | adi 2 adp (0-rom(1,1))*2 |
lae aar $2==2 && rom(1,3)>2 && rom(1,1)==0 | |
					| | loc rom(1,3) mli 2 adi 2 |
lae aar $2==2 && rom(1,3)>2 && rom(1,1)!=0 | |
		| | loc rom(1,3) mli 2 adi 2 adp (0-rom(1,1))*rom(1,3) |
aar $1==2	| R16 |
		"jsr Aar"
					| %[1] | |
aar ND	| R16 |
		"jsr Test2"
		"jsr Aar"
					| %[1] | |


/* GROUP 12 - COMPARE */

cmi $1==2	| R16 |
		"jsr Cmi"
					| %[1] | |
cmi $1==4	| |
		allocate(R16)
		"jsr Cmi4"
					| %[a] | |
cmi ND	| R16 |
		"jsr Test2"
		"jsr Cmi"
					| %[1] | |
cmu $1==2	| R16 |
		"jsr Cmu2"
					| %[1] | |
cmu $1==4	| |
		allocate(R16)
		"jsr Cmu4"
					| %[a] | |
cmu ND	| R16 |
		"jsr Test2"
		"jsr Cmu"
					| | |
cmp	| |
					| | cmu 2 |
cms $1==2	| |
		allocate(R16)
		"ldy #2"
		"jsr Cms"
					| %[a] | |
cms $1==4	| |
		allocate(R16)
		"ldy #4"
		"jsr Cms"
					| %[a] | |
cms ND	| R16 |
		"jsr TestFFh"
		"iny"
		"jsr Cms"
					| %[1] | |
tlt	| R16 |
		"jsr Tlt"
					| %[1] | |
tle	| R16 |
		"jsr Tle"
					| %[1] | |
teq	| R16 |
		"jsr Teq"
					| %[1] | |
tne	| R16 |
		"jsr Tne"
					| %[1] | |
tge	| R16 |
		"jsr Tge"
					| %[1] | |
tgt	| R16 |
		"jsr Tgt"
					| %[1] | |


/* GROUP 13 - BRANCH */

bra	| |
		remove(ALL)
		"jmp $1"
					| | |

blt	| R16 |
		"jsr Sbi2"
		"bmi $1"
					| | |
ble	| R16 |
		"jsr Sbi2"
		"bmi $1"
		"bne 1f"
		"txa"
		"beq $1\n1:"
					| | |
beq	| R16 |
		"sta BRANCH+1"
		"stx BRANCH"
		"jsr Pop"
		"cmp BRANCH+1"
		"bne 1f"
		"cpx BRANCH"
		"beq $1\n1:"
					| | |
bne	| R16 |
		"sta BRANCH+1"
		"stx BRANCH"
		"jsr Pop"
		"cmp BRANCH+1"
		"bne $1"
		"cpx BRANCH"
		"bne $1"
					| | |
bge	| R16 |
		"jsr Sbi2"
		"bpl $1"
					| | |
bgt	| R16 |
		"jsr Sbi2"
		"bmi 1f"
		"bne $1"
		"txa"
		"bne $1\n1:"
					| | |

cmi zlt $1==2 | | | | blt $2 |
cmp zlt	| | | | blt $2 |
zlt	| R16 |
		"tay"
		"bmi $1"
					| | |
cmi zle $1==2 | | | | ble $2 |
cmp zle | | | | ble $2 |
zle	| R16 |
		"tay"
		"bmi $1"
		"bne 1f"
		"txa"
		"beq $1\n1:"
					| | |
cmi zeq $1==2 | | | | beq $2 |
cmp zeq | | | | beq $2 |
cms zeq $1==2 | | | | beq $2 |
zeq	| R16 |
		"tay"
		"bne 1f"
		"txa"
		"beq $1\n1:"
					| | |
cmi zne $1==2 | | | | bne $2 |
cmp zne | | | | bne $2 |
cms zne $1==2 | | | | bne $2 |
zne	| R16 |
		"tay"
		"bne $1"
		"txa"
		"bne $1"
					| | |
cmi zge $1==2 | | | | bge $2 |
cmp zge | | | | bge $2 |
zge	| R16 |
		"tay"
		"bpl $1"
					| | |
cmi zgt $1==2 | | | | bgt $2 |
cmp zgt | | | | bgt $2 |
zgt	| R16 |
		"tay"
		"bmi 1f"
		"bne $1"
		"txa"
		"bne $1\n1:"
					| | |


/* GROUP 14 - PROCEDURE CALL */

cai	| R16 |
		"stx ADDR"
		"sta ADDR+1"
		"jsr Indir"
					| | |
cal	| |
		remove(ALL)
		"jsr $1"
					| | |
lfr $1==2 | |
		allocate(R16)
		"lda #0"
		"ldx #RETURN"
		"jsr Loi"
					| %[a] | |
lfr $1==4 | |
		allocate(R16)
		"lda #0"
		"ldx #RETURN"
		"jsr Ldi"
					| | |
lfr ret $1==$2	| | | | ret 0 |
asp lfr ret $2==$3 | | | | ret 0 |
ret $1==0 || $1==2 || $1==4 	| |
		allocate(R16)
		"ldy #$1"
		"jmp Ret"
					| | |


/* GROUP 15 - MISCELLANOUS */

asp	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jsr Asp"
					| | |
ass $1==2	| R16 |
		"jsr Asp"
					| | |
ass ND	| R16 |
		"jsr Test2"
		"jsr Pop"
		"jsr Asp"
					| | |
blm $1==0	| | | | asp 4 |
blm D	| R16 |
		"ldy #[[$1].h+1]"
		"sty NBYTES+1"
		"ldy #[$1].l"
		"jsr Blm"
					| | |
bls $1==2	| R16 |
		"sta NBYTES+1"
		"inc NBYTES+1"
		"txa"
		"tay"
		"jsr Pop"
		"jsr Blm"
					| | |
bls ND	| R16 |
		"jsr Test2"
		"sta NBYTES+1"
		"inc NBYTES+1"
		"txa"
		"tay"
		"jsr Pop"
		"jsr Blm"
					| | |
csa	| R16 |
		"jmp Csa"
					| | |
csb	| R16 |
		"jmp Csb"
					| | |
dch	| | | | loi 2 |
dup $1==2	| R16 |
		"jsr Push"
					| %[1] | |
dup $1<=256	| |
		allocate(R16)
		"ldy #[$1].l"
		"jsr Dup"
					| | |
dus $1==2	| R16 |
		"jsr TestFFh"
		"iny"
		"jsr Dup"
					| | |
exg $1==2	| R16 |
		"jsr Exg2"
					| %[1] | |
exg $1<=255	| |
		allocate(R16)
		"ldy #$1"
		"jsr Exg"
					| | |
fil	| |
		"ldy #[$1].l"
		"sty hol0+4"
		"ldy #[$1].h"
		"sty hol0+5"
					| | |
gto	| |
		allocate(R16)
		"lda #[$1].h"
		"ldx #[$1].l"
		"jmp Gto"
					| | |
lim	| |
		allocate(R16)
		"ldx IGNMASK"
		"lda IGNMASK+1"
					| %[a] | |
lin	| |
		"ldy #[$1].l"
		"sty hol0"
		"ldy #[$1].h"
		"sty hol0+1"
					| | |
lni	| |
		"inc hol0"
		"bne 1f"
		"inc hol0+1\n1:"
					| | |
lor $1==0	| |
		allocate(R16)
		"ldx LB"
		"lda LB+1"
					| %[a] | |
lor $1==1	| |
		allocate(R16)
		"ldx SP+2"
		"lda SP+1"
					| %[a] | |
lor $1==2	| |
		allocate(R16)
		"ldx HP"
		"lda HP+1"
					| %[a] | |
lpb	| | | | adp 2 |
mon	| R16 |
		"jsr Mon"
					| %[1] | |
nop	| |
		allocate(R16)
		"jsr Printstack"
					| | |
rck	| R16 | | | |
rtt	| |
		remove(ALL)
		"jmp Rtt"
					| | |
sig 	| R16 |
		"pha"
		"txa"
		"pha"
		"ldx ERRPROC"
		"lda ERRPROC+1"
		"jsr Push"
		"pla"
		"sta ERRPROC"
		"pla"
		"sta ERRPROC+1"
					| | |
sim	| R16 |
		"stx IGNMASK"
		"sta IGNMASK+1"
					| | |
str $1==0	| R16 |
		"stx LB"
		"sta LB+1"
		"tay"
		"sec"
		"txa"
		"sbc #BASE"
		"sta LBl"
		"tya"
		"sbc #0"
		"sta LBl+1"
					| | |
str $1==1	| R16 |
		"stx SP+2"
		"sta SP+1"
					| | |
str $1==2	| R16 |
		"stx HP"
		"sta HP+1"
					| | |
trp	| R16 |
		"jsr Trap"
					| | |
lol lal sti $1==$2 && $3==1 | | | | | /* throw away funny C-proc-prolog */

	| STACK |
		allocate(R16)
		"jsr Pop"
					| %[a] | |

/* FLOATING POINT
 * Every EM floating point instruction is translated
 * into a library call. At present, these library
 * routines generate an 'Illegal EM instruction' trap.
 */


adf $1==4	| STACK |
		"jsr Adf4"
					| | |
adf $1==8	| STACK |
		"jsr Adf8"		| | |

sbf $1==4	| STACK |
		"jsr Sbf4"
					| | |
sbf $1==8	| STACK |
		"jsr Sbf8"		| | |

mlf $1==4	| STACK |
		"jsr Mlf4"
					| | |
mlf $1==8	| STACK |
		"jsr Mlf8"		| | |

dvf $1==4	| STACK |
		"jsr Dvf4"
					| | |
dvf $1==8	| STACK |
		"jsr Dvf8"		| | |

ngf $1==4	| STACK |
		"jsr Ngf4"
					| | |
ngf $1==8	| STACK |
		"jsr Ngf8"		| | |

zrf $1==4	| STACK |
		"jsr Zrf4"
					| | |
zrf $1==8	| STACK |
		"jsr Zrf8"		| | |

cmf $1==4	| STACK |
		"jsr Cmf4"
					| | |
cmf $1==8	| STACK |
		"jsr Cmf8"		| | |

fef $1==4	| STACK |
		"jsr Fef4"
					| | |
fef $1==8	| STACK |
		"jsr Fef8"		| | |

fif $1==4	| STACK |
		"jsr Fif4"
					| | |
fif $1==8	| STACK |
		"jsr Fif8"		| | |

cfi 		| STACK |
		"jsr Cfi"		| | |

cif 		| STACK |
		"jsr Cif"		| | |

cuf 		| STACK |
		"jsr Cuf"		| | |

cff 		| STACK |
		"jsr Cff"		| | |

cfu 		| STACK |
		"jsr Cfu"		| | |

lfr $1==8	| STACK |
		"jsr Lfr8"		| | |

ret $1==8	| STACK |
		"jmp Ret8"		| | |

/*************\
*  M O V E S  *
\*************/

MOVES:  (AAA,AAA,"nop")

STACKS:  (R16, , "jsr Push")