This project and everyone participating in it is governed by our code of conduct guidelines. By participating, you are expected to uphold this code. Please report unacceptable behavior.
Identify the appropriate repository for the change you are suggesting:
- Use nwb_schema for any changes to the NWB:N format schema, schema language, storage and other NWB:N related documents
- Use PyNWB for any changes regarding the PyNWB API and the corresponding documentation
Ensure the feature or change was not already reported by searching on GitHub under PyNWB Issues and nwh-schema issues , respectively .
If you are unable to find an open issue addressing the problem then open a new issue on the respective repository. Be sure to include:
- brief and descriptive title
- clear description of the problem you are trying to solve*. Describing the use case is often more important than proposing a specific solution. By describing the use case and problem you are trying to solve gives the development team and ultimately the NWB:N community a better understanding for the reasons of changes and enables others to suggest solutions.
- context providing as much relevant information as possible and if available a code sample or an executable test case demonstrating the expected behavior and/or problem.
Be sure to select the appropriate labels (see :ref:`sec-issue-labels`) for your tickets so that they can be processed accordingly.
NWB:N is currently being developed primarily by staff at scientific research institutions and industry, most of which work on many different research projects. Please be patient, if our development team is not able to respond immediately to your issues. In particular issues that belong to later project milestones may not be reviewed or processed until work on that milestone begins.
See the Contributing Patches and Changes
section below for details.
Source code changes that are purely cosmetic in nature and do not add anything substantial to the stability, functionality, or testability will generally not be accepted unless they have been approved beforehand. One of the main reasons is that there are a lot of hidden costs in addition to writing the code itself, and with the limited resources of the project, we need to optimize developer time. E.g,. someone needs to test and review PRs, backporting of bug fixes gets harder, it creates noise and pollutes the git repo and many other cost factors.
Join the NWB:N mailing list for updates or ask questions on our google group.
The https://nwb-users.slack.com slack is currently used mainly for internal discussions between developers, users, and teams.
To contribute to the PyNWB and nwb_schema, you must submit your changes to the dev
branch via a Pull Request.
From your local copy directory, use the following commands.
- First create a new branch to work on
$ git checkout -b <new_branch>
- Make your changes.
- Push your feature branch to origin (i.e. github)
$ git push origin <new_branch>
Once you have tested and finalized your changes, create a pull request targeting
dev
as the base branch:- Ensure the PR description clearly describes the problem and solution.
- Include the relevant issue number if applicable.
- Before submitting, please ensure that the code follows the standard coding style of the repsective repository.
- NOTE: Contributed branches will be removed by the development team after the merge is complete and should, hence, not be used after the pull request is complete.
Labels are used to describe the general scope of an issue, e.g., whether it describes a bug or feature request etc. Please review and select the appropriate labels for the respective Git repository:
Milestones are used to define the scope and general timeline for issues. Please review and select the appropriate milestones for the respective Git repository:
Projects are currently used mainly on the NeurodataWithoutBorders organization level and are only accessible to members of the organization. Projects are used to plan and organize developments across repositories. We currently do not use projects on the individual repository level, although that might change in the future.
- Use the present tense ("Add feature" not "Added feature")
- The first should be short and descriptive.
- Additional details may be included in further paragraphs.
- If a commit fixes an issues, then include "Fix #X" where X is the number of the issue.
- Reference relevant issues and pull requests liberally after the first line.
All documentations is written in reStrcuturedText (RST) using Sphinx.
Coming soon
Coming soon
See the Readme and correspoding licence files for details about the copyright and licence.