Trailing-Edge
-
PDP-10 Archives
-
cobol12c
-
spac.mac
There are 9 other files named spac.mac in the archive. Click here to see a list.
TITLE SPAC FOR LIBOL V12C
SUBTTL CHECK STRING FOR SPACES /ACK
SEARCH COPYRT
SALL
;COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1974, 1985
;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.
;REVISION HISTROY:
;V10 *****
; 13-DEC-74 /ACK CREATION.
; 5/10/75 /DBT BIS CODE
;*****
SEARCH LBLPRM ;DEFINE PARAMETERS.
%%LBLP==:%%LBLP
EBCMP.==:EBCMP.
BIS==:BIS
EXTERN EASTB. ;FORCE EASTBL TO BE LOADED.
HISEG
.COPYRIGHT ;Put COPYRIGHT statement in .REL file.
COMMENT \
THIS ROUTINE CHECKS A STRING TO SEE IF IT CONTAINS ONLY SPACES.
CALL:
MOVEI 16,PARAMETER ADDRESS
PUSHJ 17,SPAC.6/SPAC.7/SPAC.9
PARAMETER:
BITS 0-5 BYTE POINTER RESIDUE FOR INPUT FIELD.
BIT 6 IGNORED (1 IF A SIGN IS PRESENT.)
BITS 7-17 SIZE OF THE INPUT FIELD.
BITS 18-35 ADDRESS OF THE FIRST CHARACTER OF THE INPUT FIELD.
RETURNS:
CALL+1 IF THE STRING LENGTH IS ZERO OR CONTAINS A CHARACTER
OTHER THAN A SPACE.
CALL+2 IF THE STRING CONTAINS ALL SPACES.
REGISTERS USED:
CH,SPACE,JAC, IPTR, CNT, SW
\
ENTRY SPAC.6 ;IF THE STRING IS SIXBIT.
ENTRY SPAC.7 ;IF THE STRING IS ASCII.
IFN EBCMP.,<
ENTRY SPAC.9 ;IF THE STRING IS EBCDIC.
>
EXTERN SIXSP. ;WHAT A SIXBIT SPACE LOOKS LIKE.
EXTERN ASCSP. ;WHAT AN ASCII SPACE LOOKS LIKE.
IFN EBCMP.,<
EXTERN EBCSP. ;WHAT AN EBCDIC SPACE LOOKS LIKE.
>
IFE BIS,<
;LOCAL AC DEFINITIONS:
SPACE==TAC4
EXTERN RET.2 ;RETURNS TO CALL+2.
EXTERN SET1. ;SETS UP THE PARAMETERS.
SPAC.6: JSP CH, SPAC ;ENTER HERE IF THE INPUT IS SIXBIT,
SPAC.7: JSP CH, SPAC ; HERE IF IT IS ASCII OR
IFN EBCMP.,<
SPAC.9: JSP CH, SPAC ; HERE IF IT IS EBCDIC.
>
SPAC: SUBI CH, SPAC.6-5 ;FIND OUT WHAT THE INPUT LOOKS LIKE.
MOVE SPACE, SPACES-6(CH) ;SELECT THE APPROPRATE SPACE.
JSP JAC, SET1. ;GO SET UP THE PARAMETERS.
;NOTE: IF THE STRING LENGTH IS ZERO
; WE RETURN TO CALL+1, NOT HERE.
SPAC1: ILDB CH, IPTR ;GET A CHAR.
CAIE CH, (SPACE) ;IS IT A SPACE?
POPJ PP, ;NO, RETURN TO CALL+1.
SOJG CNT, SPAC1 ;LOOP IF THERE ARE MORE CHARS.
JRST RET.2 ;RETURN TO CALL+2 - ALL SPACES.
> ;END OF NON-BIS
SPACES: EXP SIXSP.
EXP ASCSP.
IFN EBCMP.,<
IFN BIS,<
BLOCK 1
>
EXP EBCSP.
>
IFN BIS,<
EXTERN BSET1. ;SETS UP THE PARAMETERS.
SPAC.6: JSP BISCH, SPAC ;ENTER HERE IF THE INPUT IS SIXBIT,
SPAC.7: JSP BISCH, SPAC ; HERE IF IT IS ASCII OR
IFN EBCMP.,<
BLOCK 1
SPAC.9: JSP BISCH, SPAC ; HERE IF IT IS EBCDIC.
>
SPAC: SUBI BISCH, SPAC.6-5 ;FIND OUT WHAT THE INPUT LOOKS LIKE.
MOVE BIST0+E0.FLT, SPACES-6(BISCH) ;SELECT THE APPROPRATE SPACE.
;FOR FILL CHARACTER
JSP JAC, BSET1. ;GO SET UP THE PARAMETERS.
;NOTE: IF THE STRING LENGTH IS ZERO
; WE RETURN TO CALL+1, NOT HERE.
SETZB DSTPT,DSTCNT ;NO DESTINATION - COMPARE AGAINST
; THE FILL CHARACTER
MOVE BIST0+E0.INS,[CMPSN] ;COMPARE NOT EQUAL
EXTEND B.FLAG,BIST0
AOS (PP) ;EQUAL TO SPACES
POPJ PP, ;NOT SPACES
> ;END OF BIS
END