Google
 

Trailing-Edge - PDP-10 Archives - tops10_integ_tools_v4_10jan-86 - 70,6067/cobol1/alfjus.cob
There are 5 other files named alfjus.cob in the archive. Click here to see a list.
IDENTIFICATION DIVISION.
PROGRAM-ID. ALFJUS.

AUTHOR. D. VISSER.
DATE-WRITTEN.  06-May-83.
DATE-COMPILED.

************************************************************************
*****
*****		PROGRAM NAME: ALFJUS
*****
*****		PURPOSE:
*****			Right justify the accepted input according to the
*****			lenght specified.
*****
*****		NOTES:
*****			VAX-11 COBOL always accepts left-justified, regardless 
*****			of the picture specified for the receiving field 
*****			( accept actually overwrites this picture). 
*****
*****			Parameters to be passed on to this subroutine and will
*****			be handed back are (in this order to be passed on) :
*****                   
*****			WK-ALFANUMERIC : 20 characters alfanumeric, containing
*****					 the input to be right-justified and
*****					 the result to hand back to the program.
*****			WK-LENGHT      : 2 digits numeric, containing the 
*****					 lenght of the input.
*****
*****                   This routine will right-justify the accepted field 
*****			'WK-ALFANUMERIC', starting the right-justification
*****			on the position spacified in 'WK-LENGHT', to make
*****			a move in the calling program possible without having
*****			to use a RIGHT JUSTIFIED clause on the receiving field
*****			of the move. The right-justified result will be handed
*****			back to the program in the same field as the input 
*****			field ('WK-ALFANUMERIC').
*****
************************************************************************
*****
*****	HISTORY				CURRENT VERSION = 001
*****
*****	VERSION	DATE	PROGRAMMER	 CHANGES			
*****
************************************************************************

ENVIRONMENT DIVISION.

DATA DIVISION.

WORKING-STORAGE SECTION.

77  WK-PROGRAM-NAME		PIC X(6)		VALUE "ALFJUS".
77  WK-VERSION			PIC 999 		VALUE 001.

77  T-A				PIC 9(2).
77  T-J				PIC 9(2).

77  WK-NEGATIVE			PIC S9			VALUE -1.

77  WK-TRANSOK			PIC X.

01  WK-ALFATABLE                PIC X(20).
01  WK-A-TAB REDEFINES WK-ALFATABLE.
	05  WK-ALF  		PIC X OCCURS 20.

01  WK-JUSTTABLE		PIC X(20).
01  WK-J-TAB REDEFINES WK-JUSTTABLE.
	05  WK-JUS 		PIC X OCCURS 20.


LINKAGE SECTION.

01  WK-ALFANUMERIC		PIC X(20).
01  WK-LENGHT			PIC 9(2).

PROCEDURE DIVISION
		   USING WK-ALFANUMERIC
			 WK-LENGHT.

A-010-MAINLINE.

	IF WK-LENGHT NOT NUMERIC
		MOVE "Lenght not numeric. " TO WK-ALFANUMERIC
		MOVE 99 TO WK-LENGHT
		GO TO Z-999-RETURN.

	IF WK-LENGHT > 20
		MOVE "Lenght greater 20.  " TO WK-ALFANUMERIC
		MOVE 99 TO WK-LENGHT
		GO TO Z-999-RETURN.

	MOVE WK-ALFANUMERIC TO WK-ALFATABLE.
	MOVE WK-LENGHT TO T-J.

	MOVE ALL SPACES TO WK-JUSTTABLE.
	MOVE SPACE TO WK-TRANSOK.

	IF WK-ALFATABLE = ALL SPACES
		GO TO Z-999-RETURN.

	PERFORM A-110-JUSTIFY THRU A-110-JUSTIFY-EX
		VARYING T-A FROM 20 BY WK-NEGATIVE
		UNTIL T-A < 1
		   OR T-J < 1.

	MOVE WK-JUSTTABLE TO WK-ALFANUMERIC.

	GO TO Z-999-RETURN.

A-110-JUSTIFY.
	IF WK-ALF (T-A) = SPACE
		IF WK-TRANSOK = SPACE
			GO TO A-110-JUSTIFY-EX.
	MOVE WK-ALF (T-A) TO WK-JUS (T-J).
	MOVE "X" TO WK-TRANSOK.
	SUBTRACT 1 FROM T-J.

A-110-JUSTIFY-EX.
	EXIT.

Z-999-RETURN.

	EXIT PROGRAM.