Random demo
Random demo
  • Entry name:
    Elevator Repairman
  • Category:
    Games
  • Publisher/Developer:
    Analog Computing Magazine
  • Year:
    1985
  • Code:
    Fred Caprilli
  • Media format:
    Diskette, Tape
  • Controllers:
    Joystick
  • Programming language:
    Assembly language
Elevator Repairman Elevator Repairman
Listing 1
; +----------------------+
; |                      |
; |  ELEVATOR REPAIRMAN  |
; |                      |   /\
; |   by Fred Caprilli   |  /UP\
; |                      |  |--|
; |       (c) 1985       |  \DN/
; |                      |   \/
; |   Analog Computing   |
; |                      |
; +----------------------+
;
; System equates
;
VDSLST	=	$0200
SDLSTL	=	$0230
SDMCTL	=	$022F
GRACTL	=	$D01D
NMIEN	=	$D40E
WSYNC	=	$D40A
COLBAK	=	$D01A
CHBASE	=	$D409
PMBASE	=	$D407
HSCROL	=	$D404
VCOUNT	=	$D40B
HPOSP0	=	$D000
HPOSP2	=	$D002
HPOSP3	=	$D003
COLRP0	=	$02C0
COLRP1	=	$02C1
COLRP2	=	$02C2
COLRP3	=	$02C3
SIZEP0	=	$D008
SIZEP1	=	$D009
SIZEP2	=	$D00A
SIZEP3	=	$D00B
SIZEM	=	$D00C
RANDOM	=	$D20A
SETVBV	=	$E45C
XITVBV	=	$E462
CONSOL	=	$D01F
STICK	=	$D300
P2PL	=	$D00E
P3PL	=	$D00F
M0PL	=	$D008
M1PL	=	$D009
M2PL	=	$D00A
COLPF0	=	$D016
HITCLR	=	$D01E
JIFFY	=	$14
GPRIOR	=	$026F
COLOR0	=	$02C4
COLOR1	=	$02C5
COLOR2	=	$02C6
SCOLBK	=	$02C8
BOOT	=	$09
COLDST	=	$0244
DOSINI	=	$0C
ATRACT	=	$4D
DRKMSK	=	$4E
COLRSH	=	$4F
CHSET	=	$0600
;
AUDF0	=	$D200
AUDF1	=	$D202
AUDC1	=	$D203
AUDF2	=	$D204
AUDC2	=	$D205
AUDF3	=	$D206
AUDC3	=	$D207
AUDCTL	=	$D208
SKCTL	=	$D20F
PACTL	=	$D302
;
; Player / Missile Area
;
	*=	$3800
;
PMAREA	.DS	$0300
MAREA	.DS	$0100
P0AREA	.DS	$0100
P1AREA	.DS	$0100
P2AREA	.DS	$0100
P3AREA	.DS	$0100
;
; Page Zero Variables
;
	*=	$80
;
EHT	.DS	2	;P/M ht for elev
EMSK	.DS	1	;msk to clr bits
D1S	.DS	2	;climb fr height
D2S	.DS	2	;same (P3)
D1D	.DS	2	;climb to height
D2D	.DS	2	;same (P3)
DAN1	.DS	2	;P/M pg. Dan (P2)
DAN2	.DS	2	;P/M pg. Dan (P3)
ESP	.DS	2	;speed tbl pntr
COFSET	.DS	1	;DLI tbl offset
ESPEED	.DS	7	;elevator speeds
LEVEL	.DS	1	;level no.
FLOOR	.DS	1	;current floor
CLIMBF	.DS	1	;Dan climbing flg
DIEFLAG	.DS	1	;indicates dying
NEWLVL	.DS	1	;flags new level
SCORE	.DS	3	;score in BCD
OVERFLG	.DS	1	;game over status
HITES	.DS	7	;elevator heights
DIR	.DS	7	;elevator dirs
DANHOR	.DS	1	;Dan's hor pos
CLIMBHT	.DS	1	;climb height
DANDIR	.DS	1	;Dan's direction
DANSPD	.DS	1	;Dan's speed
SPDCNT	.DS	1	;speed counter
ELDLAY	.DS	1	;elev # to stall
DLYCNT	.DS	1	;death delay
COLCNT	.DS	1	;color counter
TIME	.DS	4	;time in BCD
BASCNT	.DS	1	;Bass note cntr
BASTIM	.DS	1	;Bass timer
TRBCNT	.DS	1	;Treble counter
TRBTIM	.DS	1	;Treble timer
;
; Game starts here
;
	*=	$2000
;
INIT	LDA	#$3C	;cassette off
	STA	PACTL	;if necessary
	LDA	#0
	STA	COLDST	;Warm start
	LDA	#1
	STA	BOOT	;Disk boot OK
	LDA	# <RST
	STA	DOSINI
	LDA	# >RST
	STA	DOSINI+1	;Trap S/RESET
	JSR	CLRHI	;clear hiscore
