Google
 

Trailing-Edge - PDP-10 Archives - BB-H138E-BM - 6-1-sources/wordwrap.bli
There are 10 other files named wordwrap.bli in the archive. Click here to see a list.
 %TITLE 'WORDWRAP - do word wrapping'
MODULE WORDWRAP (				! Do word wrapping
		IDENT = '3-001'			! File: WORDWRAP.BLI Edit: GB3001
		) =
BEGIN
!
!			  COPYRIGHT (c) 1981, 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.
!

!++
! FACILITY:	EDT -- The DEC Standard Editor
!
! ABSTRACT:
!
!	This module trys to do word wrapping after an insert.
!
! ENVIRONMENT:	Runs at any access mode - AST reentrant
!
! AUTHOR: John Sauter, CREATION DATE: April 7, 1982
!
! MODIFIED BY:
!
! 1-001	- Original.  JBS 07-Apr-1982
! 1-002	- New screen update logic.  JBS 13-Sep-1982
! 1-003 - Add a parameter to split line routine.  SMB 16-Nov-1982
! 1-004 - Change the parameter to the split line routine.  SMB 17-Nov-1982
! 3-001 - Add updates from V3 sources.  GB 09-May-1983
!--

%SBTTL 'Declarations'
!
! TABLE OF CONTENTS:
!

REQUIRE 'EDTSRC:TRAROUNAM';

FORWARD ROUTINE
    EDT$$WORD_WRAP;

!
! INCLUDE FILES:
!

REQUIRE 'EDTSRC:EDTREQ';

!
! MACROS:
!
!	NONE
!
! EQUATED SYMBOLS:
!
!	NONE
!
! OWN STORAGE:
!
!	NONE
!
! EXTERNAL REFERENCES:
!
!	In the routine
%SBTTL 'EDT$$WORD_WRAP - do word wrapping'

GLOBAL ROUTINE EDT$$WORD_WRAP 			! Do word wrapping
    =

!++
! FUNCTIONAL DESCRIPTION:
!
!	This routine is called after text has been inserted to do word wrapping
!	if any is called for.
!
! FORMAL PARAMETERS:
!
!	NONE
!
! IMPLICIT INPUTS:
!
!	LN_BUF
!	LN_PTR
!	LN_END
!	WD_WRAP
!
! IMPLICIT OUTPUTS:
!
!	NONE
!
! ROUTINE VALUE:
!
!	Always 1.
!
! SIDE EFFECTS:
!
!	NONE
!
!--

    BEGIN

    EXTERNAL ROUTINE
	EDT$$FMT_CHWID,
	EDT$$CS_LEFT,
	EDT$$CS_RIGHT,
	EDT$$FND_BWD,
	EDT$$SPLT_LNINS;

    EXTERNAL
	LN_BUF,				! Current line buffer.
	LN_PTR,				! Current character pointer.
	LN_END,				! End of current line pointer.
	WD_WRAP;				! Word wrap point.

    LOCAL
	CP,
	SAVE_POINT,
	DIFF,
	COL;

!+
! Do nothing if there is no word wrapping.
!-

    IF (.WD_WRAP NEQ 256)
    THEN
	BEGIN
!+
! Compute the current cursor position.
!-
	COL = 0;
	CP = CH$PTR (LN_BUF,, BYTE_SIZE);

	WHILE CH$PTR_NEQ (.CP, .LN_PTR) DO
	    COL = .COL + EDT$$FMT_CHWID (CH$RCHAR_A (CP), .COL);

!+
! If the current column is beyond the wrap point, wrap the line.
!-

	IF (.COL GTR .WD_WRAP)
	THEN
	    BEGIN
	    SAVE_POINT = .LN_PTR;
	    EDT$$CS_LEFT ();

	    IF (CH$RCHAR (.LN_PTR) EQL %C' ') THEN EDT$$CS_RIGHT () ELSE EDT$$FND_BWD (1);

	    DIFF = CH$DIFF (.SAVE_POINT, .LN_PTR);

	    IF CH$PTR_NEQ (.LN_PTR, CH$PTR (LN_BUF,, BYTE_SIZE)) THEN EDT$$SPLT_LNINS (1);

	    LN_PTR = CH$PLUS (.LN_PTR, .DIFF);
	    END;

	END;

    RETURN (1);
    END;					! of routine EDT$$WORD_WRAP


END
ELUDOM