Google
 

Trailing-Edge - PDP-10 Archives - BB-R775C-BM - sources/getfspec.bli
There are 10 other files named getfspec.bli in the archive. Click here to see a list.
 %TITLE 'GETFSPEC - Get a filespec'
MODULE GETFSPEC (				 ! Get filespec components
		IDENT = '3-002'			 ! File: GETFSPEC.BLI Edit:CJG3002
		) =
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
!
! ABSTRACT:
!
!	Get filespec components for use in GTJFN
!
! ENVIRONMENT:	Runs on TOPS-20 only
!
! AUTHOR:	CHRIS GILL	CREATION DATE: 21-June-1983
!
! MODIFIED BY:
!
! 3-002 - Fix the case when a null filespec occurs. CJG 28-Jun-1983
!
!--

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

REQUIRE 'EDTSRC:TRAROUNAM';

FORWARD ROUTINE
    EDT$$GET_FILESPEC : NOVALUE;

!
! INCLUDE FILES:
!

REQUIRE 'EDTSRC:EDTREQ';

REQUIRE 'SYS:JSYS';

!
! EXTERNAL REFERENCES:
!
!	NONE
!
! MACROS:
!
!	NONE
!
! OWN STORAGE:
!
!	NONE
!

%SBTTL 'EDT$$GET_FILESPEC - Get filespec components'

GLOBAL ROUTINE EDT$$GET_FILESPEC (
	JFN,					! JFN of file
	FILE_BLK				! Adrs of descriptor block
		) : NOVALUE =

BEGIN
!++
! FUNCTIONAL DESCRIPTION:
!
!	This routine accepts a JFN and generates pointers to the full file
!	specification (discluding device and directory if they are the defaults),
!	and then creates pointers to device, directory, name, and extension.
!
! FORMAL PARAMETERS:
!
!	JFN	= JFN of file whose specification is required
!	FILE_BLK= Address of the 6-word descriptor block
!
! IMPLICIT INPUTS:
!
!	NONE
!
! IMPLICIT OUTPUTS:
!
!	NONE
!
! ROUTINE VALUE:
!
!	NONE
!
! SIDE EFFECTS:
!
!	CALLS EDT$$ALO_HEAP
!--

    EXTERNAL ROUTINE
	EDT$$DEA_HEAP,
	EDT$$ALO_HEAP;

    LOCAL
	NEW_PTR,
	ADRS;

    MAP
	FILE_BLK : REF BLOCK [];

    IF (.JFN EQL 0) THEN RETURN;

!+
! If we already have memory allocated, then get rid of it.
!-

    ADRS = .FILE_BLK [DSC$A_POINTER];
    IF (.ADRS NEQ 0) THEN EDT$$DEA_HEAP (%REF (130), ADRS);

!+
! Allocate some memory and set the full spec pointer.
!-

    FILE_BLK [DSC$W_JFN] = .JFN;
    EDT$$ALO_HEAP (%REF (130), ADRS);
    FILE_BLK [DSC$A_POINTER] = .ADRS;

    _JFNS (CH$PTR (.ADRS), .JFN, K_JFNS; ADRS);
    FILE_BLK [DSC$W_LENGTH] = CH$DIFF (.ADRS, CH$PTR (.FILE_BLK [DSC$A_POINTER]));

!+
! If the length is too small, then we have a null filespec (may have come from
! EDT$$PA_FILE). In this case, clear the full descriptor and return.
!-

    IF (.FILE_BLK [DSC$W_LENGTH] LEQ 3) THEN
	BEGIN
	ADRS = .FILE_BLK [DSC$A_POINTER];
	EDT$$DEA_HEAP (%REF (130), ADRS);
	FILE_BLK [DSC$L_DESC] = 0;
	RETURN;
	END;
!+
! Get individual components of the filespec. If the device or directory
! fields are the default, then make sure that the pointers are null in
! order to avoid opening the null directory.
!-

    EDT$$ALO_HEAP (%REF (130), ADRS);
    ADRS = CH$PTR (.ADRS);

!+
! Device field.
!-

    FILE_BLK [DSC$A_DEVICE] = .ADRS;
    _JFNS (.ADRS, .JFN, %O'200000000000'; NEW_PTR);
    IF (.NEW_PTR EQL .ADRS)
    THEN
	FILE_BLK [DSC$A_DEVICE] = 0
    ELSE
	BEGIN
	ADRS = .NEW_PTR;
	CH$A_WCHAR (0, ADRS);
	END;

!+
! Directory field.
!-

    FILE_BLK [DSC$A_DIRECT] = .ADRS;
    _JFNS (.ADRS, .JFN, %O'20000000000'; NEW_PTR);
    IF (.NEW_PTR EQL .ADRS)
    THEN
	FILE_BLK [DSC$A_DIRECT] = 0
    ELSE
	BEGIN
	ADRS = .NEW_PTR;
	CH$A_WCHAR (0, ADRS);
	END;

!+
! File name field - always want this.
!-

    FILE_BLK [DSC$A_FNAME] = .ADRS;
    _JFNS (.ADRS, .JFN, %O'1000000000'; ADRS);
    CH$A_WCHAR (0, ADRS);

!+
! File type field - always want this.
!-

    FILE_BLK [DSC$A_FEXTN] = .ADRS;
    _JFNS (.ADRS, .JFN, %O'100000000'; ADRS);
    CH$A_WCHAR (0, ADRS);

    RETURN;

    END;

END
ELUDOM