seastalker/main.zap

506 lines
10 KiB
Plaintext
Raw Permalink Normal View History

2019-04-14 05:34:27 +03:00
.FUNCT GO
START::
2019-04-14 05:35:09 +03:00
?FCN: SET 'LIT,TRUE-VALUE
2019-04-14 05:34:27 +03:00
PUTB P-LEXV,0,59
PUTB YES-LEXV,0,4
SET 'SCORE,0
2019-04-14 05:35:09 +03:00
SET 'HERE,GAME
2019-04-14 05:34:27 +03:00
PUTB FIRST-NAME,0,3
PUTB FIRST-NAME,1,45
PUTB FIRST-NAME,2,45
PUTB FIRST-NAME,3,45
PUTB LAST-NAME,0,3
PUTB LAST-NAME,1,45
PUTB LAST-NAME,2,45
PUTB LAST-NAME,3,45
SET 'WINNER,PLAYER
CALL THIS-IS-IT,VIDEOPHONE
CALL THIS-IS-IT,TIP
CALL THIS-IS-IT,SHARON
2019-04-14 05:35:09 +03:00
FSET? CENTER-OF-LAB,TOUCHBIT /?CND1
2019-04-14 05:34:27 +03:00
CALL INTRO
2019-04-14 05:35:09 +03:00
CALL QUEUE-MAIN-EVENTS
?CND1: SET 'HERE,CENTER-OF-LAB
MOVE TIP,HERE
MOVE PLAYER,HERE
CALL MAIN-LOOP
2019-04-14 05:34:27 +03:00
JUMP ?FCN
.FUNCT INTRO,N
2019-04-14 05:35:09 +03:00
PRINTI "Copyright (c) 1984, 1985 Infocom, Inc. All rights reserved.
2019-04-14 05:34:27 +03:00
2019-04-14 05:35:09 +03:00
Welcome to interactive fiction from Infocom!
2019-04-14 05:34:27 +03:00
In this story, you're the hero or heroine, so we'll use your name!"
CRLF
?PRG3: CRLF
CALL READ-NAME,FIRST-NAME,STR?5 >N
EQUAL? N,M-FATAL /FALSE
PRINTI "Hello "
CALL PRINT-NAME,FIRST-NAME
PRINTI "! "
CALL READ-NAME,LAST-NAME,STR?6 >N
EQUAL? N,M-FATAL /FALSE
PRINTI "Is "
CALL PRINT-NAME,FIRST-NAME
PRINTI " "
CALL PRINT-NAME,LAST-NAME
PRINTI " right?"
CALL YES?
ZERO? STACK /?PRG3
PRINTI "Then let the story begin!"
SET 'N,24
?PRG22: DLESS? 'N,0 \?ELS26
JUMP ?REP23
?ELS26: CRLF
JUMP ?PRG22
?REP23: CALL V-VERSION
CRLF
PRINTI """"
CALL PRINT-NAME,FIRST-NAME
PRINTI ", snap out of it!"" cries "
PRINTD GLOBAL-TIP
PRINTI ", bursting into "
PRINTD YOUR-LABORATORY
PRINTI ". ""The alert signal is on!""
You look up from your plans for the "
PRINTD SUB
PRINTI ", a top-secret submarine that's still being tested. It's designed for capturing marine life on the ocean floor. You notice the "
PRINTD ALARM
PRINTI " on the "
PRINTD VIDEOPHONE
PRINTI " ringing. Someone's trying to reach you over the private "
PRINTD VIDEOPHONE
PRINTI " network of "
PRINTD IU-GLOBAL
PRINTR "!
"
.FUNCT QUEUE-MAIN-EVENTS
2019-04-14 05:35:09 +03:00
SET 'ALARM-RINGING,TRUE-VALUE
2019-04-14 05:34:27 +03:00
CALL QUEUE,I-ALARM-RINGING,-1
PUT STACK,0,1
CALL QUEUE,I-SHOW-SONAR,0
CALL QUEUE,I-UPDATE-FREIGHTER,0
CALL QUEUE,I-UPDATE-SUB-POSITION,0
2019-04-14 05:35:09 +03:00
SET 'OLD-HERE,CENTER-OF-LAB
SET 'TIP-FOLLOWS-YOU?,TRUE-VALUE
2019-04-14 05:34:27 +03:00
RANDOM 250
ADD 250,STACK
CALL QUEUE,I-SNARK-ATTACKS,STACK
PUT STACK,0,1
CALL QUEUE,I-LAMP-ON-SCOPE,5
PUT STACK,0,1
CALL QUEUE,I-PROMPT-1,1
PUT STACK,0,1
CALL QUEUE,I-PROMPT-2,10
PUT STACK,0,1
CALL QUEUE,I-SHARON-GONE,25
PUT STACK,0,1
RTRUE
2019-04-14 05:35:09 +03:00
.FUNCT MAIN-LOOP,TRASH
?PRG1: CALL MAIN-LOOP-1 >TRASH
JUMP ?PRG1
.FUNCT MAIN-LOOP-1,ICNT,OCNT,NUM,CNT,OBJ,TBL,V,PTBL,OBJ1,TMP,?TMP1
SET 'CNT,0
SET 'OBJ,FALSE-VALUE
SET 'PTBL,TRUE-VALUE
EQUAL? QCONTEXT-ROOM,HERE /?CND1
SET 'QCONTEXT,FALSE-VALUE
?CND1: CALL PARSER >P-WON
ZERO? P-WON /?ELS6
2019-04-14 05:34:27 +03:00
GET P-PRSI,P-MATCHLEN >ICNT
GET P-PRSO,P-MATCHLEN >OCNT
2019-04-14 05:35:09 +03:00
ZERO? OCNT \?ELS11
2019-04-14 05:34:27 +03:00
PUSH OCNT
2019-04-14 05:35:09 +03:00
JUMP ?CND7
?ELS11: GRTR? OCNT,1 \?ELS13
2019-04-14 05:34:27 +03:00
SET 'TBL,P-PRSO
2019-04-14 05:35:09 +03:00
ZERO? ICNT \?ELS16
SET 'OBJ,FALSE-VALUE
JUMP ?CND14
?ELS16: GET P-PRSI,1 >OBJ
?CND14: PUSH OCNT
JUMP ?CND7
?ELS13: GRTR? ICNT,1 \?ELS20
SET 'PTBL,FALSE-VALUE
2019-04-14 05:34:27 +03:00
SET 'TBL,P-PRSI
GET P-PRSO,1 >OBJ
PUSH ICNT
2019-04-14 05:35:09 +03:00
JUMP ?CND7
?ELS20: PUSH 1
?CND7: SET 'NUM,STACK
ZERO? OBJ \?CND23
EQUAL? ICNT,1 \?CND23
2019-04-14 05:34:27 +03:00
GET P-PRSI,1 >OBJ
2019-04-14 05:35:09 +03:00
?CND23: EQUAL? PRSA,V?WALK \?ELS30
2019-04-14 05:34:27 +03:00
CALL PERFORM,PRSA,PRSO >V
2019-04-14 05:35:09 +03:00
JUMP ?CND28
?ELS30: ZERO? NUM \?ELS32
2019-04-14 05:34:27 +03:00
GETB P-SYNTAX,P-SBITS
BAND STACK,P-SONUMS
2019-04-14 05:35:09 +03:00
ZERO? STACK \?ELS35
2019-04-14 05:34:27 +03:00
CALL PERFORM,PRSA >V
2019-04-14 05:35:09 +03:00
SET 'PRSO,FALSE-VALUE
JUMP ?CND28
?ELS35: PRINTI "(There isn't anything to "
2019-04-14 05:34:27 +03:00
GET P-ITBL,P-VERBN >TMP
2019-04-14 05:35:09 +03:00
ZERO? P-OFLAG /?ELS42
2019-04-14 05:34:27 +03:00
GET TMP,0
PRINTB STACK
2019-04-14 05:35:09 +03:00
JUMP ?CND40
?ELS42: GETB TMP,2 >?TMP1
2019-04-14 05:34:27 +03:00
GETB TMP,3
CALL WORD-PRINT,?TMP1,STACK
2019-04-14 05:35:09 +03:00
?CND40: PRINTI "!)"
2019-04-14 05:34:27 +03:00
CRLF
2019-04-14 05:35:09 +03:00
SET 'V,FALSE-VALUE
JUMP ?CND28
?ELS32: ZERO? PTBL /?ELS49
GRTR? NUM,1 \?ELS49
EQUAL? PRSA,V?COMPARE \?ELS49
2019-04-14 05:34:27 +03:00
CALL PERFORM,PRSA,OBJECT-PAIR >V
2019-04-14 05:35:09 +03:00
JUMP ?CND28
?ELS49: SET 'TMP,0
?PRG54: IGRTR? 'CNT,NUM \?ELS58
GRTR? TMP,0 \?REP55
2019-04-14 05:34:27 +03:00
PRINTI "The other thing"
2019-04-14 05:35:09 +03:00
EQUAL? TMP,1 /?CND64
2019-04-14 05:34:27 +03:00
PRINTI "s"
2019-04-14 05:35:09 +03:00
?CND64: PRINTI " that you mentioned "
EQUAL? TMP,1 /?ELS73
2019-04-14 05:34:27 +03:00
PRINTI "are"
2019-04-14 05:35:09 +03:00
JUMP ?CND71
?ELS73: PRINTI "is"
?CND71: PRINTI "n't here."
2019-04-14 05:34:27 +03:00
CRLF
2019-04-14 05:35:09 +03:00
JUMP ?REP55
?ELS58: ZERO? PTBL /?ELS86
2019-04-14 05:34:27 +03:00
GET P-PRSO,CNT >OBJ1
2019-04-14 05:35:09 +03:00
JUMP ?CND84
?ELS86: GET P-PRSI,CNT >OBJ1
?CND84: GRTR? NUM,1 \?CND90
EQUAL? OBJ1,NOT-HERE-OBJECT \?ELS95
2019-04-14 05:34:27 +03:00
INC 'TMP
2019-04-14 05:35:09 +03:00
JUMP ?PRG54
?ELS95: EQUAL? OBJ1,PLAYER \?ELS97
JUMP ?PRG54
?ELS97: EQUAL? OBJ1,IT \?ELS102
2019-04-14 05:34:27 +03:00
PRINTD P-IT-OBJECT
2019-04-14 05:35:09 +03:00
JUMP ?CND100
?ELS102: PRINTD OBJ1
?CND100: PRINTI ": "
?CND90: ZERO? PTBL /?ELS111
2019-04-14 05:34:27 +03:00
PUSH OBJ1
2019-04-14 05:35:09 +03:00
JUMP ?CND107
?ELS111: PUSH OBJ
?CND107: CALL QCONTEXT-CHECK,STACK >V
ZERO? PTBL /?ELS119
2019-04-14 05:34:27 +03:00
PUSH OBJ1
2019-04-14 05:35:09 +03:00
JUMP ?CND115
?ELS119: PUSH OBJ
?CND115: SET '?TMP1,STACK
ZERO? PTBL /?ELS127
2019-04-14 05:34:27 +03:00
PUSH OBJ
2019-04-14 05:35:09 +03:00
JUMP ?CND123
?ELS127: PUSH OBJ1
?CND123: CALL PERFORM,PRSA,?TMP1,STACK >V
EQUAL? V,M-FATAL \?PRG54
JUMP ?CND28
?REP55:
?CND28: EQUAL? V,M-FATAL \?CND4
SET 'P-CONT,FALSE-VALUE
JUMP ?CND4
?ELS6: SET 'P-CONT,FALSE-VALUE
?CND4: ZERO? P-WON /FALSE
2019-04-14 05:34:27 +03:00
CALL GAME-VERB?
2019-04-14 05:35:09 +03:00
ZERO? STACK \FALSE
2019-04-14 05:34:27 +03:00
CALL CLOCKER >V
2019-04-14 05:35:09 +03:00
RETURN V
2019-04-14 05:34:27 +03:00
.FUNCT QCONTEXT-CHECK,PRSO,OTHER,WHO=0,N=0
EQUAL? PRSA,V?WHAT,V?HELP /?THN6
EQUAL? PRSA,V?TELL-ABOUT,V?SHOW \FALSE
EQUAL? PRSO,PLAYER \FALSE
?THN6: FIRST? HERE >OTHER /?KLU33
?KLU33:
?PRG10: ZERO? OTHER \?ELS14
JUMP ?REP11
?ELS14: FSET? OTHER,PERSON \?CND12
FSET? OTHER,INVISIBLE /?CND12
EQUAL? OTHER,PLAYER /?CND12
INC 'N
SET 'WHO,OTHER
?CND12: NEXT? OTHER >OTHER /?KLU34
?KLU34: JUMP ?PRG10
?REP11: EQUAL? 1,N \?CND19
ZERO? QCONTEXT \?CND19
CALL SAID-TO,WHO
?CND19: CALL QCONTEXT-GOOD?
ZERO? STACK /FALSE
EQUAL? WINNER,PLAYER \FALSE
SET 'WINNER,QCONTEXT
PRINTI "(said to "
PRINTD QCONTEXT
PRINTR ")"
.FUNCT QCONTEXT-GOOD?
ZERO? QCONTEXT /FALSE
FSET? QCONTEXT,INVISIBLE /FALSE
EQUAL? HERE,QCONTEXT-ROOM \FALSE
CALL META-LOC,QCONTEXT
EQUAL? HERE,STACK /TRUE
RFALSE
.FUNCT SAID-TO,WHO
SET 'QCONTEXT,WHO
SET 'QCONTEXT-ROOM,HERE
2019-04-14 05:35:09 +03:00
RETURN QCONTEXT-ROOM
2019-04-14 05:34:27 +03:00
.FUNCT OBJECT-PAIR-F,P1,P2,?TMP1
GET P-PRSO,P-MATCHLEN
LESS? 2,STACK \?ELS5
EQUAL? PRSA,V?COMPARE \TRUE
PRINTR "That's too many things to compare all at once!"
?ELS5: EQUAL? PRSA,V?COMPARE \FALSE
GET P-PRSO,1 >?TMP1
GET P-PRSO,2
CALL PERFORM,PRSA,?TMP1,STACK
RTRUE
.FUNCT THIS-IS-IT,OBJ
ZERO? OBJ /TRUE
EQUAL? PRSA,V?WALK \?CND4
EQUAL? OBJ,PRSO /TRUE
?CND4: FSET? OBJ,PERSON /?ELS11
EQUAL? OBJ,GLOBAL-HERE,INTDIR /TRUE
SET 'P-IT-OBJECT,OBJ
RTRUE
?ELS11: FSET? OBJ,FEMALE \?ELS16
SET 'P-HER-OBJECT,OBJ
RTRUE
?ELS16: SET 'P-HIM-OBJECT,OBJ
RTRUE
.FUNCT FAKE-ORPHAN,TMP,?TMP1
2019-04-14 05:35:09 +03:00
CALL ORPHAN,P-SYNTAX,FALSE-VALUE
2019-04-14 05:34:27 +03:00
PRINTI "(Be specific: what thing do you want to "
GET P-OTBL,P-VERBN >TMP
ZERO? TMP \?ELS5
PRINTI "tell"
JUMP ?CND3
?ELS5: GETB P-VTBL,2
ZERO? STACK \?ELS9
GET TMP,0
PRINTB STACK
JUMP ?CND3
?ELS9: GETB TMP,2 >?TMP1
GETB TMP,3
CALL WORD-PRINT,?TMP1,STACK
PUTB P-VTBL,2,0
2019-04-14 05:35:09 +03:00
?CND3: SET 'P-OFLAG,TRUE-VALUE
SET 'P-WON,FALSE-VALUE
2019-04-14 05:34:27 +03:00
PRINTR "?)"
.FUNCT TELL-D-LOC,OBJ
PRINTD OBJ
IN? OBJ,GLOBAL-OBJECTS \?ELS7
PRINTI "(gl)"
RTRUE
?ELS7: IN? OBJ,LOCAL-GLOBALS \?ELS11
PRINTI "(lg)"
RTRUE
?ELS11: IN? OBJ,ROOMS \FALSE
PRINTI "(rm)"
RTRUE
.FUNCT FIX-HIM-HER,HEM-OBJECT,V
2019-04-14 05:35:09 +03:00
GETP HEM-OBJECT,P?CHARACTER >V
CALL ACCESSIBLE?,HEM-OBJECT
ZERO? STACK \?CND1
GET GLOBAL-CHARACTER-TABLE,V
2019-04-14 05:34:27 +03:00
RSTACK
2019-04-14 05:35:09 +03:00
?CND1: GET CHARACTER-TABLE,V >V
2019-04-14 05:34:27 +03:00
LOC V
EQUAL? HERE,STACK \FALSE
RETURN V
2019-04-14 05:35:09 +03:00
.FUNCT PERFORM,A,O=0,I=0,V,OA,OO,OI
2019-04-14 05:34:27 +03:00
ZERO? DEBUG /?CND1
PRINTI "[Perform: "
PRINTN A
ZERO? O /?CND9
PRINTI "/"
EQUAL? A,V?WALK \?ELS17
PRINTN O
JUMP ?CND9
?ELS17: CALL TELL-D-LOC,O
?CND9: ZERO? I /?CND22
PRINTI "/"
CALL TELL-D-LOC,I
?CND22: PRINTI "]"
CRLF
?CND1: SET 'OA,PRSA
SET 'OO,PRSO
SET 'OI,PRSI
SET 'PRSA,A
EQUAL? A,V?WALK /?CND30
EQUAL? IT,I,O \?CND33
2019-04-14 05:35:09 +03:00
CALL ACCESSIBLE?,P-IT-OBJECT
ZERO? STACK \?CND33
2019-04-14 05:34:27 +03:00
ZERO? I \?ELS40
CALL FAKE-ORPHAN
RETURN 2
?ELS40: PRINTI "(Sorry, but"
CALL PRINTT,P-IT-OBJECT
PRINTI " isn't here!)"
CRLF
RETURN 2
?CND33: EQUAL? HER,I,O \?CND47
CALL FIX-HIM-HER,P-HER-OBJECT >V
ZERO? V /?CND47
EQUAL? HER,O \?CND53
SET 'O,V
?CND53: EQUAL? HER,I \?CND50
SET 'I,V
?CND50:
?CND47: EQUAL? HIM,I,O \?CND59
CALL FIX-HIM-HER,P-HIM-OBJECT >V
ZERO? V /?CND59
EQUAL? HIM,O \?CND65
SET 'O,V
?CND65: EQUAL? HIM,I \?CND62
SET 'I,V
?CND62:
?CND59: EQUAL? O,IT \?ELS73
SET 'O,P-IT-OBJECT
JUMP ?CND71
?ELS73: EQUAL? O,HER \?ELS75
SET 'O,P-HER-OBJECT
JUMP ?CND71
?ELS75: EQUAL? O,HIM \?CND71
SET 'O,P-HIM-OBJECT
?CND71: EQUAL? I,IT \?ELS80
SET 'I,P-IT-OBJECT
JUMP ?CND30
?ELS80: EQUAL? I,HER \?ELS82
SET 'I,P-HER-OBJECT
JUMP ?CND30
?ELS82: EQUAL? I,HIM \?CND30
SET 'I,P-HIM-OBJECT
?CND30: SET 'PRSI,I
SET 'PRSO,O
2019-04-14 05:35:09 +03:00
SET 'V,FALSE-VALUE
EQUAL? A,V?WALK /?CND85
EQUAL? NOT-HERE-OBJECT,PRSO,PRSI \?CND85
2019-04-14 05:34:27 +03:00
CALL D-APPLY,STR?7,NOT-HERE-OBJECT-F >V
2019-04-14 05:35:09 +03:00
ZERO? V /?CND85
SET 'P-WON,FALSE-VALUE
?CND85: CALL THIS-IS-IT,PRSI
2019-04-14 05:34:27 +03:00
CALL THIS-IS-IT,PRSO
SET 'O,PRSO
SET 'I,PRSI
2019-04-14 05:35:09 +03:00
ZERO? V \?CND94
GETP WINNER,P?ACTION
2019-04-14 05:34:27 +03:00
CALL DD-APPLY,STR?8,WINNER,STACK >V
2019-04-14 05:35:09 +03:00
?CND94: ZERO? V \?CND97
LOC WINNER
2019-04-14 05:34:27 +03:00
GETP STACK,P?ACTION
CALL D-APPLY,STR?9,STACK,M-BEG >V
2019-04-14 05:35:09 +03:00
?CND97: ZERO? V \?CND100
GET PREACTIONS,A
2019-04-14 05:34:27 +03:00
CALL D-APPLY,STR?10,STACK >V
2019-04-14 05:35:09 +03:00
?CND100: SET 'NOW-PRSI,TRUE-VALUE
ZERO? V \?CND103
ZERO? I /?CND103
2019-04-14 05:34:27 +03:00
GETP I,P?ACTION
CALL D-APPLY,STR?11,STACK >V
2019-04-14 05:35:09 +03:00
?CND103: SET 'NOW-PRSI,FALSE-VALUE
ZERO? V \?CND108
ZERO? O /?CND108
EQUAL? A,V?WALK /?CND108
2019-04-14 05:34:27 +03:00
LOC O
2019-04-14 05:35:09 +03:00
ZERO? STACK /?CND108
2019-04-14 05:34:27 +03:00
LOC O
2019-04-14 05:35:09 +03:00
GETP STACK,P?CONTFCN >V
ZERO? V /?CND108
2019-04-14 05:34:27 +03:00
LOC O
2019-04-14 05:35:09 +03:00
CALL DD-APPLY,STR?12,STACK,V >V
?CND108: ZERO? V \?CND117
ZERO? O /?CND117
EQUAL? A,V?WALK /?CND117
2019-04-14 05:34:27 +03:00
GETP O,P?ACTION
CALL D-APPLY,STR?13,STACK >V
2019-04-14 05:35:09 +03:00
?CND117: ZERO? V \?CND122
GET ACTIONS,A
CALL D-APPLY,FALSE-VALUE,STACK >V
?CND122: EQUAL? V,M-FATAL /?CND125
CALL GAME-VERB?
ZERO? STACK \?CND125
2019-04-14 05:34:27 +03:00
LOC WINNER
GETP STACK,P?ACTION
CALL D-APPLY,STR?14,STACK,M-END >V
2019-04-14 05:35:09 +03:00
?CND125: SET 'PRSA,OA
2019-04-14 05:34:27 +03:00
SET 'PRSO,OO
SET 'PRSI,OI
RETURN V
.FUNCT DD-APPLY,STR,OBJ,FCN
ZERO? DEBUG /?CND1
PRINTI "["
PRINTD OBJ
PRINTI "=]"
?CND1: CALL D-APPLY,STR,FCN
RSTACK
.FUNCT D-APPLY,STR,FCN,FOO=0,RES
ZERO? FCN /FALSE
ZERO? DEBUG /?CND8
ZERO? STR \?ELS14
PRINTI "[Action:]"
CRLF
JUMP ?CND8
?ELS14: PRINTI "["
PRINT STR
PRINTI ": "
?CND8: ZERO? FOO /?ELS25
CALL FCN,FOO
JUMP ?CND21
?ELS25: CALL FCN
?CND21: SET 'RES,STACK
ZERO? DEBUG /?CND29
ZERO? STR /?CND29
EQUAL? RES,M-FATAL \?ELS36
PRINTI "Fatal]"
CRLF
RETURN RES
?ELS36: ZERO? RES \?ELS40
PRINTI "Not handled]"
CRLF
RETURN RES
?ELS40: PRINTI "Handled]"
CRLF
?CND29: RETURN RES
.ENDI