"PARSER for PLUNDERED HEARTS (c) Copyright 1987 Infocom, Inc. All Rights Reserved." ;"Parser global variable convention: All parser globals will begin with 'P-'. Local variables are not restricted in any way." > > > > > ;"pointers used by CLAUSE-COPY (source/destination beginning/end pointers)" >> >> >> > ;"number of bytes in input buffer" > > > <> <> <>>> > ;"Parse-cont variable" > > > > ;"PRSO is a direction" ;"is this necessary?" > ) ( ) ( ) (T )>> > > ;"Orphan flag" > > > > ;"Parser variables and temporaries" ;"Byte offset to # of entries in LEXV" ;"Word offset to start of LEXV entries" ;"Number of words per LEXV entry" ;"Offset to parts of speech byte" ;"Offset to first part of speech" ;"First part of speech bit mask in PSOFF byte" > > > > > ;> > > > " Grovel down the input finding the verb, prepositions, and noun clauses. If the input is or , fall out immediately setting PRSA to ,V?WALK and PRSO to . Otherwise, perform all required orphaning, syntax checking, and noun clause lookup." ) ;(DONT <>) OMERGED OWINNER OLEN LEN (DIR <>) (NW 0) (LW 0) (CNT -1)) > ,P-ITBLLEN> ) (T >)> )>> ;> ;> ;> ;> > > > > ,VEHBIT>> >)> >)> ;"rfix no. 36" > > )> > >) (,P-CONT > > )> >) (T > ,VEHBIT>> >)> > > )> "> >)> > ) ( ,W?OOPS> > ,W?PERIOD ,W?COMMA ;,W?\!> > >)> > ; ) (> >> > >> ,P-LEXELEN>> ;)> > > > > > > )>>)> )> > > 2>> > <+ <* .VAL ,P-LEXELEN> 3>>> ; )> >> ;"Fixes OOPS w/chars" > > ; ; ;>) (T > )>) ;( ,W?OOPS> > ;"rfix 36" ,W?PERIOD ,W?COMMA> > >)> > ) ( )> >> ;"Fixes OOPS w/char" 6>> 7>> <+ <* ,P-LEXELEN> 3>> >;"Will this help?" > ) (T > )>) (T >)> ,W?AGAIN ,W?G> ) ( ) (> >> ) ( > ,W?PERIOD ,W?COMMA ,W?THEN> > ,W?AND>> >> 2>>) (T )>) (T > 1>>)> 0> ) (T >)> ;> ) (T >)>>) (T > ;"fix #36" >>>> > >>> > ;> > 0> > ) ;(>> ) (> >> > ;"next clause added 8/20/84 by JW to enable TELL MY NAME TO BEAST" > ) ( > ) ( > > )> > >) (T )>)> >> ) (> ,ACT?WALK ,ACT?GO> > >> > >>> ,W?THEN>)> > > )>) (> > 2>>>> >>) (> > ;> > >> ; >> )> ;"3/3/86 -- fix OPEN BACK DOOR given that back is also a prep for HAND BACK OBJ -pdl" > >>) (> >> )>) ( ) (T > > > > )>)>) ;( > ) () ( ;"Next expr added to fix FORD, TELL ME WHY" > ) (T )>) (T )> >>)> > > ;"else, when input is just a direction, P-PRSA-WORD will remain whatever it was for the previous turn" > ; )> ;"Unc Parser falling out immediately: dir" > > >> ) (,P-OFLAG )> > T)>> ; > ) "AUX" X Y Z) >>> > >> >> >> )> > ;> > > > ;"For AGAIN purposes, put contents of one LEXV table into another." > > > 2>> > 3>> > > )>>> ;"Put contents of one INBUF into another" ) (T >)>>> ;"Put the word in the positions specified from P-INBUF to the end of OOPS-INBUF, leaving the appropriate pointers in AGAIN-LEXV" > ) (T >> >>>)> > >> > )>> .LEN>> ;"WT? checks whether word pointed at by PTR is the correct part of speech. The second argument is the part of speech (,PS?). The 3rd argument (,P1?), if given, causes the value for that part of speech to be returned." ;> .BIT> ) (T > > >)> )>)>> > .BIT> ) ( 1) (T > > >)> )>)>> > >> .NW) (ELSE >)>)>> ;" Scan through a noun clause, leave a pointer to its starting location" ) (FIRST?? T) NW (LW 0)) 2>> > > .VAL> .WRD> >) (T >)> > )> > >> > 0> >> )> > ) (>> > > ;"fix 'knock on back door', break compiler">>> 4>>) ( > ) ( ) ( > > >)>) ( ;"ADDED 4/27 FOR TURTLE,UP" >> > >> >) ;"This next clause was 2 clauses further down" ;"This attempts to fix EDDIE, TURN ON COMPUTER" ( 0>> > ,W?THEN> >) ( >> T) ;( ,ACT?SHOW ,ACT?HAND ,ACT?FEED> > ;"horrific kludge for 'give her sword to...' --pdl") ;( > > > ,ACT?SHOW ,ACT?HAND ,ACT?FEED>>>) ( >> T) ( > >> 2>>> ) (T >)>) ;"next clause replaced by following on from games with characters" ;( 0>>> >>) ( >) ( T) (T )>) (T )> > >>> > 2>> > 3>> ) (> 0> ) (T > > <- .CHR 48>>>) (>> )> >)>> ;"next COND handles inputs like 4,000" > ,W?COMMA> > >> > 2>>> 2>>>> > 2> .CCTR> ;"returning 0 would = false" )> .TMP>> > ) (T > >> > 2> 2>>> 3> 3>>>)>> > 2>>)>)> ;"this 10000 used to be 3000" )> ,W?NUMBER> > 2>> > 3>> > 0> ) (T > > ) ( > <- .CHR 48>>>) (T )> >)>> > ;"only handles 3 digits after the comma" ) ( ;"if it returned 0, the calling predicate becomes <>" ) (T )>> ) WRD) > 0>> ,PS?VERB ,P1?VERB> > > ) ( > > > )> >>> >>> ) ( ) ( 1> > > > > > >)> )>) (T > ;>)> >) (T )>) ( 1> > > > > > >)>)> > > ) (T )>) (,P-ACLAUSE > > > ) (T > > >)> > > ) (T > )>) ( ,PS?ADJECTIVE> ;"same as WT?" >> ) ( ) ( ,PS?OBJECT> ) (T )> )> > > )>>)>)> > > > ; 0>> > > ,P-ITBLLEN> ) (T >)>> T> )) >) (ELSE )> > ) (ELSE )> 0>> > > > ;"Print undefined word in input. PTR points to the unknown word in P-LEXV" ) (ELSE > >)>>> >> 2> 3>> > >> ) "AUX" BUF) ) (T )>) (T >> 2> 3>>)> > ;" Perform syntax matching operations, using P-ITBL as the source of the verb and adjectives for this input. Returns false if no syntax matches, and does it's own orphaning. If return is true, the syntax is saved in P-SYNTAX." ) (DRIVE2 <>) PREP VERB) >> )> >> > > ,P-SONUMS>> T) (> >> >>> ) ( > > ) ( > )>)> ) (T )>) (T >)>> >>> ) ( >>> ) ;( ) (T ) (T )> ) ( ,ACTORBIT>> ,ACTORBIT>>> ) (T )> ) (T )> > > )> ) (T )>> ) (T > )> )>> > ;"? ,P-OTBL?" ) ( ) (> >) (T > )>> > )> > > > ) (T >)>> )> > )> > ) (.D2 > )>> .THE?>> ) WRD (FIRST?? T) (PN <>)) ) (T >) (T )> > ,W?PERIOD> >> ) ( ) ( ) (T .CP >> )> ) ( > ) ( > ) ( > ) (T >)> >)>)> >>> ;"SYNONYMS first, adjectives follow" ; ;> ) (T )>> > ) (T )>> >) (T > 32>> 1> <+ 1>>)>> > ) (T > )>)>> ) "AUX" OCL BEG END BB EE OBEG CNT B E) > > > > > > )> >> > > )> > >>) (>> >)>) (ELSE >)> >> > .OBEG>> > > >> )> >> )> 2>>> ,P-LEXELEN> 2>>>> > 2>> .WRD> > 2>> ) ( .PREP> >>)>>> >> )> > 1> > > > >> )> > ) (T )>)> .OBJ)>) (T )>> > 0>> > ,P-PRSO> > > >>)> > 0>> > ,P-PRSI> > >> 1> >) (T >)>)>)> > > ) (> ,P-BUTS>> > )> >> .NTBL> > > > > > > "These three must be same length:" > > > > > > ) LEN WV WRD NW (WAS-ALL <>)) > )> ; ; > >> )> ) (T > ) (T >)> > )> >)>) ;( ;"This clause at PARSER too" ) ( > > ) ( >)>) (T > > >)>) ( >> > > T) () () ( )>) (> >> ;"RFIX NO. 40" ) ( )>)> > > )>>> ; ;> ) ( ) ( ) ( ) ( ) ( ) ( ) (T )>> ;> ;"grabs the first adjective, unless it comes across a special-cased adjective" ) ;( > ) ;( ) ;( ) (T )>> ) (OLEN 0) OBJ) > )> ,P-ADJ> > >) (> )>)> ;"Added by JW 4-17-85" > > )> )> > > )> ) (T > ) ( ,VEHBIT> >> .TBL>)> )> .TLEN>> ;>>) ;( > >> "?]" CR> ) (ELSE )>) (> >>>> .LEN>> ) (T )> >> >>> )> > > ) (>> > > ) ( ,P-NC1) (T ,P-NC2)>> <>> ) (.VRB )> > > )>) ( .GCHECK> > ;"Changed 6/10/83 - MARC" > > > ) (T )>)> > > ) ( )> > > >> > )>> ;"ZILCH should stick the # of the last object here" ; "ARB - I semi'd out the clause > in the first REPEAT" ;)> % ;>> ;"ZIP case" '> ;> >> >)> )>>>) (T ;"ZIL case" ' > ) (T >)>> >)> > 1> >)> > > > > > > ) ( >) (T >)> > > > )> > )> ) ( )> > 1> )>>> > > 1>> >> )> )>>)> ;> > >>>>) ;(>>>>) (> ,PS?ADJECTIVE ,P1?ADJECTIVE>>>>) ( ; ;) (T >)> >> 5>> >> > > )> > > )>>)> .LEN> ;> > )>)>> > ) (T ) ( ) (T )>)>> > > > )> > > >> ,P-MOBY-FLAG> ,P-SRCALL) ( ,P-SRCALL) (T ,P-SRCTOP)>>>)>)> >) (T )>>)>> > .OBJ> >> > >>> > >> > 0> ) (T >> > ) (T )>) ( > ) (T )>) ( > ) (T )>)> T) ( T) ( > T) ;"for TAKE ME WITH YOU" (T ) ( ) ( >> >) ( > >) (> >) ( > T>> >) (T )> > > ) ( )> ) (T )> ) ( > > )>)>)>>) (T)>> ) TMP) ,SMANY>>> ) ( ,SMANY>>> ) ( 1> ,SMANY>>> ) ( 1> ,SMANY>>> )> )> > ) ( >) (T >)> ) (T)>> )> > ) (ELSE >)> > ) ( )>>> > ) (ELSE >)> > ) ( )>>> )) > ) (T > > )>)> 0> )>)> .LIT> > 0> ,W?IT>> ) (T <>>)>> > 0> ,W?IT>> ) (T <>>)>> ;"former CRUFTY.ZIL routine" ) (> <- 2> 1>>>> ) (>> 1>>>>> ) (> >> )> >