Detailed Expanded Summary of the Diface
Unit (SWMM5)
The Diface.pas
unit, written in Object Pascal (Delphi/Lazarus), implements a dialog form (TIfaceFileForm
) used for selecting or specifying an Interface File in EPA SWMM5. An interface file is a disk file that transfers hydrologic and/or hydraulic results between different project runs or modules (e.g., rainfall, runoff, routing). Below is a detailed summary of its purpose, structure, and functionality.
1. Purpose & Scope
EPA SWMM supports interface files to share flow or pollutant results from one model run (or block) into another. The Diface.pas
module provides a user interface for:
- Selecting which type of interface file is used or saved (Rainfall, Runoff, RDII, Hotstart, Inflows, Outflows, etc.).
- Specifying whether the file is to be used (input) in the current run or saved (output) from the current run.
- Browsing or typing in the file path and confirming the validity of this path before finalizing.
Thus the user can easily set the correct interface file in the project’s Options.
2. Key Components
2.1. Form Class: TIfaceFileForm
- Inheritance: Descends from
TForm
, the Delphi standard for visual dialog windows. - Purpose: Captures user input about an interface file.
- Key UI Elements:
- FileTypeCombo: A
TComboBox
listing possible interface file types (Rainfall, Runoff, RDII, etc.). - UseBtn & SaveBtn: Two radio buttons letting the user pick whether the file is read from or written to.
- FileNameEdit: An
TEdit
that shows (and accepts input for) the path to the interface file. - BrowseBtn: A
TBitBtn
that opens either an Open or Save dialog. - OKBtn, CancelBtn, HelpBtn: Standard confirm, cancel, and help controls.
- FileTypeCombo: A
2.2. Major Fields
SaveStatus
: A Boolean indicating which mode is default (save or use).Fname
&Fdir
: Strings that hold the interface file’s chosen name and directory, respectively.OpenDialog
&SaveDialog
: Delphi’s built-in file selection dialog classes.
2.3. Constants
IfaceFileTypes
: A global array enumerating recognized interface file types.ExtensionTxt[]
&FilterTxt[]
: Arrays mapping an index to default file extensions (.rff
,.rof
,.txt
, etc.) and file selection filters.
3. Implementation Details
3.1. Form Lifecycle
-
FormCreate
- Sets up the
FileTypeCombo
with the recognized interface file types (IfaceFileTypes
). - Configures the
BrowseBtn
glyph from a resource (throughProjectImageList
). - Initializes
Fdir
(default directory) andFname
(blank). - Defaults
SaveStatus
toTrue
(meaning "Save") and sets the UI to reflect that state.
- Sets up the
-
FormKeyDown
- Catches F1 to show help when pressed.
3.2. User Interactions
FileTypeCombo
:
The user picks which type of interface file (Rainfall, Runoff, RDII, etc.). If the chosen type is “INFLOWS” or “OUTFLOWS,” only one mode (“Use” or “Save”) might be valid, forcing the other radio button to be disabled.
UseBtn
/ SaveBtn
:
Specifies if the file is used for reading in or for saving out. These can be toggled except for certain file types that can only “Use” or only “Save.”
FileNameEdit
:
User can enter or display a path. The path is validated on OK (the path must be non-empty, and the file must exist if “Use” is selected).
BrowseBtnClick
:
Opens a standard file dialog:
- If “Use” is selected, the
OpenDialog
is shown. - If “Save” is selected, the
SaveDialog
is shown.
Once a file is chosen, the result is stored in Fname
, and the FileNameEdit
is updated.
3.3. Data Flow
Reading from the UI:
- The user picks “Use” or “Save,” which sets the first token to either “SAVE” or “USE”.
- The user picks a file type from
FileTypeCombo
, forming the second token in the final string. - The user picks a file name, forming the third token.
At the end, the string is'SAVE FileType "C:\SomeFile.rof"'
or'USE RDII "D:\Inflow.txt"'
.
Writing to the UI (populating the dialog from an existing setting):
- A string
'SAVE TSERIES "C:\SomeFile.dat"'
is split into tokens. - The first token
'SAVE'
sets the radio button. The second'TSERIES'
selects the file type. The third is the path.
3.4. Important Methods
BrowseBtnClick(Sender: TObject)
- Determines the correct
OpenDialog
orSaveDialog
approach. - Applies extension filters from the
FilterTxt
array based on the file type index. - If the dialog executes successfully, updates
Fname
andFileNameEdit
.
- Determines the correct
OKBtnClick(Sender: TObject)
- Validates the file name is non-blank.
- If it’s a “Use” operation, checks the file physically exists.
- If everything is okay, closes with
mrOK
.
SetData(S: String)
- Given a previously stored
'SAVE <type> "<filepath>"'
string, it parses tokens, setsSaveStatus
, and updates UI.
- Given a previously stored
GetData(var S: String)
- Combines the current
'SAVE'/'USE'
, the chosen type, plus the finalFname
into the final string.
- Combines the current
4. Workflow Example
- User wants to specify a new interface file: The main SWMM UI calls
IfaceFileForm.SetData(oldString)
to fill in existing settings. - User modifies the type (Rainfall to Runoff or etc.) or toggles “Use” or “Save”.
- User browses for a file path, or manually types it in
FileNameEdit
. - OK:
IfaceFileForm.OKBtnClick
verifies the path, closes withmrOK
. The main UI callsGetData(newString)
to retrieve'SAVE <type> "<path>"'
or'USE <type> "<path>"'
.
5. Edge Cases & Validation
- If type is “INFLOWS,” only “Use” is possible; if type is “OUTFLOWS,” only “Save” is possible. The
UseBtn
orSaveBtn
is disabled accordingly. - If “Use” is selected, the file must exist.
- The file path cannot be empty on “OK.”
6. Extensibility & Maintenance
- Additional interface file types can be added to
IfaceFileTypes
,FilterTxt
, andExtensionTxt
. - Additional constraints on file path or existence can be implemented in
OKBtnClick
. - Internationalization could adapt the user-facing strings for different locales.
Conclusion:
The Diface.pas
unit is a specialized form for configuring SWMM interface files. It features radio buttons for “Use”/“Save” mode, a file type combo box, a file path input, and a “Browse” button. Internally, it constructs or parses a 'SAVE/USE type "filepath"'
style string to store the user’s choice in SWMM’s project Options.