Thank you for considering contributing to PH-Tools. We welcome contributions to all our projects on Github and from anyone, even if you are new to open source we will be happy to help you to get started. Most of the PH-Tools developers started learning programming through developing for PH-Tools.
Feel free to submit issues and enhancement requests to each repository.
Please refer to each project's contributing file for style guidelines. In general, we follow the "fork-and-pull" Git workflow.
- Fork the repo on GitHub
- Clone the project to your own machine
- Commit changes to your own branch
- Push your work back up to your fork
- Submit a Pull request so that we can review your changes
If you don't know what Git is, please read the section for new users.
NOTES:
- Be sure to open an issue or contact the current developers and let them know about your desire to work on the project. This will ensure that no one else is working on the same problem and also provides the opportunity for us to help you to get started with development.
- Be sure to merge the latest from "upstream" before making a pull request!
- An acceptable Pull request should not be more than 200 lines of changes otherwise it will be very hard for us to review the code.
- Read the contributing.md of the project beforehand to ensure your pull request meets the requirement of the project.
For Python projects see PH-Tools Python style guide.
Please also take a look at the zen of Python by Tim Peters. To read the Zen of Python, please write
import this
in your Python shell and run it.
All PH-Tools repositories follow a convention of assuming SI units by default. Accordingly, all properties on objects and all inputs to functions within a repository are expected to be in SI.
For developers needing to convert the inputs or outputs of PH-Tools repositories to other unit systems
for front-end interfaces, ladybug-core includes a dataype module that is capable of converting between many types of units.
Furthermore, all geometry objects of ladybug-geometry
possess scale
methods that can be used to scale the geometry to/from meters.
For angular inputs and outputs, all PH-Tools repositories use degrees (as opposed to radians) with the only excpetion being ladybug-geometry, which uses radians for faster trigonometric operations and better compatability with CAD interfaces.
PH-Tools repositories are open source under the GNU General Public License v3.0. unless indicated otherwise. For more information about the license see here.
The first thing to do is to register a user name with GitHub.
You will need to supply a username and email address and to create a password.
After you have registered you can go to your GitHub settings. Here you can add a photo and update your bio. It's a good thing to add at least some data - especially a photo and a location. These help your friends remember and know that it is really you.
If you are new and looking for some way to contribute a good place to start is to look at the issues tagged good first issue.
Please note that all participants of this project are expected to follow our Code of Conduct. We enjoy the development of PH-Tools and want to make it enjoyable for others. We care about good code but value our community and the people over the code and development. By participating in PH-Tools project you agree to abide by its terms. See our code of conduct.