Open Source Submission Guidelines - nasa/gunns GitHub Wiki

GUNNS is an open source project with NASA reserving authority over the central repository. We encourage the user community to share their improvements to this code base with us and each other so we can all benefit from each other’s efforts.

Requirements of new feature code

We try to limit what’s in the GUNNS repository to only generic models that can be reused across multiple projects. This keeps the GUNNS repository code base small and maintainable while maximizing its value for everyone.

Typically users will extend GUNNS for their own projects by writing new link or spotter classes to do specific things they need. When you develop these new classes, consider whether you want to share them with the community. If you want to share and your code satisfies the requirements listed below, then we welcome you to add it to the GUNNS repository in the appropriate place under the gunns/aspects/ folder, and submit it with a merge request.

New code should:

  • Conform to the software license,
  • Add generic & reusable value for other users,
  • Include unit tests in our existing CppUnit test framework with 100% line coverage, zero Valgrind errors, and zero Address Sanitizer (ASan) errors,
  • Contain no sensitive or personally identifiable information.

Requirements of bug fixes

We welcome fixes to the existing code case. Submissions are encouraged to be unit tested, but not required. We’ll try to add tests for it when we can. Bug fix code should:

  • Conform to the software license,
  • Contain no sensitive or personally identifiable information.

How to submit changes

For non-core GUNNS developers, such as public contributors: after satisfying the requirements above, submit a pull request here in the GUNNS GitHub to merge to master. Please follow these instructions:

  • The pull request should be associated with an issue in the issue tracker, and you are welcome to create a new issue for your updates if there isn’t already one.
  • The commits should reference the issue number in the commit message. This creates the association between the pull request and the issue.
    For example, our convention is like:
    (#115) add float limitRange function, update models

We will review and accept or reject the changes, and take it from there. We may ask to you resubmit your updates with changes before accepting them. We will usually require the CI jobs to pass before merging to master.

Repository push access for core developers

Push access to the repository is restricted to the GUNNS team, and membership is controlled by NASA. For GUNNS core developers, submit a NASA NAMS request for the “AGCY NASA Github Collaborator Form” asset, specifying you need to be able to push to the GUNNS repository and be added to the GUNNS team.

⚠️ **GitHub.com Fallback** ⚠️