Below is an extended summary of the code, highlighting its purpose, key functionalities, and structure:
Overview and Purpose
The script is a standard Python setup.py
installer for the pyswmm
library, which serves as a Python wrapper for the SWMM5 (Storm Water Management Model) API. It leverages the setuptools
library to package and distribute pyswmm
by defining metadata, dependencies, and additional configurations. This allows developers and users to install the library easily using tools like pip
or other Python package managers.
Key Functions and Features
-
Version Extraction (
get_version
)- The
get_version
function dynamically reads the version frompyswmm/__init__.py
. - It uses the
ast.literal_eval
function to parse theVERSION_INFO
tuple found in the file. - This approach ensures that the package version stays consistent and centralized, avoiding manual, error-prone duplication of version strings.
- The
-
Long Description Retrieval (
get_description
)- The
get_description
function reads theREADME.md
file to fetch the long description of the package. - By specifying
long_description_content_type='text/markdown'
, it tells PyPI and other package repositories to interpret the long description as Markdown for a more visually appealing presentation.
- The
-
Dependencies and Requirements
- The
REQUIREMENTS
list includes packages (swmm-toolkit
,julian
,aenum
, andpackaging
) necessary for runningpyswmm
. - The
extras_require
dictionary defines additional dependencies pinned to specific SWMM toolkit versions. Each key corresponds to a SWMM5 version, while its value references the required toolkit version. This makes it straightforward for users to install a configuration matching their preferred SWMM version.
- The
-
Metadata and Package Information
- The
setup
function includes a variety of metadata such as:- Name (
pyswmm
) - Description (“Python Wrapper for SWMM5 API”)
- URL (“https://www.pyswmm.org”)
- Author (Bryant E. McDonnell)
- Licensing information (“BSD2 License”)
- Key topics and keywords (hydraulic and hydrology modeling, SWMM, etc.)
- Name (
- This metadata ensures proper categorization and discoverability on package repositories.
- The
-
Supported Python Versions
- The
classifiers
list explicitly states support for Python versions 3.7 through 3.12. - It also designates the package’s maturity as “Development Status :: 5 - Production/Stable,” indicating it is ready for widespread use.
- The
-
Included Files and Data
- By specifying
packages=find_packages(exclude=['contrib', 'docs'])
, the script automatically includes all sub-packages within thepyswmm
directory (except directories likecontrib
anddocs
). - The
package_data
dictionary includes additional files such asLICENSE.txt
,AUTHORS
, and test inputs (.inp
files), ensuring they are packaged alongside the code.
- By specifying
-
Installation Command
- After defining all setup parameters, the script culminates in a call to the
setup
function, which orchestrates the build, distribution, and installation process.
- After defining all setup parameters, the script culminates in a call to the
Conclusion
Overall, this setup.py
script is a classic example of Python packaging. It consolidates version management, documentation, and dependency handling into a single file, ensuring that pyswmm
can be seamlessly installed and that different SWMM versions are supported through an organized extras_require
mechanism. This well-structured setup process enables developers and practitioners alike to integrate pyswmm
into their hydraulic and hydrological modeling workflows with minimal friction.