Trailing-Edge
-
PDP-10 Archives
-
AP-D480B-SB_1978
-
format.bli
There are 12 other files named format.bli in the archive. Click here to see a list.
!THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
! OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.
!COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION
!AUTHOR: T.E. OSTEN/FJI/HPW/DBT
MODULE FORMAT(RESERVE(0,1,2,3),SREG=#17,FREG=#16,VREG=#15,DREGS=4)=
BEGIN
GLOBAL BIND FORMV = 2^24+0^18+31; !VERSION DATE: 30-JUN-1974
%(
REVISION HISTORY
29 ----- ----- COMMENT OUT CODE WHICH SELECTIVELY ALLOWS OPTIONAL COMMAS
AND MAKE COMMAS ALWAYS OPTIONAL
30 ----- ----- ADD THE R FORMAT SPECIFICATION
)%
REQUIRE FMTLEX.BLI;
STRUCTURE STRING[I]=@(.STRING+.I);
STRUCTURE VECTX[I]=[I] .VECTX+.I;
BIND VECTOR FLEX=PLIT(
FLEXNAME GLOBALLY NAMES
%0% PLIT'ILLEGAL CHARACTER',
%1% PLIT'"$"',
%2% PLIT'LITSTRING',
%3% PLIT'"("',
%4% PLIT'")"',
%5% PLIT'END OF STATEMENT?0',
%6% PLIT'"+"',
%7% PLIT'","',
%8% PLIT'"-"',
%9% PLIT'"."',
%10% PLIT'"/"',
%11% PLIT'CONSTANT',
%12% PLIT'"A"',
%13% PLIT'"D"',
%14% PLIT'"E"',
%15% PLIT'"F"',
%16% PLIT'"G"',
%17% PLIT'"I"',
%18% PLIT'"L"',
%19% PLIT'"O"',
%20% PLIT'"P"',
%21% PLIT'"R"',
%22% PLIT'"T"',
%23% PLIT'"X"');
BIND LEFTBUILD = 0;
REQUIRE FRMBNF.BLI;
REQUIRE LOOKFM.BLI;
SWITCHES NOLIST;
REQUIRE FIRST.BLI;
SWITCHES LIST;
! BIND VECTX TYPE[0]= BNFTBL<24,12>,
! VECTX SUBP[0]= BNFTBL<12,12>,
! VECTX NUMBER[0]= BNFTBL<0,12>,
! VECTX LEXNUM[0]= BNFTBL<12,6>,
! VECTX OPNUM[0]= BNFTBL<18,6>;
STRUCTURE TYPSTR[I] = (.TYPSTR+.I)<24,12>;
STRUCTURE SUBSTR[I] = (.SUBSTR+.I)<12,12>;
STRUCTURE NUMSTR[I] = (.NUMSTR+.I)<0,12>;
BIND TYPSTR TYPE = BNFTBL,
SUBSTR SUBP = BNFTBL,
NUMSTR NUMBER = BNFTBL;
FORWARD
FORMATSYN,
ORERROR;
EXTERNAL LSAVE,LEXL,ISN,LEXICAL,FATLEX,WARNLEX,ENTRY,NAME;
EXTERNAL GSTFMTLEX;
% OWN NOCOMM; %
EXTERNAL E0,E2,E3,E70,E61;
% THE FOLLOWING TABLE IS ACCESSED BY LEXICAL( .GSTFMTLEX )
IN ORDER TO RETURN THE PROPER LEXEME CODE %
% THE CODES WHICH ACCESS THE NON-LETTER LEXEMES ARE THE STANDARD
LEXICAL CHARACTER CODES %
BIND DUMDUM = PLIT (
FMTLET GLOBALLY NAMES FMTLEX GLOBALLY NAMES
0, % ADJUSTMENT%
% "A"= #101 % ACHAR ^18+ %ILL % ILLCHAR ,
% "B"= #102 % ILLCHAR ^18+ %TAB % ILLCHAR ,
% "C"= #103 % ILLCHAR ^18+ %LT % ILLCHAR ,
% "D"= #104 % DCHAR ^18+ %BLANK % ILLCHAR ,
% "E"= #105 % ECHAR ^18+ %SPEC % ILLCHAR ,
% "F"= #106 % FCHAR ^18+ %DIGIT % CONST ,
% "G"= #107 % GCHAR ^18+ %UPPER % ILLCHAR ,
% "H"= #110 % ILLCHAR ^18+ %LOWER % ILLCHAR ,
% "I"= #111 % ICHAR ^18+ %FOS % LINEND ,
% "J"= #112 % ILLCHAR ^18+ %EOB % ILLCHAR ,
% "K"= #113 % ILLCHAR ^18+ %REMARK % ILLCHAR ,
% "L"= #114 % LCHAR ^18+ %ANDSGN % ILLCHAR ,
% "M"= #115 % ILLCHAR ^18+ %LPAREN % LPAREN ,
% "N"= #116 % ILLCHAR ^18+ %RPAREN % RPAREN ,
% "O"= #117 % OCHAR ^18+ %COLON % ILLCHAR ,
% "P"= #120 % PCHAR ^18+ %COMMA % COMMA ,
% "Q"= #121 % ILLCHAR ^18+ %DOLLAR % DOLLAR ,
% "R"= #122 % RCHAR ^18+ %MINUS % MINUS ,
% "S"= #123 % ILLCHAR ^18+ %SLASH % SLASH ,
% "T"= #124 % TCHAR ^18+ %PLUS % PLUS ,
% "U"= #125 % ILLCHAR ^18+ %ASTERISK% ILLCHAR ,
% "V"= #126 % ILLCHAR ^18+ %EQUAL % ILLCHAR ,
% "W"= #127 % ILLCHAR ^18+ %LTSGN % ILLCHAR ,
% "X"= #130 % XCHAR ^18+ %GTSGN % ILLCHAR ,
% "Y"= #131 % ILLCHAR ^18+ %NEQSGN % ILLCHAR ,
% "Z"= #132 % ILLCHAR ^18+ %DOT % PERIOD ,
%SEMICOL% ILLCHAR ,
%LITSGN % LITSTRING ,
%OCTSGN % ILLCHAR ,
%COMNTSGN% ILLCHAR ,
%DEBUGSGN% ILLCHAR ,
%UPAROW % ILLCHAR
);
% THE FOLLOWING BIND SPECIFIES THE LEXEMES FOR WHICH FOLLOWING COMMAS ARE
OPTIONAL %
% BIND OKNCM = 1^XCHAR + 1^LITSTRING + 1^SLASH ; %
GLOBAL ROUTINE FORMATSYN (STKNODE) =
BEGIN
EXTERNAL LEXICAL,GSTFMTLEX;
REGISTER NODE,SUBNODE,T2;
NODE_.STKNODE;
SUBNODE_.SUBP[.NODE];
CASE .TYPE[.NODE] OF SET
!
!CASE 0
!
RETURN -1;
!
!CASE 1-LEXEME
!
BEGIN
IF .LSAVE NEQ 0 THEN LSAVE_0 ELSE LEXL_LEXICAL(.GSTFMTLEX);
IF .LEXL NEQ .SUBNODE THEN
BEGIN
RETURN FATLEX ( .FLEXNAME[.SUBNODE],.FLEXNAME[.LEXL],E0<0,0>)
END
% ELSE NOCOMM _ OKNCM AND 1^.LEXL %
END;
!
!CASE 2-META
!
IF FORMATSYN(.SUBNODE) LSS 0 THEN RETURN -1;
!
!CASE 3-AND
!
INCR I FROM .SUBNODE TO .SUBNODE+.NUMBER[.NODE] DO
BEGIN
IF FORMATSYN(.I) LSS 0 THEN RETURN -1
END;
!
!CASE 4-OR
!
BEGIN
IF .LSAVE EQL 0 THEN (LSAVE_-1; LEXL_LEXICAL(.GSTFMTLEX) );
T2 _1^.LEXL;
VREG_INCR I FROM .SUBNODE TO .SUBNODE+.NUMBER[.NODE] DO
IF (.LOOKAHEAD[.I] AND .T2) NEQ 0 THEN EXITLOOP .I;
IF .VREG LSS 0 THEN RETURN ORERROR(.NODE);
IF FORMATSYN(.VREG) LSS 0 THEN RETURN -1
END;
!
!CASE 5-OPTION
!
BEGIN
IF .LSAVE EQL 0 THEN (LSAVE_-1; LEXL_LEXICAL(.GSTFMTLEX) );
T2 _1^.LEXL;
VREG_INCR I FROM .SUBNODE TO .SUBNODE+.NUMBER[.NODE] DO
IF (.LOOKAHEAD[.I] AND .T2) NEQ 0 THEN EXITLOOP .I;
IF .VREG LSS 0 THEN RETURN;
IF FORMATSYN(.VREG) LSS 0 THEN RETURN -1
END;
!
!CASE 6-LIST
!
WHILE 1 DO
BEGIN
IF FORMATSYN(.SUBNODE) LSS 0 THEN RETURN -1;
IF .LSAVE EQL 0 THEN (LSAVE_-1; LEXL_LEXICAL(.GSTFMTLEX) );
%COMMAS ARE NOW ALWAYS OPTIONAL %
IF .LEXL EQL COMMA
THEN
BEGIN
LSAVE _ 0;
% NOCOMM _ 0 %
END
ELSE
BEGIN
% IF .NOCOMM EQL 0 THEN EXITLOOP
ELSE
BEGIN
NOCOMM _ 0; %
IF .LEXL EQL RPAREN OR .LEXL EQL LINEND
THEN EXITLOOP
% END %
END
END;
!
!CASE 7-REPEAT
!
DO
BEGIN
IF FORMATSYN(.SUBNODE) LSS 0 THEN RETURN -1;
IF .LSAVE EQL 0 THEN (LSAVE_-1; LEXL_LEXICAL(.GSTFMTLEX) );
T2 _1^.LEXL;
END
WHILE (.T2 AND .LOOKAHEAD[.NODE]) NEQ 0
TES;
.VREG
END;
ROUTINE ORERROR(NODE) =
%(-----------------------------------------------------------------------------------------------------------------
NONE OF A SET OF "OR" CHOICES WERE FOUND
OUTPUT SUITABLE MESSAGE
-----------------------------------------------------------------------------------------------------------------)%
BEGIN
LOCAL L,N;EXTERNAL ENTRY[10];
N_0;L_.LOOKAHEAD[.NODE];
UNTIL .L DO (L_.L^(-1);N_.N+1);
FATLEX(.FLEXNAME[.N],.FLEXNAME[.LEXL],E2<0,0>);
UNTIL (N_.N+1;L_.L^(-1)) EQL 0 DO
BEGIN
EXTERNAL NUMFATL;
UNTIL .L DO (L_.L^(-1);N_.N+1);
FATLEX(.FLEXNAME[.N],E3<0,0>);
%ADJUST TOTAL NUMBER OF ERRORS%
NUMFATL_.NUMFATL-1
END;
RETURN -1
END;
GLOBAL ROUTINE FORMSTA=
BEGIN
EXTERNAL FORMPTR,IDOFSTATMENT,NEWENTRY,CORMAN,POOL,FORMAREA;
LOCAL NUM,FORPTR,LASTTRUESRC;
REGISTER BASE T1;
MAP BASE FORMPTR;
EXTERNAL SAVSPACE;
GLOBAL FMTPTR,FMTEND;
% FORMATS ARE PROCESSED AS FOLLOWS:
1. MAKE AN INITIAL FORMAT AREA ENTRY FO 10 WORDS
2. FMTPTR IS A BYTE POINTER TO THE FIRST CHARACTER OF THE AREA
3. FMTEND CONTAINS THE ADDRESS OF THE LAST WORD OF THE
AREA +1.
4. THE LEXICAL ANALYZER, WHICH IS CALLED BY FORMATSYN TO
PARSE THE FORMAT WILL DEPOSIT EACH SIGNIFICANT CHARACTER
INTO THE FORMAT AREA. WHEN IT REACHES THE END IT WILL
REQUEST SOME ADDITIONAL SPACE AND CONTINUE.
5. IF WE SUCCESSFULLY MAKE IT BACK THE SIZE OF THE FORMAT AREA
IS COMPUTED ( FMTPTR POINTS TO THE LAST WORD AND FORPTR TO
THE FIRST ) AND ANY UNUSED AREA IS RETURNED TO FREE CORE.
NOT E THAT THE AREA IS ALWAYS INCREMENTED IN 10 WORD
PIECES BECAUSE CORMAN TAKES THESE FROM FREE CORE AND
THUS THEY WILL BE CONTIGIOUS.
6. BUILD THE NODE , UPDATE A FEW POINTERS AND THATS IT
%
% GET A FORMAT AREA %
NAME<LEFT> _ 10;
FORPTR _ CORMAN();
FMTPTR _ (@FORPTR)<36,7>; ! FIRST BYTE
FMTEND _ .FORPTR<RIGHT> + 10; ! THE END
IF FORMATSYN(1) LSS 0 THEN RETURN; !CHECK SYNTAX
!SEMANTIC ANALYSIS BEGINS
% CALCULATE THE SIZE %
NUM _ .FMTPTR<RIGHT> - .FORPTR + 1;
FORMAREA _ .FORMAREA + .NUM<RIGHT>; !ACCUMULATE TOTAL WORDS OCCUPIED BY FORMAT STRINGS
!FOR LATER ALLOCATION USE
% SAVE LASTSRC SO THIS NODE CAN BE REMOVED FROM THE TREE %
LASTTRUESRC _ .LASTSRC;
% BUILD THE NODE %
NAME _ IDOFSTATMENT _ FORMDATA;
NAME<RIGHT>_SORTAB;
T1 _ NEWENTRY();
%NOW REMOVE IT FROM THE SORCE TREES%
IF .LASTTRUESRC EQL 0 THEN LASTSRC _ .SORCPTR<LEFT> ELSE LASTSRC _ .LASTTRUESRC;
!
!MAKE SURE STATEMENT IS LABELLED
!
IF .T1[SRCLBL] EQL 0 THEN FATLEX(E70<0,0>); !NOT LABELLED
T1[FORSIZ]_.NUM;
T1[FORSTRING] _ .FORPTR;
IF .FORMPTR EQL 0 THEN FORMPTR<LEFT>_FORMPTR<RIGHT>_.T1
ELSE (FORMPTR[FMTLINK]_.T1; FORMPTR<RIGHT>_.T1);
% RETURN ANYTHING LEFT %
IF ( NUM _ 9 - ( .NUM MOD 10 )) LSS 9
THEN SAVSPACE ( .NUM, .FMTPTR<RIGHT>+1 );
.VREG
END;
GLOBAL ROUTINE FMTOVER ( CHAR ) =
BEGIN
% THIS ROUTINE IS CALLED IF THE LEXICAL ANALYZER NEEDS MORE SPACE
TO STORE THE FORMAT IN %
EXTERNAL FMTPTR,FMTEND,NAME,CORMAN;
NAME<LEFT> _ 10;
IF CORMAN() NEQ .FMTEND
THEN FATLEX ( PLIT'FORMSTA?0',E61<0,0> ); !BIG TROUBLE
FMTEND _ .FMTEND + 10;
REPLACEN(FMTPTR, .CHAR )
END;
END ELUDOM