RST	CLD		;just in case
	JSR	TITLE	;Title screen
	JSR	ZERO	;init. variables
	JSR	SLEVEL
	JSR	SETUP	;main display
	JSR	INITIM	;reset timer
;
; Mainline (non-VBI) code
;
MAIN	LDA	OVERFLG	;Game over?
	BEQ	MN1	;No.
	LDA	#8	;Yes, so clear
	STA	CONSOL	;CONSOL and
MN0	LDA	CONSOL	;poll START key
	EOR	#6	;Is it pressed?
	BNE	MN0	;No.
	STA	OVERFLG	;Yes, zero flag
	LDA	#7	;back to   
	LDY	# <XITVBV	;standard VB
	LDX	# >XITVBV	;routine
	JSR	SETVBV
	JMP	RST	;and start at top
MN1	LDA	NEWLVL	;Check new level
	BEQ	MAIN	;Not yet, loop
	JSR	SLEVEL	;Yes, new level
	JMP	MAIN	;and loop back
;
; End of Mainline code
;
SETUP	LDX	#0
	STX	SDMCTL	;Disable DMA
	LDA	#$40
	STA	NMIEN	;Disable DLI
	LDA	# <DLIST
	STA	SDLSTL	;Point to
	LDA	# >DLIST	;the game
	STA	SDLSTL+1	;display list
	LDA	# <DLI1	;DLI vector
	STA	VDSLST
	LDA	# >DLI1
	STA	VDSLST+1
	LDY	# <VBI	;Set up VBI
	LDX	# >VBI
	LDA	#7	;Deferred
	JSR	SETVBV
	LDA	#$3D	;P/M enable, and
	STA	SDMCTL	;narrow playfield
	LDA	#$C0
	STA	NMIEN	;enable DLI's
	LDA	#$0A	;white
	STA	COLOR0	;for stairs
	LDA	#$00	;black 
	STA	COLOR1	;for shafts
	STA	SCOLBK	;and screen top.
	STA	BASCNT	;bass notes index
	LDA	#$CC	;green
	STA	COLOR2	;for digits
;
	LDA	#$50	;16-bit ch. 0/1
	STA	AUDCTL	;8-bit ch. 2,3
	LDA	#3
	STA	SKCTL	;reset POKEY
	LDA	#$AA	;vol.10, dist.10
	STA	AUDC1
	STA	AUDC2
	STA	AUDC3
	LDA	#$FF
	STA	TRBTIM	;timer for treble
	STA	TRBCNT	;treble note cntr
	LDA	#14
	STA	BASTIM	;timer for bass
;
; Download charset to page 6
;
	LDX	#55	;# of bytes
CDL	LDA	CSETB,X
	STA	CHSET,X
	DEX
	BPL	CDL
	RTS
;
ZERO	LDA	#0	;zero variables
	LDX	#OVERFLG-COFSET
Z1	STA	COFSET,X
	DEX
	BPL	Z1
	LDA	#2	;Dan moves...
	STA	DANSPD	;every other VBI
	LDA	#$90	;ATASCII inv "0"
	LDX	#5
L1	STA	SSCORE,X	;0 score
	DEX
	BPL	L1
	STA	LEVBYTE	;level 0
	LDA	#$FF
	STA	DANDIR	;no initial dir.
	LDA	#$99	;digit 9 on 
	STA	MENBYT	;screen - 9 men
	LDA	# <TLINE
	STA	MSG
	LDA	# >TLINE
	STA	MSG+1	;Top shows timer
	RTS
;
CLRHI	LDX	#5	;hi to 000000
	LDA	#$90
CR1	STA	HISCORE,X
	DEX
	BPL	CR1
	RTS
;
PMSETUP	LDA	# >PMAREA
	STA	PMBASE	;to P/M area
	LDA	#3
	STA	GRACTL	;enable P/M DMA
	LDA	#0	;clear P/M area
	TAY
CLN	STA	MAREA,Y
	STA	P0AREA,Y
	STA	P1AREA,Y
	STA	P2AREA,Y
	STA	P3AREA,Y
	DEY
	BNE	CLN
;
	LDY	#7	;8 P/M locs
INITPM	LDA	ELEPOS,Y	;init P/M
	STA	HPOSP0,Y	;horizontal pos
	DEY		;next P/M
	BPL	INITPM	;done? No.
	LDA	#64
	STA	DANHOR
;
	JSR	SETHTS	;elev heights
;
	LDA	#$7A	;Set P/M colors
	STA	COLRP0
	LDA	#$F8
	STA	COLRP1
	LDA	#$48
	STA	COLRP2
	LDA	#$90
	STA	COLRP3
