-
Notifications
You must be signed in to change notification settings - Fork 1
Home
NOTICE (4/25/2021): hipas/gridlabd
is currently a fork of slacgismo/gridlabd
As of 11/13/19, this wiki is only for project administration and developers. The user manuals for HiPAS GridLAB-D are deployed at HiPAS GridLAB-D Documentation. This documentation uses the SLAC-Gismo Docs-Browser, which allows developers to manage the documentation of each branch separately.
Developer manuals, troubleshooting guides, and module guides are version specific and compiled when the application is build on a target host. You must start a web server instance on that target host to view those documents, e.g., using python3 -m http.server
.
If you are looking for documentation for the PNNL versions of GridLAB-D, please use the ShoutWiki GridLAB-D Documentation.
- The
master
branch is the default branch.
-
The
develop
branch is used for active development targeted for the next merge intomaster
. Each update ofmaster
will receive the nextpatch
number in in the currentminor
sequence, e.g.,4.2.n -> 4.2.(n+1)
-
The
minor
branch is used for pull requests that are to be deployed to master with the next minor update, e.g.,4.n.x -> 4.(n+1)/.0
. Minor updates are intended for significant new capabilities that are otherwise fully compatible with the existing version. Removal of deprecated capabilities is not permitted in a minor update. -
The
major
branch is used for pull requests that are to be deployed to master with the next major update, e.g.,n.x.y -> (n+1).0.0
. Major updates are intended for significant new capabilities that are incompatible with the existing version. Removal of deprecated capabilities is permitted in a major update provide the capability has been deprecated for at least one minor update.
- If you would like to make contributions to hipas/gridlabd, please fork this repository.
Please be sure to create your feature branches from the develop
branch. When ready to submit your code to the hipas/gridlabd repository, create a pull request from your feature branch to hipas/develop. We will not approve pull requests directed to the master
branch. Pull Requests must include a list of code, documentation, and validation changes.
-
Code changes should be delivered using the current Coding guide.
-
Documentation is maintained in the
docs
folder of the same branch in which the code changes are introduced. Documentation changes will be reviewed at the same time that code changes are reviewed after you submit your Draft pull request for review. See Documentation guide for details on writing docs for HiPAS GridLAB-D. -
Validation tests are delivered in
autotest
folders throughout the source tree. See Validation guide for details. -
Pull Requests to
develop
may be retargeted forminor
ormajor
by the project managers.
-
You may view the Pull Requests to determine the status of a branch. All branches are automatically validated using GitHub Actions and you may monitor validation progress at the HiPAS GitHub Actions page or by viewing the status of the Pull Request. You may submit your Pull Request for review when it passes validation.
-
The
master
anddevelop
branches are automatically built on Docker Hub. The resulting containers are stored in the GridLAB-D docker repositories. See Docker images for a list of the latest images for each major release. -
Only the project administrators may tag master commits. These will be automatically tagged in Docker Hub at that time. Docker images are named after major power plants.
For additional details on workflows, see Workflows.
To build the master
branch and any branch from master
, you must first manually prepare your system (which is host dependent). For a rough guide see the build-aux/setup*.sh
files of the develop
branch.
If you have never installed HiPAS GridLAB-D on your system before, you will need to run the install script to prepare your system for development:
bash$ git clone http://source.gridlabd.us/ gridlabd
bash$ cd gridlabd
bash$ ./install.sh
This might take a few minutes. At this time, only a few platforms are supported, e.g., Mac OS X (Darwin 17 and 18), Linux (Centos 7 and 8, Ubuntu 16 and 18, and Amazon EC2). If you are using a different platform, please use the install script of the system that most closely resembles yours. The install scripts are located in the build-aux
folder and use the naming convention setup-<type>-<version>.sh
. For developers, these scripts are fairly self-explanatory.
The regular rebuild process is usually the following:
bash$ make reconfigure && make -j30 system
bash$ gridlabd --version=install
<check the version>
bash$ gridlabd --validate
<check that it works ok>
To download the development branch, use the following command:
bash$ git clone http://source.gridlabd.us/ -b develop gridlabd
bash$ cd gridlabd
If you plan to make changes to the code, fork the hipas/gridlabd repository to your GitHub account. See GitHub documetation on how to fork a repository. You will then need to clone your repo to access the code locally, and then create your feature branch from the develop branch.
bash$ git clone https://github.com/<YOUR-GITHUB-ACCOUNT>/gridlabd
bash$ git checkout -b develop-new-branch develop
after which you can safely make your changes.
To rebuild and install your code after making local changes, you should run the following command:
bash$ make reconfigure && make -j30 system
again, and running validation
bash$ gridlabd --validate
If you would like to use the system debugger, you can rebuild with debugging symbols enabled using the following command:
bash$ make reconfigure-debug && make -j30 system
Then you can use the debugger subcommand to load gridlabd in the system debugger, e.g.,
bash$ gridlabd [lldb|gdb] ...
where lldb
is used for macOS system and gdb
for Linux systems.
The develop
version can manage multiple versions of HiPAS GridLAB-D on the same host running concurrently. For more information use the command
bash$ gridlabd version help