From 8c78caba8d5661c5d7669c8189114a738a634127 Mon Sep 17 00:00:00 2001 From: misi9170 <39596329+misi9170@users.noreply.github.com> Date: Wed, 20 Dec 2023 16:01:10 -0500 Subject: [PATCH] Update installation instructions for developers (#21) * Incomplete * Develop instructions included; reordering. * Ruff bugfix on importing find_packages. --- README.md | 23 +------------------- docs/_toc.yml | 3 ++- docs/code_development.md | 23 ++++++++++++++++++++ docs/install_instructions.md | 42 +++++++++++++++++++++++++++++++++++- setup.py | 4 ++-- 5 files changed, 69 insertions(+), 26 deletions(-) create mode 100644 docs/code_development.md diff --git a/README.md b/README.md index b967f867..c3dbce90 100644 --- a/README.md +++ b/README.md @@ -20,25 +20,4 @@ WHOC controllers will also call on design tools such as [FLORIS](https://github.com/NREL/floris). Documentation for WHOC can be found on -[nrel.github.io](https://nrel.github.io/wind-hybrid-open-controller/intro.html) - -## Code development -To contribute to WHOC, please consider forking the main github repository, -with the [main repo](https://github.com/NREL/wind-hybrid-open-controller) as an -upstream remote. To submit a new feature or bug fix, create a new branch -in your fork and submit a pull request back to the `develop` branch in the -main repo. The pull request will be reviewed by other WHOC developers and -merged (using "squash and merge") into the `develop` branch. Periodically, -the `develop` branch will be merged into the `main` branch and a version -number will be assigned. - -Unless an existing controller or interface exist to suit your needs, most -users will need to generate: -- A new interface class inheriting from `InterfaceBase` -- A new controller class, implementing the desired control algorithm and -inheriting from `ControllerBase` - -Additionally, if you'd like to contribute to this base repository, please -include in your pull request: -- Unit tests for the implemented controller -- Possibly unit tests for the implemented interface, if needed \ No newline at end of file +[nrel.github.io](https://nrel.github.io/wind-hybrid-open-controller/intro.html) \ No newline at end of file diff --git a/docs/_toc.yml b/docs/_toc.yml index 9206f70e..66faf4a1 100644 --- a/docs/_toc.yml +++ b/docs/_toc.yml @@ -4,9 +4,10 @@ format: jb-book root: intro parts: - - caption: Installation + - caption: General information chapters: - file: install_instructions + - file: code_development - caption: Controllers chapters: - file: controllers diff --git a/docs/code_development.md b/docs/code_development.md new file mode 100644 index 00000000..124de22a --- /dev/null +++ b/docs/code_development.md @@ -0,0 +1,23 @@ +# Code development +To contribute to WHOC, please consider forking the main github repository, +with the [NREL repo](https://github.com/NREL/wind-hybrid-open-controller) as an +upstream remote. See the [Installation instructions](install_instructions) +for details about how to set up your repository as a developer. + +To submit a new feature or bug fix, create a new branch +in your fork and submit a pull request back to the `develop` branch in the +main repo. The pull request will be reviewed by other WHOC maintainers and +merged (using "squash and merge") into the `develop` branch. Periodically, +the `develop` branch will be merged into the `main` branch and a version +number will be assigned. + +Unless an existing controller or interface exist to suit your needs, most +users will need to generate: +- A new interface class inheriting from `InterfaceBase` +- A new controller class, implementing the desired control algorithm and +inheriting from `ControllerBase` + +Additionally, if you'd like to contribute to this base repository, please +include in your pull request: +- Unit tests for the implemented controller +- Possibly unit tests for the implemented interface, if needed \ No newline at end of file diff --git a/docs/install_instructions.md b/docs/install_instructions.md index d1c4e61d..42f125d2 100644 --- a/docs/install_instructions.md +++ b/docs/install_instructions.md @@ -1,6 +1,46 @@ # Installation +WHOC is _not_ designed to be used as a stand-alone package. Most likely, +you'll want to add WHOC to an existing conda environment that contains your +simulation testbed, such as [Hercules](https://github.com/NREL/hercules). +For example, see the [Hercules installation instuctions](\ +https://nrel.github.io/hercules/install_instructions.html) for how to set up +an appropriate conda environment. + +## General users + +If you intend to use WHOC, but not contribute, the following lines should +be sufficient to install WHOC (presumably, after activating your conda +environment): + ``` git clone https://github.com/NREL/wind-hybrid-open-controller -pip install -e wind-hybrid-open-controller +pip install wind-hybrid-open-controller/ ``` + +## Developers + +If you intend to contribute to WHOC, we request that your fork the WHOC +repository on github. You can then install WHOC (again, assuming you have +already activated your conda environment) according to: + +``` +git clone https://github.com/your-github-id/wind-hybrid-open-controller +pip install -e wind-hybrid-open-controller/ +``` +To contribute back to the base repository +https://github.com/NREL/wind-hybrid-open-controller, please do the following: +- Create a branch from the base repository's `develop` branch on your fork +containing your code changes (e.g. `your-github-id:feature/your-new-feature`) +- Open a pull request into the base repository's `NREL:develop` branch, and provide +a description of the new/updated capabilities +- The maintainers will review your pull request and provide feedback before +possibly merging the pull request (via the "squash and merge" method) into the +`NREL:develop` branch +- At the next release, `NREL:develop` will be merged into `NREL:main`, and your changes +contributions will appear there + +For more information on what your pull request should contain, see +[Code development](code_development.md). + + diff --git a/setup.py b/setup.py index 3ccbaa78..2480061e 100644 --- a/setup.py +++ b/setup.py @@ -23,7 +23,7 @@ import os from pathlib import Path -from setuptools import find_packages, setup +from setuptools import setup # Package meta-data. NAME = "whoc" @@ -101,7 +101,7 @@ python_requires=REQUIRES_PYTHON, url=URL, # package_dir={"": "hercules"}, - packages=["whoc"], #find_packages(exclude=["tests", "*.tests", "*.tests.*", "tests.*"]), + packages=["whoc"], # find_packages(exclude=["tests", "*.tests", "*.tests.*", "tests.*"]), # If your package is a single module, use this instead of 'packages': # py_modules=['mypackage'], # entry_points={