Skip to navigation


Utility routines: BRBR

[Commodore 64 version]

Name: BRBR [Show more] Type: Subroutine Category: Utility routines Summary: The standard BRKV handler for the game
Context: See this subroutine in context in the source code References: This subroutine is called as follows: * BRKBK calls BRBR

This routine is unused in this version of Elite (it is left over from the 6502 Second Processor version).
.BRBR ; When we call this routine, we know that brkd will be ; zero, as it is initialised to zero and the only other ; place it gets changed is in the TITLE routine, where ; it also gets set to 0 DEC brkd ; Set brkd = $FF to indicate that there is a system ; error that needs to be printed out on the title screen ; by the TITLE routine LDX #$FF ; Set the stack pointer to $01FF, which is the standard TXS ; location for the 6502 stack, so this instruction ; effectively resets the stack JSR backtonormal ; Disable the keyboard and set the SVN flag to 0 TAY ; The call to backtonormal sets A to 0, so this sets Y ; to 0, which we use as a loop counter below LDA #7 ; Set A = 7 to generate a beep before we print the error ; message .BRBRLOOP JSR CHPR ; Print the character in A, which contains a line feed ; on the first loop iteration, and then any non-zero ; characters we fetch from the error message INY ; Increment the loop counter LDA ($FD),Y ; Fetch the Y-th byte of the block pointed to by ; ($FD $FE), so that's the Y-th character of the message ; pointed to by the MOS error message pointer BNE BRBRLOOP ; If the fetched character is non-zero, loop back to the ; JSR OSWRCH above to print the it, and keep looping ; until we fetch a zero (which marks the end of the ; message) JMP BR1 ; Jump to BR1 to restart the game