;
	LDA	#$3F	;P/M widths
	STA	SIZEP0	;quadruple for
	STA	SIZEP1	;elevators (P0,
	STA	SIZEM	;P1,M0-M2)
	LDA	#0	;single for
	STA	SIZEP2	;Dan
	STA	SIZEP3	;(P2,P3)
	LDA	#$21
	STA	GPRIOR	;Multicolor PL
	LDA	# >P2AREA	;Set up zero
	STA	DAN1+1	;page pointers
	STA	D1S+1
	STA	D1D+1
	LDA	# >P3AREA
	STA	DAN2+1
	STA	D2S+1
	STA	D2D+1
	RTS
;
; The Display list interrupt routines
;
DLI1	PHA		;Save registers
	TXA
	PHA
	LDX	# >CHSET	;new charset
	LDA	#$C2
	STA	WSYNC
	STX	CHBASE
	EOR	COLRSH	;mask attract
	AND	DRKMSK
	STA	WSYNC
	STA	COLBAK	;change color
	LDA	# >DLI2
	STA	VDSLST+1
	LDA	# <DLI2
	STA	VDSLST	;next DLI
	PLA
	TAX
	PLA		;Restore regs
	RTI
;
DLI2	PHA		;Save registers
	TXA
	PHA
	LDA	#0
	STA	WSYNC
	STA	COLBAK	;Black ceiling
	LDX	COFSET
	LDA	COLORS,X	;get color
	EOR	COLRSH	;mask attract
	AND	DRKMSK
	STA	WSYNC
	STA	COLBAK
	INC	COFSET	;inc index
	LDA	COFSET	;table index
	CMP	#11	;last DLI?
	BNE	EX	;no.
	LDA	#$E0	;Yes, so restore
	STA	CHBASE	;default cset.
	LDA	#0
	STA	COFSET	;and zero index
	STA	COLPF0	;and color 0.
	LDA	# <DLI1	;Point back to
	STA	VDSLST	;first DLI.
	LDA	# >DLI1
	STA	VDSLST+1
EX	PLA
	TAX
	PLA		;Restore registers.
	RTI
;
; The Vertical Blank routine
;
VBI	LDA	OVERFLG	;Skip VBI if
	BEQ	V0	;game over.
	JMP	XVB
V0	LDA	DIEFLAG	;Dan dying?
	BNE	DAN	;Yes, skip elevs
;
; Check screen heights for elevators
; and reverse direction if necessary
;
C3	LDX	#6	;do 7 elevator
C0	LDA	HITES,X
	CMP	#32	;At top?
	BPL	C1	;No. skip
	CMP	#68	;Intermediate
	BPL	C1
	LDA	#1	;Going down!
	BNE	C2A
;
C1	CMP	#159	;intermediate
	BMI	C2
	CMP	#193	;At bottom?
	BMI	C2	;No. no change
	LDA	#0	;Yes, going up!
C2A	STA	DIR,X
C2	DEX		;next elevator
	BPL	C0	;done? No.
;
; Now set up for movement of elevators
;
	LDX	#6	;do 7 elevators
M1	CPX	ELDLAY	;slow it down?
	BNE	M2	;No.
	LDA	DLYCNT	;Yes.
	BEQ	M2	;Delay over yet?
	DEC	DLYCNT	;No.
	LDA	DLYCNT	;count down one
	AND	#3	;and skip a turn
	BEQ	M5	;every 1/15 sec.
M2	LDA	ELOCS,X	;P/M page
	STA	EHT+1
	LDA	HITES,X	;byte loc in page
	STA	EHT
	LDA	EMASKS,X	;Get mask
	EOR	#$FF	;save its inverse
	STA	EMSK
	LDA	DIR,X	;0=up, 1=down
	BEQ	UP
;
; Set up for down movement
;
	LDA	ESPEED,X	;elevator speed
	BEQ	D1
	INC	HITES,X
	INC	EHT	;double speed
D1	INC	HITES,X
	INC	EHT	;normal speed
	JMP	M4
;
; Set up for up movement
;
UP	LDA	ESPEED,X
	BEQ	U1
	DEC	HITES,X
	DEC	EHT	;double speed
U1	DEC	HITES,X
	DEC	EHT	;normal speed
;
; Execute the movement
;
M4	JSR	MV	;move the bytes
M5	DEX		;next elevator
	BPL	M1	;done? No.
;
	LDA	JIFFY	;Stall elevator?
	BNE	DAN	;(when JIFFY=0)
	JSR	ELNEW
;
; Elevators done. Now, we process
; Dan the Elevator Repair Man.
;
DAN	LDA	CLIMBF	;climbing?
	BEQ	VB1	;No.
	JSR	CLIMB1	;Yes, move him up
	JMP	DANEND	;and exit.
VB1	LDA	DIEFLAG	;Presently dying?
	BEQ	VB2	;No. skip
	JSR	DEATH	;Yes. keep dying
	JMP	XVB	;and exit.
