Trailing-Edge
-
PDP-10 Archives
-
bb-r775c-bm_tops20_ks_upd_3
-
sources/wfclear.bli
There are 10 other files named wfclear.bli in the archive. Click here to see a list.
%TITLE 'WFCLEAR - empty the current buffer'
MODULE WFCLEAR ( ! Empty the current buffer
IDENT = '1-002' ! File: WFCLEAR.BLI Edit: JBS1002
) =
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:
!
! Empty the current buffer.
!
! ENVIRONMENT: Runs at any access mode - AST reentrant
!
! AUTHOR: Bob Kushlis, CREATION DATE: October 16, 1978
!
! MODIFIED BY:
!
! 1-001 - Original. DJS 23-Feb-1981. This module was created by
! extracting routine EDT$$WF_CLRBUF from module EDTWF.
! 1-002 - Regularize headers. JBS 16-Mar-1981
!--
%SBTTL 'Declarations'
!
! TABLE OF CONTENTS:
!
REQUIRE 'EDTSRC:TRAROUNAM';
FORWARD ROUTINE
EDT$$WF_CLRBUF : NOVALUE;
!
! INCLUDE FILES:
!
REQUIRE 'EDTSRC:EDTREQ';
!
! MACROS:
!
! NONE
!
! EQUATED SYMBOLS:
!
! NONE
!
! OWN STORAGE:
!
! NONE
!
! EXTERNAL REFERENCES:
!
! In the routine
%SBTTL 'EDT$$WF_CLRBUF - empty the current buffer'
GLOBAL ROUTINE EDT$$WF_CLRBUF ! Empty the current buffer
: NOVALUE =
!++
! FUNCTIONAL DESCRIPTION:
!
! Clear the entire current buffer. The first bucket of the buffer is
! updated to be empty, and, if there is more than one, the rest of the
! bucket is placed on the available bucket list. Note that since the
! buckets are already linked together, we need only link the last bucket
! in the buffer to the current available bucket, then make avail the
! first bucket we are releasing.
!
! FORMAL PARAMETERS:
!
! NONE
!
! IMPLICIT INPUTS:
!
! CUR_BUF
! WK_AVAIL
! WK_BUK
! WK_CURBUK
! LNO_ZERO
!
! IMPLICIT OUTPUTS:
!
! WK_AVAIL
! WK_BUK
! CUR_BUF
! WK_MODFD
!
! ROUTINE VALUE:
!
! NONE
!
! SIDE EFFECTS:
!
! NONE
!
!--
BEGIN
EXTERNAL ROUTINE
EDT$$WF_BOT : NOVALUE,
EDT$$TOP_BUF : NOVALUE;
EXTERNAL
CUR_BUF : REF TBCB_BLOCK, ! Current text buffer control block
WK_AVAIL, ! Pointer to next available deleted bucket
WK_BUK : ! Pointer to current bucket
REF BLOCK [WF_BUKT_SIZE] FIELD (WFB_FIELDS),
WK_CURBUK, ! Number of the current bucket
WK_MODFD, ! Flag indicating bucket was modified
LNO_ZERO : LN_BLOCK;
EDT$$TOP_BUF ();
!+
! Release remaining buckets if there are more than one.
!-
IF (.WK_BUK [WFB_NEXT_BUKT] NEQ 0)
THEN
BEGIN
EDT$$WF_BOT ();
WK_BUK [WFB_NEXT_BUKT] = .WK_AVAIL;
WK_MODFD = 1;
EDT$$TOP_BUF ();
WK_AVAIL = .WK_BUK [WFB_NEXT_BUKT];
END;
CUR_BUF [TBCB_LINE_ADDR] = WFB_FIXED_SIZE;
WK_BUK [WFB_END] = WFB_FIXED_SIZE;
WK_BUK [WFB_NEXT_BUKT] = 0;
WK_MODFD = 1;
MOVELINE (LNO_ZERO, CUR_BUF [TBCB_LINE_COUNT]);
CUR_BUF [TBCB_CHAR_COUNT] = 0;
CUR_BUF [TBCB_LAST_BUKT] = .WK_CURBUK;
END;
END
ELUDOM