Nodes of different colours represent the following:
Solid arrows point from a parent (sub)module to the submodule which is descended from it. Dashed arrows point from a module being used to the module or program unit using it. Where possible, edges connecting nodes are given different colours to make them easier to distinguish in large graphs.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
character(len=*), | intent(in) | :: | CoilType | |||
character(len=*), | intent(in) | :: | CoilName | |||
logical, | intent(inout) | :: | ErrorsFound |
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed arrows point from an interface to procedures which implement that interface. This could include the module procedures in a generic interface or the implementation in a submodule of an interface in a parent module. Where possible, edges connecting nodes are given different colours to make them easier to distinguish in large graphs.
FUNCTION GetCoilWaterInletNode(CoilType,CoilName,ErrorsFound) RESULT(NodeNumber)
! FUNCTION INFORMATION:
! AUTHOR Linda Lawrie
! DATE WRITTEN April 2011
! MODIFIED na
! RE-ENGINEERED na
! PURPOSE OF THIS FUNCTION:
! This function looks up the given coil and returns the inlet node number. If
! incorrect coil type or name is given, errorsfound is returned as true and node number is returned
! as zero.
! METHODOLOGY EMPLOYED:
! na
! REFERENCES:
! na
! USE STATEMENTS:
USE InputProcessor, ONLY: FindItem
USE WaterCoils, ONLY: GetWaterCoilWaterInletNode=>GetCoilWaterInletNode
IMPLICIT NONE ! Enforce explicit typing of all variables in this routine
! FUNCTION ARGUMENT DEFINITIONS:
CHARACTER(len=*), INTENT(IN) :: CoilType ! must match coil types in this module
CHARACTER(len=*), INTENT(IN) :: CoilName ! must match coil names for the coil type
LOGICAL, INTENT(INOUT) :: ErrorsFound ! set to true if problem
INTEGER :: NodeNumber ! returned node number of matched coil
! FUNCTION PARAMETER DEFINITIONS:
! na
! INTERFACE BLOCK SPECIFICATIONS:
! na
! DERIVED TYPE DEFINITIONS:
! na
! FUNCTION LOCAL VARIABLE DECLARATIONS:
INTEGER :: WhichCoil
! Obtains and allocates HXAssistedCoolingCoil related parameters from input file
IF (GetCoilsInputFlag) THEN ! First time subroutine has been called, get input data
! Get the HXAssistedCoolingCoil input
CALL GetHXAssistedCoolingCoilInput
GetCoilsInputFlag=.false. ! Set logic flag to disallow getting the input data on future calls to this subroutine
End If
IF(TotalNumHXAssistedCoils .GT. 0)THEN
WhichCoil=FindItem(CoilName,HXAssistedCoil%Name,TotalNumHXAssistedCoils)
ELSE
WhichCoil=0
END IF
IF (WhichCoil /= 0) THEN
IF (HXAssistedCoil(WhichCoil)%CoolingCoilType_Num == Coil_CoolingWater) THEN
NodeNumber=GetWaterCoilWaterInletNode(HXAssistedCoil(WhichCoil)%CoolingCoilType, &
HXAssistedCoil(WhichCoil)%CoolingCoilName,ErrorsFound)
ELSEIF (HXAssistedCoil(WhichCoil)%CoolingCoilType_Num == Coil_CoolingWaterDetailed) THEN
NodeNumber=GetWaterCoilWaterInletNode(HXAssistedCoil(WhichCoil)%CoolingCoilType, &
HXAssistedCoil(WhichCoil)%CoolingCoilName,ErrorsFound)
ELSE ! even though validated in Get, still check.
CALL ShowSevereError('GetCoilWaterInletNode: Invalid Cooling Coil for HX Assisted Coil, Type="'// &
TRIM(HXAssistedCoil(WhichCoil)%CoolingCoilType)//'" Name="'//TRIM(CoilName)//'"')
ErrorsFound=.true.
NodeNumber=0 !Objexx:Return Added line to set return value
ENDIF
ELSE
CALL ShowSevereError('GetCoilInletNode: Could not find Coil, Type="'//TRIM(CoilType)//'" Name="'//TRIM(CoilName)//'"')
ErrorsFound=.true.
NodeNumber=0
ENDIF
RETURN
END FUNCTION GetCoilWaterInletNode