VB2	LDY	FLOOR
	LDA	STAIRS,Y	;Has he reached
	CMP	DANHOR	;the stairs?
	BNE	VB4	;No.
	CPY	#10	;Top floor?
	BMI	VB3	;No, climb stairs
	JSR	ENDLEV	;Yes, so end it
	JMP	DANEND	;and exit.
VB3	JSR	SCLIMB	;init climbing
	JMP	DANEND	;and exit.
VB4	JSR	HITCHK	;Chk collision
	BEQ	VB5	;Dan hit? No.
	LDA	#120	;Yes, start 120
	STA	DIEFLAG	;jiffy death...
	BNE	DANEND	;and exit
;
; If we make it to here, it means our
; hero is either starting or in the
; midst of his perilous trek across
; the screen.
;
VB5	INC	SPDCNT	;Speed counter
	LDA	SPDCNT
	CMP	DANSPD	;Time to move?
	BMI	DANEND	;No, so exit.
	LDA	#0
	STA	SPDCNT	;Zero the counter
	LDX	DANDIR	;Save old dir
	JSR	JOY	;dir change?
	CPX	DANDIR
	BEQ	MOVEDAN	;No, skip
	JSR	DRAWDAN	;Yes, redraw him
MOVEDAN	LDA	DANDIR
	BMI	DANEND	;Wait on joystick
	LDY	FLOOR
	LDA	STARTS,Y	;Is Dan at start
	CMP	DANHOR	;of floor?
	BEQ	F3	;Yes, skip next
	CLC		;animate feet
	LDA	DANHT,Y
	ADC	#15	;Bottom of Dan
	TAY		;for feet.
	LDA	JIFFY
	AND	#7	;Mod 8 counter
	CMP	#4	;at 4 jiffies?
	BMI	F2
	LDA	#$18	;"feet in" byte
	BNE	F3A
F2	LDA	#$24	;"feet out" byte
F3A	STA	P2AREA,Y
F3	LDA	DANDIR
	ROR	A	;Right or left?
	BCC	MVRT	;Right (DANDIR=0)
	LDA	DANHOR	;trying to pass
	CMP	#$40	;left edge?
	BEQ	DANEND	;Yes, stop him
	DEC	DANHOR	;Dec horizontal
	JMP	MVLF
MVRT	LDA	DANHOR	;Trying to pass
	CMP	#$B8	;right edge?
	BEQ	DANEND	;Yes, stop him
	INC	DANHOR	;No, so move it
MVLF	LDA	DANHOR	;position shadow
	STA	HPOSP2	;and do the
	STA	HPOSP3	;horizontal move
;
DANEND	JSR	TIMER	;Do the timer
	JSR	MUSIC	;Do the music
XVB	STA	HITCLR	;clr collisions
	JMP	XITVBV	;and finish VBI!
;
; Subroutines
; -----------
;
; Pick an elevator to stall [0-6]
;
ELNEW	LDA	RANDOM
	AND	#7	;0-7
	CMP	#7
	BEQ	ELNEW	;0-6
	STA	ELDLAY
	LDA	#$80
	STA	DLYCNT
	RTS
;
; Animate the elevators - on entry,
; (EHT) pointS to the pertinent P/M
; area, and EMSK contains inverse bit
; mask, to zero out bits (tops and
; bottoms of elevators).  Elevators
; are 12 solid lines plus 2 blanks on
; top and 2 on bottom.
;
MV	LDY	#15	;16 bytes
	JSR	V2	;15-14 (bottom)
	DEY
V1	LDA	(EHT),Y	;lines 13 to 2
	AND	EMSK	;Clr current bits
	ORA	EMASKS,X	;set new ones
	STA	(EHT),Y
	DEY
	CPY	#1
	BNE	V1
V2	LDA	(EHT),Y	;line 1
	AND	EMSK	;Zero out bits
	STA	(EHT),Y	;with mask
	DEY
	LDA	(EHT),Y	;line 0 (top)
	AND	EMSK
	STA	(EHT),Y
	RTS
;
; Generate elevator starting heights
;
SETHTS	LDX	#6	;7 elevators
SH1	LDA	RANDOM
	AND	#$3F	;0-63
	ASL	A	;0-126 even
	ADC	#40	;40-166 even
	STA	HITES,X
	DEX
	BPL	SH1
	RTS
;
; This subroutine updates the
; countdown timer, and puts it to
; the screen
;
TIMER	LDA	CLIMBF	;Don't time
	BNE	TI1	;if climbing
	LDA	TIME+2
	BNE	TI0
	LDA	TIME+1
	AND	#$0F
	BEQ	TI1	;If 0 don't dec
