Showing posts with label SWMM5 Delphi GUI Uvalidate.pas Summary. Show all posts
Showing posts with label SWMM5 Delphi GUI Uvalidate.pas Summary. Show all posts

Monday, December 30, 2024

SWMM5 Delphi GUI Uvalidate.pas Summary

 Below is a high-level summary of Uvalidate.pas, a Delphi unit responsible for validating new or edited property values of EPA SWMM objects in the SWMM GUI.


1. Purpose & Overview

The Uvalidate.pas unit’s central function is ValidateEditor, which checks if new or modified property values (entered by a user in the Property Editor) are valid for the particular SWMM object (e.g., rain gage, subcatchment, node, link, or map label). It ensures that:

  • Required fields are not blank,
  • Numeric fields contain valid numbers,
  • Key constraints (such as unique ID names or nonzero values) are honored,
  • Geometric constraints (like not connecting a link’s start and end node to the same node) are satisfied.

When validation fails, an error message is displayed to the user.


2. Key Components

2.1 Main Validation Routine

  1. ValidateEditor(I: Integer; var S: String; var E: String): Boolean
    • The primary entry point from the Property Editor.
    • Parameters:
      • I = the index of the property being changed,
      • S = the new string value,
      • E = returned error message (if any).
    • Determines the object type (e.g., RAINGAGE, SUBCATCH, etc.) from a global EditorObject variable and dispatches the validation to specialized routines.

2.2 Specialized Validation Subroutines

Each SWMM object type has its own function to check properties:

  1. ValidateRaingage

    • Checks for unique ID and validates numerical properties (coordinates, data frequency, etc.).
    • Moves the gage on the map if X/Y is changed.
  2. ValidateSubcatch

    • Checks for unique subcatchment ID.
    • Validates area, outlet node/subcatchment name, coordinate changes, and infiltration parameters.
  3. ValidateNode

    • Covers Junctions, Outfalls, Dividers, Storage nodes.
    • Ensures unique ID, verifies numeric properties, and moves the node on the map if X/Y changed.
  4. ValidateLink

    • Covers Conduits, Pumps, Orifices, Weirs, Outlets.
    • Ensures unique link ID, valid start and end nodes, and numeric property checks (e.g., zero lengths or offsets disallowed for some properties).
  5. ValidateLabel

    • For a map label: checks text changes, new anchor node references, and moves the label if X/Y changes.

2.3 Data Checking Helpers

  1. ValidateData

    • A generic function used to see if a property’s value is non-blank or nonzero, depending on rules for that property (e.g., area must be non-blank, roughness can’t be zero).
  2. ReplaceID

    • If a new name for an object is valid, updates that name in the project’s database and on the visual map.

2.4 Error Handling

  • Uses Errmsg as a global string to hold the latest error message if a check fails.
  • Typical error messages:
    • MSG_DUPLICATE_ID: “ID name is blank or already in use.”
    • MSG_NO_DATA: “This data field cannot be blank.”
    • MSG_ZERO_VALUE: “This property cannot be 0.”

2.5 Map Updates

  • On successful coordinate changes (X or Y), calls MapForm.MoveGage, MapForm.MoveSubcatch, MapForm.MoveNode, or MapForm methods to visually redraw objects.

  • On renaming an object, calls ReplaceID to:

    • Update the project’s internal list,
    • Adjust references to that object’s old name,
    • Refresh the map display if needed.

3. Typical Usage Flow

  1. User edits a property (ID, coordinate, or numeric setting) in the Property Editor.
  2. The editor calls ValidateEditor with that property’s index and the new value.
  3. ValidateEditor identifies the object type from a global variable (EditorObject) and delegates to the appropriate routine:
    • ValidateRaingage, ValidateSubcatch, ValidateNode, ValidateLink, or ValidateLabel.
  4. The specialized routine checks the input:
    • If invalid, sets Errmsg, returns False, and no changes are made.
    • If valid, updates the project data structure, calls map redraw if needed, and returns True.
  5. If False, an error dialog is shown with the stored Errmsg.

4. Summary

Uvalidate.pas is dedicated to checking and enforcing correctness of edited SWMM object properties:

  • Ensuring unique or non-empty IDs,
  • Preventing invalid references (like a link’s node = itself),
  • Maintaining numeric validity and constraints (e.g., area > 0),
  • Redrawing the map whenever property changes affect the visual layout.

This module guarantees data consistency within SWMM’s GUI, so that changes made via the Property Editor do not compromise the project’s internal model data.

Banach-Tarski paradox and SWMM5 modeling.

Banach-Tarski paradox and SWMM5 modeling.  Let's elaborate on how the principles underlying Banach-Tarski could inspire practical hydrau...