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.
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.
SUBROUTINE ProcessInputDataFile
! SUBROUTINE INFORMATION:
! AUTHOR Linda K. Lawrie
! DATE WRITTEN August 1997
! MODIFIED na
! RE-ENGINEERED na
! PURPOSE OF THIS SUBROUTINE:
! This subroutine processes input data file for EnergyPlus. Each "record" is
! parsed into the LineItem data structure and, if okay, put into the
! IDFRecords data structure.
! METHODOLOGY EMPLOYED:
! na
! REFERENCES:
! na
! USE STATEMENTS:
! na
IMPLICIT NONE ! Enforce explicit typing of all variables in this routine
! SUBROUTINE PARAMETER DEFINITIONS:
! na
! INTERFACE BLOCK SPECIFICATIONS
! na
! DERIVED TYPE DEFINITIONS
TYPE (FileSectionsDefinition), ALLOCATABLE :: TempSectionsonFile(:) ! Used during reallocation procedure
TYPE (LineDefinition), ALLOCATABLE :: TempIDFRecords(:) ! Used during reallocation procedure
! SUBROUTINE LOCAL VARIABLE DECLARATIONS:
LOGICAL :: EndofFile = .false.
LOGICAL BlankLine
INTEGER Pos
MaxIDFRecords=ObjectsIDFAllocInc
NumIDFRecords=0
MaxIDFSections=SectionsIDFAllocInc
NumIDFSections=0
ALLOCATE (SectionsonFile(MaxIDFSections))
ALLOCATE (IDFRecords(MaxIDFRecords))
ALLOCATE (LineItem%Numbers(MaxNumericArgsFound))
ALLOCATE (LineItem%NumBlank(MaxNumericArgsFound))
ALLOCATE (LineItem%Alphas(MaxAlphaArgsFound))
ALLOCATE (LineItem%AlphBlank(MaxAlphaArgsFound))
EndofFile=.false.
DO WHILE (.not. EndofFile)
CALL ReadInputLine(IDFFile,Pos,BlankLine,InputLineLength,EndofFile)
IF (BlankLine .or. EndofFile) CYCLE
Pos=SCAN(InputLine,',;')
If (Pos /= 0) then
If (InputLine(Pos:Pos) == ';') then
CALL ValidateSection(InputLine(1:Pos-1),NumLines)
IF (NumIDFSections == MaxIDFSections) THEN
ALLOCATE (TempSectionsonFile(MaxIDFSections+SectionsIDFAllocInc))
TempSectionsonFile(1:MaxIDFSections)=SectionsonFile
DEALLOCATE (SectionsonFile)
ALLOCATE (SectionsonFile(MaxIDFSections+SectionsIDFAllocInc))
SectionsonFile=TempSectionsonFile
DEALLOCATE (TempSectionsonFile)
MaxIDFSections=MaxIDFSections+SectionsIDFAllocInc
ENDIF
else
CALL ValidateObjectandParse(InputLine(1:Pos-1),Pos,EndofFile)
IF (NumIDFRecords == MaxIDFRecords) THEN
ALLOCATE(TempIDFRecords(MaxIDFRecords+ObjectsIDFAllocInc))
TempIDFRecords(1:MaxIDFRecords)=IDFRecords
DEALLOCATE(IDFRecords)
ALLOCATE(IDFRecords(MaxIDFRecords+ObjectsIDFAllocInc))
IDFRecords=TempIDFRecords
DEALLOCATE(TempIDFRecords)
MaxIDFRecords=MaxIDFRecords+ObjectsIDFAllocInc
ENDIF
endif
else
!Error condition, no , or ; on first line
CALL ShowMessage('IP: IDF Line~'//TRIM(IPTrimSigDigits(NumLines))//' '//TRIM(InputLine))
CALL ShowSevereError(', or ; expected on this line',EchoInputFile)
endif
END DO
! IF (NumIDFSections > 0) THEN
! SectionsonFile(NumIDFSections)%LastRecord=NumIDFRecords
! ENDIF
IF (NumIDFRecords > 0) THEN
DO Pos=1,NumObjectDefs
IF (ObjectDef(Pos)%RequiredObject .and. ObjectDef(Pos)%NumFound == 0) THEN
CALL ShowSevereError('IP: No items found for Required Object='//TRIM(ObjectDef(Pos)%Name))
NumMiscErrorsFound=NumMiscErrorsFound+1
ENDIF
ENDDO
ENDIF
RETURN
END SUBROUTINE ProcessInputDataFile