TI0	SED		;Decimal math
	SEC
	LDA	TIME+3	;Fractional byte
	SBC	#17	;approx. 0.1 sec
	STA	TIME+3	;(rolls over
	LDA	TIME+2	;every 6 jiffies)
	SBC	#0
	STA	TIME+2
	LDA	TIME+1
	SBC	#0
	STA	TIME+1
	CLD
;
	LDA	TIME+2	;Take 3-byte (6
	AND	#$0F	;decimal digit),
	ORA	#$90	;take the low 3
	STA	TLINE+8	;digits and put
	LDA	TIME+2	;to the screen.
	LSR	A	;move high nybble
	LSR	A	;for 2nd decimal
	LSR	A	;digit down to
	LSR	A	;low nybble
	ORA	#$90	;make it ATASCII
	STA	TLINE+7	;put to screen
	LDA	TIME+1	;we only want low
	AND	#$0F	;nybble here
	STA	TIME+1	;(3 digits total)
	ORA	#$90	;make it ATASCII
	STA	TLINE+6	;put to screen
	LDA	#0
	STA	TIME	;not used
TI1	RTS
;
; This subroutine updates the scoring
; when Dan reaches a new floor
;
SCORING	LDX	#3	;3-byte (6-digit)
	SED		;decimal add
	CLC
SC1	DEX
	LDA	SCORE,X
	ADC	TIME,X
	STA	SCORE,X
	TXA
	BNE	SC1
	CLD
	STA	TIME	;Zero out timer
	STA	TIME+1
	STA	TIME+2
	STA	TIME+3
	LDX	#2
	LDY	#5
SC2	LDA	SCORE,X
	PHA		;Save it
	AND	#$0F	;low nybble
	ORA	#$90	;make it ATASCII
	STA	SSCORE,Y	;put on screen
	PLA		;use same byte
	LSR	A	;high nybble
	LSR	A	;we move it
	LSR	A	;down to
	LSR	A	;low nybble
	ORA	#$90	;make it ATASCII
	DEY
	STA	SSCORE,Y	;put to screen
	DEY
	DEX
	BPL	SC2
	RTS
;
; This subroutine reads the joystick.
;
JOY	LDA	STICK	;Read joystick
	AND	#8	;Right?
	BEQ	JLR	;Yes.
	LDA	STICK
	AND	#4	;No. left?
	BNE	JE	;No, dir same
	LDA	#1	;1 = left
JLR	STA	DANDIR
JE	RTS
;
; This subroutine updates the score
; and sets up the climb.
;
SCLIMB	JSR	SCORING	;Update score
	LDA	#16	;16 scan lines
	STA	CLIMBF	;to climb.
	LDY	FLOOR	;index to screen.
	LDA	DANHT,Y	;height table
	STA	CLIMBHT	;start climb here
	RTS
;
; This subroutine makes Dan climb 1
; scan line per VBI (if CLIMBF<>0).
; It continues into the INITIM
; subroutine.
;
CLIMB1	LDY	#0
	LDA	CLIMBHT	;Set up zero page
	STA	D1S	;pointers
	STA	D2S
	DEC	CLIMBHT	;destination is
	LDA	CLIMBHT	;one scan line up
	STA	D1D
	STA	D2D
CL1	LDA	(D1S),Y	;Move P2 up one.
	STA	(D1D),Y
	LDA	(D2S),Y	;Move P3 up one.
	STA	(D2D),Y
	INY
	CPY	#16	;All bytes moved?
	BMI	CL1	;No.
	LDA	#0	;Erase last line
	STA	(D1D),Y
	STA	(D2D),Y
	DEC	CLIMBF
	BNE	INITIM	;Is climb over?
	INC	FLOOR	;Yes, new floor.
;
; This subroutine sets timer to 250
;
INITIM	LDA	#0	;250 decimal
	STA	TIME
	LDA	#2
	STA	TIME+1
	LDA	#$50
	STA	TIME+2
	LDA	#$92	;"2"
	STA	TLINE+6
	LDA	#$95	;"5"
	STA	TLINE+7
	LDA	#$90	;"0"
	STA	TLINE+8
	RTS
;
; This subroutine sets up a new level,
; speeds of elevators and Dan, timer,
; Dan on bottom, increased level no.
;
SLEVEL	LDY	LEVEL
	CPY	#7	;Level 7 or more?
	BMI	SL0	;No.
	LDA	#1	;Yes, so we have
	STA	DANSPD	;superfast Dan.
SL0	CPY	#4	;Level 4 or more?
	BMI	SL1	;No.
	LDY	#4	;Yes, lev.4 speed
SL1	TYA
	ASL	A
	TAY		;Lev *2 index
	LDA	LEVSPD,Y	;elev speed tbl
	STA	ESP	;init 0 page pntr
	INY
	LDA	LEVSPD,Y
	STA	ESP+1
	LDY	#6	;Download elev
SL2	LDA	(ESP),Y	;speeds to 
	STA	ESPEED,Y	;zero page tbl
	DEY
	BPL	SL2
	JSR	PMSETUP	;reset P/M gr
	LDA	#0
	STA	FLOOR	;floor 0
	JSR	SFLOOR
	JSR	INITIM
	LDA	LEVEL
	ORA	#$90	;make it ATASCII
	STA	LEVBYTE	;put to screen.
	LDA	#0
	STA	NEWLVL	;Turn off flag.
	RTS
;
SFLOOR	LDY	FLOOR	;find hor. start
	LDA	STARTS,Y
	STA	HPOSP2	;put Dan there.
	STA	HPOSP3
	STA	DANHOR
	JSR	DRAWDAN	;Draw him
	LDA	#0
	STA	ATRACT	;defeat attract
	LDA	#$FF
	STA	DANDIR	;no initial dir.
	RTS
;
DRAWDAN	LDY	FLOOR	;index to height
	LDA	DANHT,Y	;tbl corresponds
	STA	DAN1	;to P/M memory
	STA	DAN2	;'height'
	LDY	#15	;draw 16 bytes
	LDA	DANDIR
	ROR	A	;Right or left?
	BCS	S2
;
; Draw Dan facing right
;
S1	LDA	DANRT1,Y	;P2 data
	STA	(DAN1),Y
	LDA	DANRT2,Y	;P3 data
	STA	(DAN2),Y
	DEY
	BPL	S1
	RTS
;
; Draw Dan facing left
;
S2	LDA	DANLF1,Y	;P2 data
	STA	(DAN1),Y
	LDA	DANLF2,Y	;P3 data
	STA	(DAN2),Y
	DEY
	BPL	S2
	RTS
;
; Death subroutine - flip-flop Dan
; for 1 second, then freeze for 1
; second.  If no lives are left,
; it ends the game.
;
DEATH	LDA	#0
	STA	AUDF0
	STA	AUDF1
	STA	AUDF2	;Silence music
	DEC	DIEFLAG	;lower counter
	LDA	DIEFLAG	;Done yet?
	BEQ	DE2	;Yes.
	CMP	#60	;time for freeze?
	BPL	DE8	;No.
	LDA	#0	;Yes...
	STA	AUDF3	;silence
	RTS		;skip flip-flop.
DE8	AND	#3	;No, flip Dan
	BNE	DE3	;every 4 jiffies
	LDA	DANDIR
	BEQ	DE1
	JSR	DRAWDAN	;flip left
	LDA	#0	;and set up for
	STA	DANDIR	;right flip
	LDA	#$20	;high note
	BNE	DE0
DE1	JSR	DRAWDAN	;flip right
	LDA	#1	;and set up for
	STA	DANDIR	;left flip
	LDA	#$40	;low note
DE0	STA	AUDF3
	RTS
;
; Death over
;
DE2	JSR	SFLOOR	;put Dan back
	DEC	MENBYT	;One less man...
	LDA	MENBYT	;Any men left?
	AND	#$0F
	BNE	DE3	;Yes, continue.
	LDA	# <OVERLN	;No, change
	STA	MSG	;top line LMS
	LDA	# >OVERLN	;LMS to show
	STA	MSG+1	;"GAME OVER"
	LDA	#1	;set flag
	STA	OVERFLG
	LDX	#0	;Compare score to
DE4	LDA	SSCORE,X	;high score
	CMP	HISCORE,X	;digit by digit
	BMI	DE3	;lt?, no change
	BNE	DE5	;gt?, update hi
	INX		;next digit
	CPX	#6
	BMI	DE4
	RTS
DE5	LDX	#5
DE6	LDA	SSCORE,X	;Move score
	STA	HISCORE,X	;to high score
	DEX
	BPL	DE6
DE3	RTS
;
; This subroutine does collision
; detection.
;
HITCHK	LDA	P2PL	;Did P2
	ORA	P3PL	;or P3 hit
	AND	#3	;elev 0,1,5,6?
	BNE	ENDCHK	;Yes, Dan's dead.
	LDA	M0PL	;Did M0 (elev 2)
	ORA	M1PL	;or M1 (elev 3)
	ORA	M2PL	;or M2 (elev 4)?
	AND	#$0C
ENDCHK	STA	HITCLR	;Clear collision
	RTS
;
ENDLEV	JSR	SCORING	;update score
	INC	LEVEL	;on to next level
	LDA	#1	;Flag so mainline
	STA	NEWLVL	;code can set up
	RTS		;a new level
;
; This subroutine produces the title
; screen, and waits for START.
;
TITLE	LDA	#0
	STA	SDMCTL	;disable DMA
	STA	COLOR0	;black letters
	LDA	# <TDLIST	;Point to
	STA	SDLSTL	;Display list
	LDA	# >TDLIST	;for title
	STA	SDLSTL+1	;screen
	LDA	#$3D	;narrow playfield
	STA	SDMCTL
	LDA	#$0E	;white letters
	STA	COLOR1
	LDA	#4	;center titles
	STA	HSCROL
X1	LDA	VCOUNT	;rainbow backgrnd
	BNE	X1	;wait for line 0
	TAY		;and keep track
	LDX	COLCNT	;colour counter
X2	STA	WSYNC	;sync to TV line
	STA	COLBAK	;store in reg
	INX		;inc color #
	TXA
	AND	#$F0	;but make it
	ORA	#$08	;luminance 8
	INY
	CPY	#$F0	;screen bottom?
	BNE	X2	;No.
;
; Now increase the starting colour for
; next TV frame, produces scrolling
; rainbow effect
;
	INC	COLCNT
	LDA	#8	;We have some
	STA	CONSOL	;time left to
	LDA	CONSOL	;check for START
	EOR	#6	;Pushed?
	BEQ	X3	;Yes, so exit
	STA	WSYNC	;keep stuffing
	STA	COLBAK
	BNE	X1	;Infinite loop
X3	RTS		;unless sent here
;
; This subroutine plays the music.
;
MUSIC	LDA	BASTIM	;New note time?
	BPL	BN0	;No.
	LDA	#14	;all notes
	STA	BASTIM	;are 15 jiffies.
	INC	BASCNT
BN0	LDA	BASCNT	;Get the note.
	AND	#7	;mod 8 counter
	TAY
	LDA	BASSLO,Y	;Bass is 16-bit
	STA	AUDF0	;sound, so stuff
	LDA	BASSHI,Y	;lo and hi bytes
	STA	AUDF1	;in channels 0,1
	LDX	BASTIM
	LDA	BASENV,X
	STA	AUDC1	;Apply envelope
	DEC	BASTIM	;dec. duration
;
; Melody (Treble)
;
	LDA	TRBTIM	;Note timer done?
	BPL	TN1	;No.
	INC	TRBCNT	;Yes - inc cntr
	LDY	TRBCNT	;Are we at...
	CPY	#26	;end of tune?
	BMI	TN0	;No.
	LDA	#$FF	;Yes, reset
	STA	TRBCNT	;counter
	BNE	TN2
TN0	LDA	TRBDUR,Y	;load the
	STA	TRBTIM	;duration
TN1	LDY	TRBCNT
	LDA	TREBLE,Y	;Play the note..
	STA	AUDF2
	DEC	TRBTIM	;and dec timer.
TN2	RTS
;
; Various Data Tables
;
ELEPOS	.BYTE	72,160,64,64
	.BYTE	108,124,140,0
COLORS	.BYTE	$82,$22,$B2,$42,$12,$52
	.BYTE	$72,$32,$62,$E4,$06
EMASKS	.BYTE	$C0,$0C,$03,$0C
	.BYTE	$30,$C0,$0C
ELOCS	.BYTE	>P0AREA,>P0AREA
	.BYTE	>MAREA,>MAREA
	.BYTE	>MAREA,>P1AREA
	.BYTE	>P1AREA
STARTS	.BYTE	$40,$B8,$40,$B8,$40
	.BYTE	$B8,$40,$B8,$40,$B8,$40
STAIRS	.BYTE	$B8,$40,$B8,$40,$B8
	.BYTE	$40,$B8,$40,$B8,$40,$B8
ESPED1	.BYTE	0,0,0,0,0,0,0
ESPED2	.BYTE	0,1,0,0,1,0,0
ESPED3	.BYTE	1,1,0,1,0,1,0
ESPED4	.BYTE	0,1,1,1,1,0,1
ESPED5	.BYTE	1,1,1,1,1,1,1
;
LEVSPD	.WORD	ESPED1,ESPED2,ESPED3
	.WORD	ESPED4,ESPED5
;
; Vertical height of tops of floors
;
DANHT	.BYTE	$C0,$B0,$A0,$90
	.BYTE	$80,$70,$60,$50
	.BYTE	$40,$30,$20
;
DANLF1	.BYTE	$00,$0F,$3F,$1C
	.BYTE	$34,$7D,$7D,$6F
	.BYTE	$06,$02,$1E,$3F
	.BYTE	$3F,$3F,$1E,$0C
DANLF2	.BYTE	$00,$0F,$3F,$03
	.BYTE	$0B,$02,$02,$10
	.BYTE	$18,$0E,$1E,$3D
	.BYTE	$39,$39,$1E,$00
DANRT1	.BYTE	$00,$78,$7E,$1C
	.BYTE	$16,$5F,$5F,$7B
	.BYTE	$30,$20,$3C,$7E
	.BYTE	$7E,$7E,$3C,$18
DANRT2	.BYTE	$00,$78,$7E,$60
	.BYTE	$68,$20,$20,$04
	.BYTE	$0C,$38,$3C,$5E
	.BYTE	$4E,$4E,$3C,$00
;
TLINE	.SBYTE	"      "
	.SBYTE	+$80,"000"
	.SBYTE	"       "
TOPLINE	.BYTE	1,$46,0,$46,0,0,$41,0
	.BYTE	$41,0,$41,0,$46,0,$46,5
LLINE	.BYTE	3,$46,0,$46,0,0,$41,0
	.BYTE	$41,0,$41,0,$46,0,$46,2
RLINE	.BYTE	1,$46,0,$46,0,0,$41,0
	.BYTE	$41,0,$41,0,$46,0,$46,4
INFOLN	.SBYTE	"SC "
SSCORE	.SBYTE	+$80,"000000"
	.SBYTE	" MEN "
MENBYT	.SBYTE	+$80,"0"
	.SBYTE	" HI "
HISCORE	.SBYTE	+$80,"000000"
	.SBYTE	" LEV "
LEVBYTE	.SBYTE	+$80,"0"
OVERLN	.SBYTE	"   GAME OVER    "
;
; Music Data
;
BASSLO	.BYTE	$6B,$6B,$96,$6B
	.BYTE	$EA,$6B,$03,$64
BASSHI	.BYTE	$35,$35,$2F,$35
	.BYTE	$2C,$35,$28,$2A
BASENV	.BYTE	$A2,$A6,$AA,$A8
	.BYTE	$A8,$A8,$A8,$A8
	.BYTE	$A8,$A8,$A7,$A5
	.BYTE	$A3,$A0,$A0
TREBLE	.BYTE	68,81,0,68,40,57,0,81
	.BYTE	68,60,57,0,57,0,57,0
	.BYTE	57,60,68,81,91,81,108
	.BYTE	96,0,0
TRBDUR	.BYTE	114,34,89,114,19,19,99
	.BYTE	14,14,14,19,0,18,0,18
	.BYTE	0,18,19,19,19,19,19,14
	.BYTE	14,127,80
;
; The Game Display List
;
DLIST	.BYTE	$70,$70,$C6
MSG	.WORD	TLINE
	.BYTE	$C7
	.WORD	TOPLINE
	.BYTE	$C7
	.WORD	LLINE
	.BYTE	$C7
	.WORD	RLINE
	.BYTE	$C7
	.WORD	LLINE
	.BYTE	$C7
	.WORD	RLINE
	.BYTE	$C7
	.WORD	LLINE
	.BYTE	$C7
	.WORD	RLINE
	.BYTE	$C7
	.WORD	LLINE
	.BYTE	$C7
	.WORD	RLINE
	.BYTE	$C7
	.WORD	LLINE
	.BYTE	$C7
	.WORD	RLINE
	.BYTE	$10,$46
	.WORD	INFOLN
	.BYTE	$06,$41
	.WORD	DLIST
;
; Title Screen Display List
;
TDLIST	.BYTE	$70,$70,$70,$70
	.BYTE	$70,$70,$47
	.WORD	GAME
	.BYTE	$70,$17,$70,$70,$46
	.WORD	AUTHOR
	.BYTE	$70,$70,$46
	.WORD	COPYR
	.BYTE	$70,$06,$70,$70,$56
	.WORD	INSTR
	.BYTE	$70,$70,$41
	.WORD	TDLIST
;
GAME	.SBYTE	"    ELEVATOR    "
	.SBYTE	"     REPAIRMAN      "
AUTHOR	.SBYTE	"BY FRED CAPRILLI"
COPYR	.SBYTE	"    (C) 1985    "
	.SBYTE	"ANALOG COMPUTING"
INSTR	.SBYTE	"    press"
	.SBYTE	" start     "
;
;MODIFIED CHARACTER SET
;
CSETB	.BYTE	$00,$00,$00,$00
	.BYTE	$00,$00,$00,$00
	.BYTE	$80,$80,$80,$80
	.BYTE	$80,$80,$80,$80
	.BYTE	$01,$01,$01,$01
	.BYTE	$01,$01,$01,$01
	.BYTE	$80,$FF,$80,$FF
	.BYTE	$80,$FF,$80,$FF
	.BYTE	$01,$FF,$01,$FF
	.BYTE	$01,$FF,$01,$FF
	.BYTE	$3C,$7E,$7E,$E7
	.BYTE	$E7,$FF,$FF,$FF
	.BYTE	$08,$08,$08,$08
	.BYTE	$08,$08,$08,$08
;
	*=	$02E0
;
	.WORD	INIT
	.END  

This is non-commercial site, its content is based on Atari 8-bit home computer contents and references.
If you feel your rights are violated by showing/using any part of contents of your product represented on this page, please contact me immediatelly so I can remove it!