CDSS / TSTool (Developer)
This developer documentation explains how to build, enhance, and maintain Colorado's Decision Support Systems (CDSS) TSTool software. TSTool software automates processing time series, data tables, and other data. See also the TSTool User Documentation.
- How to Use this Documentation
- Acknowledgements
- Colorado's Decision Support Systems
- About the Open Water Foundation
- License
- Source Repository on GitHub
- Release Notes - this documentation has been updated for TSTool version 14.7.0
How to Use this Documentation
This website is a companion to the TSTool source code and provides guidance for software developers that modify and support TSTool.
The documentation is organized with the first sections focusing on setup for a new developer and common development tasks. The reference sections at the end provide information that may be of use but are typically not used day to day. Use the search feature of this website to find specific information.
As of version 14.0.0, the TSTool development environment creates a 64-bit Java TSTool runtime for use on Windows and Linux computers.
Older versions focused on 32-bit Java runtime.
Icons for Cygwin  , Linux
, Linux  , and Windows
, and Windows  are included to help indicate documentation
specific to an operating system.
are included to help indicate documentation
specific to an operating system.
- New Developer Setup - new TSTool software developers should start here
- Development Tasks - describes common development tasks - refer to this after new development environment is configured
- REFERENCE: Software Design - provides details about the software code design
- REFERENCE: Deployed Environment - describes the deployed environment after software is installed
- REFERENCE: Development Environment - describes development environment software installation
- REFERENCE: Initial Project Setup - describes initial project setup and file structure
Use the navigation menu provided on the left side of the page to navigate the documentation sections within the full document. Use the navigation menu provided on the right side of the page to navigate the documentation sections with a page. The navigation menus may not be displayed if the web browser window is narrow or if viewing on a mobile device, in which case look for a menu icon to access the menus. Use the search feature to find documentation matching the search words.
Acknowledgements
TSTool has been developed by the Open Water Foundation (OWF) with significant funding provided by the Colorado Water Conservation Board (CWCB) in coordination with the Division of Water Resources (DWR), as part of Colorado’s Decision Support Systems (CDSS).
Additional enhancements to TSTool have been funded by various organizations including:
- Open Water Foundation
- US Bureau of Reclamation
- Tennessee Valley Authority
- and others
TSTool software developers are encouraged to provide feedback using the GitHub Issues page for the TSTool main application repository, or the issues for the appropriate repositories.
Feedback specific to CDSS functionality (e.g., HydroBase, StateMod, StateModB, StateCU input) can be provided using the CDSS email address.
Software Components
The following components are used in TSTool and require or request attribution:
- Material Theme icons - these icons are used in documentation
Colorado's Decision Support Systems
Colorado's Decision Support Systems (CDSS, https://cdss.colorado.gov/) has been developed to answer important questions about Colorado's water resources. CDSS efforts are led by the Colorado Water Conservation Board (CWCB) and Colorado Division of Water Resources (DWR).
 
CDSS has been under development since 1994, with progress occurring via a series of basin decision support systems (DSS), starting with the Colorado River DSS (CRDSS). Other focused DSS were also developed, such as the CWCB's Instream Flow DSS. Each DSS resulted in enhancements to the core CDSS tools, which are envisioned as a general platform of data and tools to help with water supply planning.
The TSTool software was originally developed in CDSS to process time series and other data from Colorado's HydroBase database into into water resources model data files. Since the initial development, TSTool has been significantly enhanced to use additional data sources, add commands with new functionality, and add new functionality to facilitate interactive and automated data processing.
In late 2016, the Open Water Foundation began the effort to move TSTool and other CDSS software to open source licensing and establish open source software projects, referred to as "OpenCDSS". The OpenCDSS project has resulted in a significant evolution in how CDSS software development occurs, such as implementing version control with Git/GitHub and modernizing the development environment and documentation. See the OpenCDSS Website for more information.
About the Open Water Foundation
The Open Water Foundation is a nonprofit social enterprise that focuses on developing and supporting open source software for water resources, so that organizations can make better decisions about water. OWF also works to advance open data tools and implementation. OWF staff have been the primary TSTool developers on State of Colorado and other projects.
License
This TSTool documentation is licensed using the Creative Commons Attribution International 4.0 (CC BY 4.0) license.
The TSTool software is licensed using the GPL 3 license (see the TSTool software repository).
Source Repository on GitHub
The source files for this documentation are maintained in a GitHub repository: cdss-app-tstool-doc-dev.
This developer documentation is currently maintained in a repository that is separate from TSTool code in order to avoid confusion with the legacy documentation and to facilitate updates.
Release Notes
See the TSTool release notes section of the TSTool user documentation for information about TSTool software changes.