Trailing-Edge
-
PDP-10 Archives
-
BB-AE97C-BM
-
sources/edtreq.req
There are 11 other files named edtreq.req in the archive. Click here to see a list.
!+
! This file, EDT.REQ, contains definitions for EDT.
!****************************************************************************
!* *
!* COPYRIGHT (c) 1984, 1985 *
!* BY DIGITAL EQUIPMENT CORPORATION, MAYNARD, MASS. *
!* ALL RIGHTS RESERVED. *
!* *
!* THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED *
!* ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE AND WITH THE *
!* INCLUSION OF THE ABOVE COPYRIGHT NOTICE. THIS SOFTWARE OR ANY OTHER *
!* COPIES THEREOF MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY *
!* OTHER PERSON. NO TITLE TO AND OWNERSHIP OF THE SOFTWARE IS HEREBY *
!* TRANSFERRED. *
!* *
!* THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE *
!* AND SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT *
!* CORPORATION. *
!* *
!* DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY OF ITS *
!* SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY DIGITAL. *
!* *
!****************************************************************************
!
! Edit history:
!
! 1-001 - Beginning of edit history.
! 1-002 - Add ASSERT macro, remove bugcheck codes. JBS 01-Jun-1981
! 1-003 - Offset the PDP-11 error codes, so they can be distinguished
! from system-specific error codes. JBS 16-Jul-1981
! 1-004 - Remove the error messages, putting them in
! ERRMSG.REQ. JBS 20-Jul-1981
! 1-005 - Add two fields to TBCB ; one points to the previous buffer,
! the other marks the buffer as a macro. Delete
! the creation of the MAC_BLOCK structure TMV 6-Aug-81
! 1-006 - Add the verb number for the new bell verb. STS 10-Aug-1981
! 1-007 - Add INP_JOURNAL and INP_COMMAND to replace INP_FILE. This
! lets us journal the responses to SUBSTITUTE/QUERY in
! the journal file. JBS 16-Aug-1981
! 1-008 - Add the verb number for the new day/time verb. STS 31-Aug-1981
! 1-009 - Update the routine and variable names. JBS & TMV 16-Aep-1981
! 1-010 - Add new verbs to set up default verb. STS 21-Sep-1981
! 1-011 - Add new verbs for delete select and toggle select. STS 23-Sep-1981
! 1-012 - Add new search and select verb. STS 24-Sep-1981
! 1-013 - Add literals for word and para types. STS 23-Oct-1981
! 1-014 - Add PREV_RANGE. JBS 02-Nov-1981
! 1-015 - Add definitions for file i/o codes and streams. STS 08-Dec-1981
! 1-016 - Change edt$$k to edt$k for file i/o definitions. STS 09-Dec-1981
! 1-017 - Add macro to set up address and length in string desc. STS 11-Jan-1982
! 1-036 - Fix above macro to work with 11's. STS 13-Jan-1982
! 1-019 - Add literals for open output seq and open output noseq. STS 13-Jan-1982
! 1-020 - Chang string_desc macro for bliss16. STS 15-Jan-1982
! 1-021 - Change 32-bit arithmetic to 48-bit arithmetic. SMB 15-Jan-1982
! 1-022 - Modify block allocation so that odd address traps don't occur on 11's. SMB 25-Jan-1982
! 1-023 - Remove original line numbers. SMB 29-Jan-1982
! 1-024 - Make callable literals global. STS 08-Mar-1982
! 1-025 - Remove callable literals. STS 08-Mar-1982
! 1-026 - Add symbols for control C handling. JBS 24-May-1982
! 1-027 - Change VMS multiply. SMB 25-May-1982
! 1-028 - Add FMT_BUFLEN. JBS 05-Jul-1982
! 1-029 - Add verb for xlate. STS 13-Aug-1982
! 1-030 - Remove the keypad definitions to KEYPADDEF.REQ. JBS 13-Aug-1982
! 1-031 - Add ASC_K_CSI, for 8-bit keyboards. JBS 17-Aug-1982
! 1-032 - Add ASC_K_SS3, for 8-bit keyboards. JBS 20-Aug-1982
! 1-033 - Add verb_k_clss. STS 26-Aug-1982
! 1-034 - Add K_RDAHED_LEN. JBS 31-Aug-1982
! 1-035 - Add new screen data structures. SMB 11-Sep-1982
! 1-036 - Put back a line that was deleted by mistake. SMB 15-Sep-1982
! 1-037 - Revise the EDIT section of the new screen data structures. JBS 17-Sep-1982
! 1-038 - Add CC_RDCNT. JBS 17-Sep-1982
! 1-039 - Remove CC_RDCNT. STS 20-Sep-1982
! 1-040 - Work on conditionalizing addline macro for speed. STS 30-Sep-1982
! 1-041 - Add memory allocation maximum. SMB 18-Oct-1982
! 1-042 - Add macros for comparing line numbers. STS 20-Oct-1982
! 1-043 - Work on 11-version of compare macro. STS 21-Oct-1982
! 1-044 - Bind high word of linenumbers in compare macro. STS 21-Oct-1982
! 1-045 - Fix bug in compare. STS 22-Oct-1982
! 1-046 - Work on 11 version of compare macro. STS 26-Oct-1982
! 1-047 - Change 11 compare to call EDT$$CMP_LNO. STS 27-Oct-1982
! 1-048 - Add SCR_EDIT_MINPOS, remove a bunch of unused and obsolete definitions. JBS 27-Oct-1982
! 1-049 - Reduce the size of the screen edit area on the PDP-11. This saves
! space at the expense of time. JBS 15-Nov-1982
! 1-050 - Remove the edit buffer entirely. JBS 27-Dec-1982
! 1-051 - Reduce the amount of code generated by the ASSERT macro, to try
! to save space on the PDP-11. JBS 16-Jan-1983
! 1-052 - Correct the definition of SS3. JBS 19-Jan-1983
! 1-053 - Change the format buffer size for VMS. SMB 24-Feb-1983
!
! 3-001 - Start of modifications for Tops10/20. CG 15-Nov-82
! 3-002 - Use XPORT $FIELD for field definitions.
! 3-003 - Redefine TBCB fields and various macros under BLISS36 conditionals. GB 12-Dec-82
! 3-004 - Add STRING_9 macro for 9-bit strings. CJG 3-Jun-1983
! 3-005 - Change journal constants. CJG 17-Jun-1983
! 3-006 - Change the way that filespecs are handled. CJG 22-Jun-1983
! 3-007 - Add COM_PUSH for PUSH command. CJG 20-Sep-1983
! 3-008 - Fix TBCB layout to stop consistency checks on very large files. CJG 11-Oct-1983
! 3-009 - Make the internal read-ahead buffer the same length as the system
! buffer to prevent data corruption. CJG 21-Dec-1983
! 3-010 - Modify ASSERT macro to include an error code. CJG 30-Jan-1984
!--
!+
! DEFINITION DEFINITIONS
! ~~~~~~~~~~~~~~~~~~~~~~
!
! The following definitions are used to facilitate further definitions.
!-
!+
! Field definition macros. This set of macros allows for definitions
! of the fields of data structures, letting the compiler compute the
! the offsets.
!-
LIBRARY 'BLI:XPORT';
COMPILETIME FIELD_OFFSET = 0;
! Macro to copy a lump of memory
MACRO EDT$$CPY_MEM (LEN, SRCPTR, DSTPTR) = BEGIN EXTERNAL ROUTINE CPYMEM;
CPYMEM (LEN, SRCPTR, DSTPTR) END %;
! Macro to copy a string
MACRO EDT$$CPY_STR (LEN, SRCPTR, DSTPTR) = BEGIN EXTERNAL ROUTINE CPYSTR;
CPYSTR (LEN, SRCPTR, DSTPTR) END %;
!+
! IMPLEMENTATION PARAMETERS.
!
! The following definitions are parameters used in the work-file system
! which may require re-definition for different implementations.
!-
LITERAL
WF_BLN_LEN = 18,
LINE_NUM_LEN = 18, ! Bit length of a line number. (actually 3*18=54)
WC_K_NUM_BUKT = 2;
!+
! TBCB DEFINITION
! ~~~~~~~~~~~~~~~
!
! The EDT work file can contain multiple, independent data sets
! referred to as Text Buffers. A text buffer corresponds to the construct
! of the same name found in EDT user documentation, it is a seqential file
! of variable length records. The records are grouped together into blocks
! of 512 characters. The records in a block are sequentially ordered,
! though the blocks themselves are not. Each block contains a two-byte
! link to the previous and following blocks. In addition to the lines in
! the work-file, an input file may be associated with a text buffer. In this
! case the input file is logically placed at the end of the text buffer.
! The Text buffer is accessed via a control block called the Text Buffer
! Control Block, or TBCB.
!-
$FIELD
TBCB_FIELDS =
SET
TBCB_LINE_ADDR = [$POINTER], ! Pointer to current line.
TBCB_CUR_BUKT = [$SHORT_INTEGER], ! Current bucket number.
TBCB_CUR_PAD = [$SHORT_INTEGER], ! Pad to make line number word aligned for arithmetic routines
TBCB_CUR_LIN = [$SHORT_INTEGER], ! Current line number.
TBCB_CUR_LINM = [$SHORT_INTEGER],
TBCB_CUR_LINH = [$SHORT_INTEGER],
TBCB_CHAR_POS = [$SHORT_INTEGER], ! The character position within the line
TBCB_FIRST_BUKT = [$SHORT_INTEGER], ! First bucket number.
TBCB_LAST_BUKT = [$SHORT_INTEGER], ! Last bucket number.
TBCB_INPUT_LINE = [$SHORT_INTEGER], ! Number of last input line.
TBCB_INPUT_LINM = [$SHORT_INTEGER],
TBCB_INPUT_LINH = [$SHORT_INTEGER],
TBCB_LINE_COUNT = [$INTEGER], ! Count of lines in buffer.
TBCB_LC_M = [$SHORT_INTEGER],
TBCB_LC_H = [$SHORT_INTEGER],
TBCB_CHAR_COUNT = [$INTEGER], ! Count of chars in buffer.
TBCB_INPUT_RAB = [$ADDRESS], ! Pointer to input RAB.
! Not a pointer on TOPS but used
! to indicate if file is still open
TBCB_PREV_BUF = [$POINTER], ! Pointer to previous buffer
TBCB_NEXT_BUF = [$POINTER], ! Pointer to next text buffer.
TBCB_IS_MAC = [$POINTER], ! Buffer is a macro
TBCB_NAME_LEN = [$SHORT_INTEGER], ! Length of buffer name.
TBCB_FILL_NAME = [$SHORT_INTEGER], ! Name filler
TBCB_NAME = [$STRING(0)] ! Name of buffer
TES ;
LITERAL
TBCB_SIZE = $FIELD_SET_SIZE;
MACRO TBCB_BLOCK = BLOCK[TBCB_SIZE] FIELD(TBCB_FIELDS)% ;
!+
! The pos block is the portion of the TBCB which contains information needed
! to locate the current line. This block must be identical to the first
! part of the TBCB or everything will fail.
!-
$FIELD
POS_FIELDS =
SET
POS_LINE_ADDR = [$POINTER], ! Pointer to current line.
POS_CUR_BUKT = [$SHORT_INTEGER], ! Current bucket number.
POS_CUR_PAD = [$SHORT_INTEGER], ! Pad to make line number word aligned for arithmetic.
POS_CUR_LIN = [$SHORT_INTEGER], ! Current line number.
POS_CUR_LINM = [$SHORT_INTEGER],
POS_CUR_LINH = [$SHORT_INTEGER],
POS_CHAR_POS = [$SHORT_INTEGER]
TES ;
LITERAL
POS_SIZE = $FIELD_SET_SIZE; ! Define size of position information
MACRO POS_BLOCK = BLOCK[POS_SIZE] FIELD(POS_FIELDS)%;
!+
! TEXT LINE DEFINITIONS
!
! A line number contains an integer part and a fractional part.
!-
$FIELD
LIN_FIELDS =
SET
LIN_LENGTH = [$SHORT_INTEGER], ! Length of line
LIN_NEXT = [$SHORT_INTEGER], ! Offset to next line in buffer
LIN_NUM = [$SHORT_INTEGER], ! The line number
LIN_NUMM = [$SHORT_INTEGER],
LIN_NUMH = [$SHORT_INTEGER],
LIN_PAD2 = [$SHORT_INTEGER],
LIN_TEXT = [$STRING(0)] ! The actual text
TES ;
LITERAL
LIN_FIXED_SIZE = $FIELD_SET_SIZE;
MACRO LIN_BLOCK = BLOCK[LIN_FIXED_SIZE] FIELD(LIN_FIELDS)%;
!+
! WORK-FILE BUCKET DEFINITIONS
! ~~~~~~~~~~~~~~~~~~~~~~~~~~~
!
! The work file is orgainized into blocks of WF_BLOCK_SIZE characters.
! Each Text Buffer in the work file consists of a linked list of blocks.
!-
LITERAL WF_BUKT_SIZE = 512; ! Size of a work-file block (in words)
LITERAL BYTES_PER_WORD = 5; ! Number of bytes in a word
LITERAL BYTE_SIZE = 7; ! Size of a byte (in text buffer)
$FIELD
WFB_FIELDS =
SET
WFB_PREV_BUKT = [$SHORT_INTEGER], ! Number of previous bucket
WFB_NEXT_BUKT = [$SHORT_INTEGER], ! Number of next bucket
WFB_END = [$POINTER], ! Offset to last record in block
WFB_RECORDS = [$POINTER] ! Address of first record in block
TES ;
LITERAL
WFB_FIXED_SIZE = $FIELD_SET_SIZE;
!+
! LINE NUMBER BLOCK DEFINITIONS
!
! The line number is defined as a block, so it can be handled as
! one word and one half word.
!-
$FIELD
LN_FIELDS =
SET
LN_LO = [$SHORT_INTEGER],
LN_MD = [$SHORT_INTEGER],
LN_HI = [$SHORT_INTEGER]
TES;
LITERAL
LN_SIZE = $FIELD_SET_SIZE;
MACRO LN_BLOCK = BLOCK [LN_SIZE] FIELD(LN_FIELDS) %;
STRUCTURE
LNOVECTOR[I;N] = [N*LN_SIZE] (LNOVECTOR+I*LN_SIZE);
!+
! Semantic node definitions.
!
! The following defines the structures created by the EDT
! command parser semantic routines. These structures form
! a tree-like representation of the command.
!
! The fields which are grouped together are re-definitions of the
! same slot for use in different types of nodes.
!-
FIELD NODE_FIELDS =
SET
NODE_TYPE = [0,0,18,0], ! Identifies the type of node
COM_NUM = [0,18,18,0], ! Identifies the command
RAN_TYPE = [0,18,18,0], ! Identifier type of range
OP_TYPE = [0,18,18,0], ! Identifies type of operand
SEQ_VAL = [0,18,18,0], ! Did the seq switch have value.
RANGE1 = [%UPVAL,0,%BPVAL,0], ! First range specifier
RAN_VAL = [%UPVAL,0,%BPVAL,0], ! Value for range specifier
SW_BITS = [%UPVAL,0,%BPVAL,0], ! Bits for each possible switch
SRCHADDR = [%UPVAL,0,%BPVAL,0], ! Address of search string
SET_TYPE = [%UPVAL,0,%BPVAL,0], ! Which type of set command
LEFT_OP = [%UPVAL,0,%BPVAL,0], ! Left operand for binary ops
OP_LEN = [%UPVAL,0,%BPVAL,0], ! operand length for op nodes.
OP_VAL = [%UPVAL,0,%BPVAL,0], ! Operand value for numerics.
COM_EXPR = [%UPVAL,0,%BPVAL,0], ! Expression pointer for LET
OP_LEFTOP = [%UPVAL,0,%BPVAL,0], ! Left operand for operators.
SUB_BASE = [%UPVAL,0,%BPVAL,0], ! Substring base string.
RANGE2 = [%UPVAL*2,0,%BPVAL,0], ! Second range specifier
SUB_RANGE = [%UPVAL*2,0,%BPVAL,0], ! Pointer to range for ranges
STR_PNT = [%UPVAL*2,0,%BPVAL,0], ! Pointer to a search string
SRCHLEN = [%UPVAL*2,0,%BPVAL,0], ! Search string length
FILSPEC = [%UPVAL*2,0,%BPVAL,0], ! File specification address
SW_VAL1 = [%UPVAL*2,0,%BPVAL,0], ! First value for switches
AS_STR = [%UPVAL*2,0,%BPVAL,0], ! Addr of string for AS
RIGHT_OP = [%UPVAL*2,0,%BPVAL,0], ! Right operand for binary ops.
BUF_NAME = [%UPVAL*2,0,%BPVAL,0], ! Address of buffer name
OP_ADDR = [%UPVAL*2,0,%BPVAL,0], ! Operand address for op nodes.
COM_VARBL = [%UPVAL*2,0,%BPVAL,0], ! Variable pointer for LET
OP_RIGHTOP = [%UPVAL*2,0,%BPVAL,0], ! Right operand for operators.
SUB_START = [%UPVAL*2,0,%BPVAL,0], ! Substring start pos.
TAB_COUNT = [%UPVAL*2,0,%BPVAL,0], ! Count for tabs adjust.
SET_VAL1 = [%UPVAL*3,0,%BPVAL,0], ! Value for set command
REPADDR = [%UPVAL*3,0,%BPVAL,0], ! Replace string address
FSPCLEN = [%UPVAL*3,0,%BPVAL,0], ! File spec length
AS_LEN = [%UPVAL*3,0,%BPVAL,0], ! Length of string for AS
BUF_LEN = [%UPVAL*3,0,%BPVAL,0], ! length of buffer name
SUB_LENGTH = [%UPVAL*3,0,%BPVAL,0], ! Substring length.
NEXT_COM = [%UPVAL*4,0,%BPVAL,0], ! Pointer to next command
NEXT_RANGE = [%UPVAL*4,0,%BPVAL,0], ! Pointer to next range
REPLEN = [%UPVAL*4,0,%BPVAL,0], ! Replace string length
SET_VAL = [%UPVAL*4,0,%BPVAL,0],
KEY_VAL = [%UPVAL*4,0,%BPVAL,0], ! Number of key for def key
PREV_RANGE = [%UPVAL*5,0,%BPVAL,0], ! Reverse of NEXT_RANGE
SWITS = [%UPVAL*5,0,%BPVAL,0], ! Switch block pointer
SW_VAL2 = [%UPVAL*5,0,%BPVAL,0], ! Second switch value
SW_OVR1 = [%UPVAL*6,0,%BPVAL,0], ! Part of second switch value
SW_OVR2 = [%UPVAL*7,0,%BPVAL,0] ! Part of second switch value
TES;
LITERAL
NUM_NODES = 20, ! Number of semantic nodes
NODE_SIZE = 8*%UPVAL; ! Size of semantic node
LITERAL ! Node type equates
COM_NODE = 1, ! Command node
RANGE_NODE = 2, ! Range node
STR_NODE = 3, ! SUBSTITUTE strings
SW_NODE = 4, ! Option switch value
OP_NODE = 5; ! Expression operand
MACRO NODE_BLOCK = BLOCK[NODE_SIZE] FIELD(NODE_FIELDS) %;
!+
! ASCII CHARACTER DEFINITIONS
!
! Commonly used non-printing ASCII characters.
!-
LITERAL
ASC_K_BS = %O'10',
ASC_K_TAB = %O'11',
ASC_K_LF = %O'12',
ASC_K_CTRL_K= %O'13',
ASC_K_FF = %O'14',
ASC_K_CR = %O'15',
ASC_K_SO = %O'16',
ASC_K_SI = %O'17',
ASC_K_CTRL_U= %O'25',
ASC_K_CTRL_Z= %O'32',
ASC_K_ESC = %O'33',
ASC_K_SP = %O'40',
ASC_K_DEL = %O'177',
ASC_K_CSI = ASC_K_ESC + %X'80',
ASC_K_SS3 = ASC_K_SI + %X'80';
!+
! COMMAND NUMBER DEFINITIONS
!
! The following values are used in a command type node to specify which
! command it is.
!-
LITERAL
COM_NULL = 0,
COM_CHANGE = 1,
COM_COPY = 2,
COM_DEFINE = 3,
COM_DELETE = 4,
COM_EXIT = 5,
COM_FIND = 6,
COM_INCLUDE = 7,
COM_INSERT = 8,
COM_MOVE = 9,
COM_PRINT = 10,
COM_QUIT = 11,
COM_REPLACE = 12,
COM_RESEQ = 13,
COM_SET = 14,
COM_SHOW = 15,
COM_SUBS = 16,
COM_TYPE = 17,
COM_WRITE = 18,
COM_SUBS_NEXT=19,
COM_HELP = 20,
COM_CLEAR = 21,
COM_TADJ = 22,
COM_FILL = 23,
COM_DEF_MAC = 24,
COM_MAC_CALL= 25,
COM_PUSH = 26,
COM_TRACE = 27,
COM_XDDT = 28,
! COM_VERIFY = ?,
LAST_COM = 28;
!+
! RANGE TYPE DEFINITIONS
!
! The following constants are used in range nodes to specify the type of
! range.
!-
LITERAL
RAN_NULL = 0,
RAN_NUMBER = 1,
RAN_DOT = 2,
RAN_STR = 3,
RAN_BEGIN = 4,
RAN_END = 5,
RAN_ORIG = 6,
RAN_PATTERN = 7,
RAN_LAST = 8,
RAN_BEFORE = 9,
RAN_REST = 10,
RAN_WHOLE = 11,
RAN_SELECT = 12,
RAN_BUFFER = 13,
RAN_PLUS = 14,
RAN_MINUS = 15,
RAN_FOR = 16,
RAN_THRU = 17,
RAN_MINSTR = 18,
RAN_ALL = 19,
RAN_AND = 20,
NUM_RAN = 20, ! Total number of ranges
NUM_SLR = 7; ! number of single line ranges
!
! Operand types for operand nodes.
!
LITERAL
OP_STRING = 0, ! Operand is a quoted string
OP_NUM = 1, ! Operand is a number
OP_VAR = 2, ! Operand is a variable
OP_DOT = 3, ! Operand is the dot pseudo variable
OP_ADD = 4, ! Operand is an addition operator
OP_SUB = 5, ! Operand is a subtractions operator
OP_MULT = 6, ! Operand is a multiplication operator
OP_DIV = 7, ! Operand is a division operator
OP_AND = 8, ! logical and
OP_OR = 9, ! logical or
OP_LSS = 10, ! compare for less
OP_LEQ = 11, ! compare for less or equal
OP_EQL = 12, ! Compare for equality
OP_GEQ = 13, ! compare for greater or equal
OP_GTR = 14, ! compare for greater
OP_NEQ = 15, ! compare for not equal
OP_AMP = 16, ! concatenation
OP_SUBSTR = 17, ! substringing
OP_NEG = 18, ! negation
OP_NOT = 19, ! logical not
OP_LENGTH = 20, ! length of
OP_COL = 21, ! current column
OP_FIND = 22,
OP_POS = 23, ! current position
OP_LAST_OP = 23; ! last operand type
!+
! LINE NUMBER HANDLING MACROS
!
! These macros are used for arithmetic involving line numbers, so it can
! be transportable across systems with various word lengths. At least 48
! bits of precision are required for line numbers. Line numbers are stored
! as an integer with a scale of -5, i.e. the true value * 10**5, so we can
! have 5 decimal positions and 10 integer positions in the line number.
!-
MACRO
ADDLINE(S1,S2,D1) =
BEGIN EXTERNAL ROUTINE A54_ADD; A54_ADD(S1,S2,D1) END %,
SUBLINE(S3,S4,D2) =
BEGIN EXTERNAL ROUTINE A54_SUB; A54_SUB(S3,S4,D2) END %,
MULTLINE(S5,S6,D3) =
BEGIN EXTERNAL ROUTINE A54_MUL; A54_MUL(S5,S6,D3) END %,
MOVELINE(S11,D6) =
BEGIN EXTERNAL ROUTINE MOVELI; MOVELI(S11,D6) END %,
BUILDLINE(S12,D7) = (D7 = S12; (D7+1) = 0; )%;
!+
! Option switch bit definitions
!-
LITERAL
OPT_QUERY = 2,
OPT_BRIEF = 4,
OPT_NOTYP = 8,
OPT_SEQ = 16,
OPT_DUPL = 32,
OPT_SAVE = 64,
OPT_STAY = 128,
OPT_GO = 256;
MACRO
OPB_QUERY = 1,1 %,
OPB_BRIEF = 2,1 %,
OPB_NOTYP = 3,1 %,
OPB_SEQ = 4,1 %,
OPB_DUPL = 5,1 %,
OPB_SAVE = 6,1 %,
OPB_STAY = 7,1 %,
OPB_GO = 8,1 %;
!
! Input source definitions.
!
! These constants define the source command line input.
!
LITERAL
INP_TERM = 0, ! Terminal
INP_MACRO = 1, ! A macro
INP_COMMAND = 2, ! The startup file
INP_JOURNAL = 3; ! The journal file (only during /RECOVER)
!+
! Terminal type definitions.
!
! These literals define the type of terminal we are running on.
!
LITERAL
TERM_UNKNOWN= 0,
TERM_VT52 = 1,
TERM_VT100 = 2,
TERM_HCPY = 3,
TERM_VT10052= 4;
!+
! Length of type-ahead buffer
!-
LITERAL
K_RDAHED_LEN = 256;
!
! Editor mode definitions.
!
LITERAL
CHANGE_MODE = 0,
LINE_MODE = 1;
!
! definitions for types of words and paras
!
LITERAL
DELIMITED = 0,
NOT_DELIMITED = 1,
WPSPARA = 0,
EDTPARA = 1;
!+
! Define the error codes.
!-
REQUIRE 'EDTSRC:ERRMSG.REQ';
!+
! Definition of the screen update data structure.
!
! This structure has an entry for each line which is represented on the screen.
! In NOTRUNCATE mode, each record may occupy one or more screen lines.
!-
$FIELD
SCR_FIELDS =
SET
SCR_PRV_LINE = [$POINTER], ! Pointer to the previous line
SCR_NXT_LINE = [$POINTER], ! Pointer to the next line
SCR_LINE_IDX = [$BYTE], ! The i'th screen line of this record
SCR_CHR_FROM = [$BYTE], ! Workfile char position from
SCR_CHR_TO = [$BYTE], ! Workfile char position to
SCR_EDIT_MINPOS = [$BYTE], ! Minimum position that has had an edit
SCR_EDIT_MAXPOS = [$BYTE], ! Maximum position that has had an edit
SCR_EDIT_FLAGS = [$BYTE] ! Modify, delete and insert flags
TES;
LITERAL
SCR_SIZE = $FIELD_SET_SIZE;
MACRO
SCREEN_LINE = BLOCK [SCR_SIZE] FIELD(SCR_FIELDS) %;
!+
! These flags go in SCR_EDIT_FLAGS and are also used when calling EDT$$MRK_LNCHG.
!-
LITERAL
SCR_EDIT_MODIFY = 1, ! This line has been modified
SCR_EDIT_INSLN = 2, ! This line has been inserted
SCR_EDIT_DELLN = 4; ! This line has been deleted
!+
! Define function for comparing string ptrs.
!-
MACRO
CH$PTR_GTR(P1,P2) = CH$DIFF(P1,P2) GTR 0 %,
CH$PTR_GEQ(P1,P2) = CH$DIFF(P1,P2) GEQ 0 %,
CH$PTR_EQL(P1,P2) = CH$DIFF(P1,P2) EQL 0 %,
CH$PTR_LEQ(P1,P2) = CH$DIFF(P1,P2) LEQ 0 %,
CH$PTR_LSS(P1,P2) = CH$DIFF(P1,P2) LSS 0 %,
CH$PTR_NEQ(P1,P2) = CH$DIFF(P1,P2) NEQ 0 %;
!+
! Define the entity types.
!-
LITERAL
ENT_K_CHAR = 1,
ENT_K_WORD = 3,
ENT_K_BW = 5,
ENT_K_EW = 7,
ENT_K_LINE = 9,
ENT_K_BL = 11,
ENT_K_NL = 13,
ENT_K_VERT = 15,
ENT_K_EL = 17,
ENT_K_SEN = 19,
ENT_K_BSEN = 21,
ENT_K_ESEN = 23,
ENT_K_PAR = 25,
ENT_K_BPAR = 27,
ENT_K_EPAR = 29,
ENT_K_PAGE = 31,
ENT_K_BPAGE = 33,
ENT_K_EPAGE = 35,
ENT_K_BR = 37,
ENT_K_ER = 39,
ENT_K_QUOTE = 41,
ENT_K_SR = 43,
LAST_K_ENT = 43;
!+
! Define the verb numbers.
!
! These are the codes used to represent the change mode subcommands.
!
! The verbs from VERB_MOVE through VERB_APPEND require entities and
! their verb numbers must remain contiguous.
!-
LITERAL
VERB_K_MOVE = 0,
VERB_K_DELETE= 1,
VERB_K_REPLACE= 2,
VERB_K_CHGC = 3,
VERB_K_CHGU = 4,
VERB_K_CHGL = 5,
VERB_K_SSEL = 6,
VERB_K_FILL = 7,
VERB_K_TADJ = 8,
VERB_K_CUT = 9,
VERB_K_APPEND= 10,
VERB_K_SEL = 11,
VERB_K_SUBS = 12,
VERB_K_PASTE= 13,
VERB_K_INSERT= 14,
VERB_K_XLATE= 15,
VERB_K_CC = 16,
VERB_K_EXIT = 17,
VERB_K_SN = 18,
VERB_K_UNDC = 19,
VERB_K_UNDW = 20,
VERB_K_UNDL = 21,
VERB_K_ADV = 22,
VERB_K_BACK = 23,
VERB_K_REF = 24,
VERB_K_TOP = 25,
VERB_K_HELP = 26,
VERB_K_ASC = 27,
VERB_K_QUIT = 28,
VERB_K_SHL = 29,
VERB_K_SHR = 30,
VERB_K_TAB = 31,
VERB_K_TC = 32,
VERB_K_TD = 33,
VERB_K_TI = 34,
VERB_K_EXT = 35,
VERB_K_KS = 36,
VERB_K_DEFK = 37,
VERB_K_BELL = 38,
VERB_K_DATE = 39,
VERB_K_DUPC = 40,
VERB_K_DLWC = 41,
VERB_K_DMOV = 42,
VERB_K_DESEL = 43,
VERB_K_TGSEL = 44,
VERB_K_CLSS = 45,
LAST_K_VERB = 45;
!
! Changecase types.
!
LITERAL
CASE_K_CHGC = 1, ! Invert case, corresponds to VERB_K_CHGC
CASE_K_CHGU = 2, ! Upper case, corresponds to VERB_K_CHGU
CASE_K_CHGL = 3; ! Lower case, corresponds to VERB_K_CHGL
!+
! PARSER OP-CODE DEFINITIONS
!
! The following are the op-codes accepted by the parser driver.
!-
LITERAL
OPC_ABORT = 0, ! Abort the parse
OPC_ACTION = 1, ! Perform action routine
OPC_CALL = 2, ! Call sub-table
OPC_RETURN = 3, ! End of table or sub-table (return)
OPC_GOTO = 4, ! Unconditional goto
OPC_OPTION = 5, ! Optional phrase check
OPC_REQUIRE = 6, ! Require a specific token
OPC_SELECT = 7, ! select one of several options
OP_ABORT = 0, ! now the bit values
OP_ACTION = 32,
OP_CALL = 64,
OP_RETURN = 96,
OP_GOTO = 128,
OP_OPTION = 160,
OP_REQUIRE = 192,
OP_SELECT = 224;
!+
! Token class definitions
!-
LITERAL
CL_NAME = 0, ! name class
CL_NUMBER = 1, ! the number class
CL_SPECIAL = 2, ! the special character class
CL_STRING = 3; ! The qouted string class
!+
! Parser token handling and matching macros
!-
MACRO
PAR_MIN_LENGTH = 0,0,3,0 %,
PAR_MAX_LENGTH = 0,4,4,0 %,
PAR_OPT_PERCENT = 0,3,1,0 %,
PAR_SYMBOL = 1,0,0,0 %;
!+
! Filespec parsing literal - used by JFNS calls.
!-
LITERAL K_JFNS = %O'221120000001';
!+
! Miscellaneous definitions
!-
!+
! Descriptors on Tops10/20 are one word with the length in the
! left half and the address in the right half.
! File descriptor blocks are in the form a 6-word block containing the JFN,
! the length and address of the full filepec, and the pointers to the four
! main components - device, directory, name, and extension.
!-
MACRO
DSC$L_DESC = 0, 0,36,0 %, ! File descriptor
DSC$A_POINTER = 0, 0,18,0 %, ! Pointer to filespec
DSC$W_LENGTH = 0,18,18,0 %, ! Length of filespec
DSC$W_JFN = 1, 0,18,0 %, ! JFN of file
DSC$W_STATUS = 1,18,18,0 %, ! File status
DSC$A_DEVICE = 2, 0,36,0 %, ! Pointer to device string
DSC$A_DIRECT = 3, 0,36,0 %, ! Pointer to directory string
DSC$A_FNAME = 4, 0,36,0 %, ! Pointer to filename string
DSC$A_FEXTN = 5, 0,36,0 %; ! Pointer to extension string
LITERAL
DSC$K_SIZE = 6; ! Size of descriptor
MACRO STRING_DESC (DESC, LEN, ADDR) =
BEGIN
MAP
DESC : BLOCK[1];
DESC[DSC$A_POINTER] = ADDR;
DESC[DSC$W_LENGTH] = .LEN;
END %;
!+
! The following literals refer to file status.
!-
LITERAL
EDT$K_FILE_OPEN = 1,
EDT$K_FILE_CLOSED = 0;
!+
! FLD macro is used to set up arbitrary fields given a mask. This is used in
! the parser and other places.
!-
MACRO
FLD (VAL, MSK) =
((VAL) ^ (%NBITSU (MSK AND -MSK) -1 )) %;
LITERAL
FLD_9B1 = %O'777000000000', ! First 9-bit byte
FLD_9B2 = %O'000777000000', ! Second 9-bit byte
FLD_9B3 = %O'000000777000', ! Third 9-bit byte
FLD_9B4 = %O'000000000777', ! Fourth 9-bit byte
FLD_LHS = %O'777777000000', ! Left half word
FLD_RHS = %O'000000777777'; ! Right half word
!+
! STRING_9 - generate a string of 9-bit bytes.
!
! This macro must be supplied with a string of values which will be placed
! in 9-bit bytes, 4 per word. If a byte is to be 0, it may be left blank.
! The string must contain an integral number of 4-bytes.
!-
MACRO
STRING_9 (A,B,C,D)[] =
FLD (%IF %NULL (A) %THEN 0 %ELSE A %FI, FLD_9B1) +
FLD (%IF %NULL (B) %THEN 0 %ELSE B %FI, FLD_9B2) +
FLD (%IF %NULL (C) %THEN 0 %ELSE C %FI, FLD_9B3) +
FLD (%IF %NULL (D) %THEN 0 %ELSE D %FI, FLD_9B4)
%IF (%LENGTH GEQ 5) %THEN
, STRING_9 (%REMAINING)
%FI %;
!+
! Screen handling definitions
!-
LITERAL
NO_UPDATE = 256, ! Indicating no update of current line needed
NO_REFRESH = 100, ! Indicating no refresh of screen needed
MESSAG_LINE = 22, ! Line on which messages are displayed
COMMAND_LINE= 23, ! Line on which command prompts are displayed
DIR_FORWARD = 1, ! Forward direction.
DIR_BACKWARD= 0; ! Backward direction.
!+
! Definition of the ASSERT macro. This macro calls EDT$$INTER_ERR if the
! condition is not true.
!-
MACRO ASSERT (CODE,CONDITION) =
BEGIN
IF (NOT (CONDITION))
THEN
BEGIN
EXTERNAL ROUTINE EDT$$INTER_ERR : NOVALUE;
EDT$$INTER_ERR (CODE);
END;
END %;
!+
! Symbols used in control C journaling.
!-
LITERAL
CC_REC_SIZE = 14, ! Size of a control C record
JOU_REC_ESC = %X'1F', ! First (escape) byte of a non-text record in the journal file
CC_REC_FLAG = 1, ! Second byte: control C record
CC_CTR_MAX = 4000000000; ! Maximum counter value in control C handling
!+
! Symbol used in the formatter
!-
LITERAL
FMT_BUFLEN = 512; ! Length of the format buffer
! End of file EDT.REQ