Trailing-Edge
-
PDP-10 Archives
-
tops20-v7-ft-dist1-clock
-
7-sources/diumlb.bli
There are 4 other files named diumlb.bli in the archive. Click here to see a list.
%TITLE 'DIUMLB -- Library of definitions for data type code mappings.'
!++
! COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1986.
! 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 THAT IS NOT SUPPLIED BY DIGITAL.
!
! FACILITY: Data Interchange Utility (DIU)
!
! ABSTRACT: DIUMLB is the library of definitions and data structures
! used by the Mapping routines (see module DIUMAP).
!
! AUTHOR: Sandy Clemens, Creation Date: 30-Jul-84
!
! HISTORY:
!
! 236 Change library of DIXLIB to DIUDIX.
! Sandy Clemens 19-Jun-86
!
! 73 Get rid of "need_usage". Make all usage type literals POSITIVE so that
! comparison of reqblk[DIU$B_???_USAGE_TYP] (a single BYTE) with the
! the fullword literals always gives the desired result.
! Sandy Clemens 4-Mar-86
!
! 65 Add new usage type codes.
! Sandy Clemens 12-Feb-86
!
!--
!++
!
! Library and require files.
!
!--
%BLISS32
(LIBRARY 'SYS$LIBRARY:XPORT';)
%BLISS36
(LIBRARY 'BLI:XPORT';)
LIBRARY 'DIUDIX';
!++
!
! The maximum possible values for the various data type codes. The
! three sources for data type codes are VAX CDD, TOPS-20 Datatrieve,
! and DIL/DIU sources. The maximum values are determined by what is
! value for each of the sources! The DIL maximum values are defined
! (one for each class) in DIUDIX. The names for the DIL maximum data
! type codes are named DT_CLASS_<class-name>_MAX. For example the max
! type code for the string class is DT_CLASS_STRING_MAX. See DIUDIX
! for more information!
!
!--
LITERAL cdd_max = 260, ! max cdd table index value
dtr_max = 26; ! max dtr table index value
!++
!
! Values for the usage type flag. The usage flag indicates a usage
! type (or character set) which overrides the usage type that may be
! indicated by the data type. This flag should be set to default_typ
! for non-text data types. Text data types are in the classes string
! and display-numeric. Note that packed decimal has a special case
! here because on 36-Bit systems packed decimal can only be used with
! usage EBCDIC, but on 8-bit systems it can be used with any usage.
!
!--
LITERAL default_typ = 0, ! default usage type
ascii_txt = 1, ! ascii text
ebcdic_txt = 2, ! ebcdic text
sixbit_txt = 3, ! sixbit text
unspec_typ = 4; ! type has not been specified yet
!++
!
! Source indicators. The source indicator is passed by any routine
! which calls the mapping routines. The source indicator
! determines whether the source is DTR-20, VAX CDD or DIL/DIU. It
! is necessary to know this in order to know which set of data type
! codes are being mapped from.
!
!--
LITERAL
cdd32_src = 0,
dil_src = 1,
dtr20_src = 2;
!++
! Define two literals which do not conflict with any of the DIL
! datatypes and which can be used to identify the cases of datatype
! OVERLAY and datatype STRUCTURE. The CDD uses the literal value
! 'CDD$K_DTYPE_OVR' which is set to 258 for data type overlay. The
! value 258 is aleady used as a data type code by DIL. The CDD uses
! the literal 'CDD$K_DTYPE_Z' (which is set to 0) for structures, but
! the mapping routines return zero when a requested mapping is
! invalid. Therefore, we can't simply use the CDD codes, so two new
! literals are necesssary.
!--
LITERAL DIU$K_DT_OVERLAY = 4001;
LITERAL DIU$K_DT_STRUCTURE = 4002;
!++
!
! Definition of the OPTLST structure. The OPTLST structure is the
! list of options available if a special usage type switch is
! indicated. The list of options is in a separate structure so that
! space can be saved in the MAP_TAB structure, and because for many
! of the MAP_TABs used in DIUMAP, the options are exactly the same
! for numerous data types. If a data type in a mapping table is a
! usage type, the address of the OPTLST for the data type will be
! stored as part of the MAP_TAB entry.
!
!--
$field optlst_fields =
SET
opt_ascii8 = [$bits(class_code_bits + type_code_bits)], ! ascii 8bit
opt_ascii7 = [$bits(class_code_bits + type_code_bits)], ! ascii 7bit
opt_ebcdic8 = [$bits(class_code_bits + type_code_bits)], ! ebcdic 8bit
opt_ebcdic9 = [$bits(class_code_bits + type_code_bits)], ! ebcdic 9bit
opt_sixbit = [$bits(class_code_bits + type_code_bits)] ! sixbit
TES;
LITERAL optlst_size = $field_set_size;
!++
!
! Macro optlst_vals is used to assign values to a single OPTLST's
! fields. If the caller indicates a usage option, other than the
! default, and the data type's text flag is set to ON in the
! MAP_TAB, then the mapping routines will use the OPTLST indicated
! in the MAP_TAB to select the appropriate data type. For example,
! if a calling program has passed the CDD data type code for ASCII
! 8-bit text, but the user has the EBCDIC flag on and indicates that
! the destination system is LCG, then the data type which should be
! returned is EBCDIC 9-bit. A second example: If the caller passes
! data type code for UNSIGNED NUMERIC ASCII 8-bit (DN8U) but the
! SIXBIT flag is on and the destination system is LCG, then the data
! type which should be returned is UNSIGNED NUMERIC SIXBIT (DN6U).
! The OPTLST table is where this information is stored. This macro
! is used to make assigning values to OPTLST's easier!!! (*WHEW*)
!
!--
MACRO optlst_vals (asc_lcg, asc_8bit, ebc_lcg, ebc_8bit, sxb_lcg) =
[opt_ascii7] = asc_lcg,
[opt_ascii8] = asc_8bit,
[opt_ebcdic9] = ebc_lcg,
[opt_ebcdic8] = ebc_8bit,
[opt_sixbit] = sxb_lcg
%;
!++
!
! Macro OPTLST is used to define a single OPTLST structure...
!
!--
MACRO optlst = BLOCK [optlst_size]
FIELD (optlst_fields)
%;
!++
!
! Definition of the mapping table (MAP_TAB) structure. Each MAP_TAB
! is set up for the index to be a data type code of the source
! facility (CDD, DTR, DIL/DIU). Each MAP_TAB entry, one for each
! possible source data type code, contains a default data type for
! each of the three systems: LCG, 8BIT (VAX/VMS), PRO. Each entry
! also has a text flag which indicates whether or not the data type
! can be effected by a character set preference. If the text flag
! is ON, then there should be an OPTLST address included in the
! MAP_TAB entry. If the text flag is OFF, the OPTLST address should
! be set to zero, althought it will be ignored.
!
!--
$field map_fields =
SET
map_def8 = ! default 8bit data type
[$bits(class_code_bits
+ type_code_bits)],
map_deflcg = ! default LCG data type
[$bits(class_code_bits
+ type_code_bits)],
map_defpro = ! default PRO data type
[$bits(class_code_bits
+ type_code_bits)],
map_txt_flg = [$bit], ! if ON, there are different options
! available, depending on the usage
! type indicated by the caller
map_optlst = [$address] ! address of OPTLST
TES;
LITERAL map_size = $field_set_size;
!++
!
! Macro map_entry is used to define a single map table entry. It
! takes the index, text flag, default 8-bit data type, default LCG
! data type, default PRO data type and the OPTLST address and stuffs
! all this information into the MAP_TAB at the index indicated. The
! index should be the value of a data type code from the source
! facility, depending on what that source facility is (DIU/DIL, CDD,
! DTR).
!
!--
MACRO map_entry (map_indx, txt_flag, def_8bit, def_lcg, def_pro, opts) =
[map_indx, map_def8] = def_8bit,
[map_indx, map_deflcg] = def_lcg,
[map_indx, map_defpro] = def_pro,
%IF txt_flag ! if text flag ON, save OPTLST address
%THEN
[map_indx, map_optlst] = %QUOTE %NAME (opts, '_opt'),
%ELSE
%FI
[map_indx, map_txt_flg] = txt_flag
%;
!++
!
! Macro MAP_TAB is used to define a mapping table structure...
!
!--
MACRO map_tab (size) = BLOCKVECTOR [size, map_size]
FIELD (map_fields)
%;