If you are new to the project, or looking for some way to help take a look at:
- label:"good first issue"
- label:component/documentation
- label:closed/needs-new-author
- label:Abandoned
- For anything other than minor bug fixes, please comment on an existing issue or create a new issue providing details about your proposed change.
- Unrelated changes should be addressed in separate issues.
- Include information about use cases, design, user experience, etc.
- This allows us to discuss these aspects and any other concerns that might arise, thus potentially avoiding a great deal of wasted time.
- It is recommended to wait for acceptance of your proposal before you start coding.
- A
triaged
label is an indicator that an issue is ready for a fix. - Please understand that we very likely will not accept changes that are not discussed first.
- Consider starting a GitHub discussion or mailing list topic to see if there is interest.
- A
- A minor/trivial change which definitely wouldn't require design, user experience or implementation discussion, you can just create a pull request rather than using an issue first.
- e.g. a fix for a typo/obvious coding error or a simple synthesizer/braille display driver
- This should be fairly rare.
- If in doubt, use an issue first. Use this issue to discuss the alternatives you have considered in regards to implementation, design, and user experience. Then give people time to offer feedback.
- Issues with translations should be reported to the NVDA Translators list.
- Setup your development environment.
- Ensure the issue you plan to fix is triaged
- Create a branch for the contribution, to be used for a pull request.
- Pull requests should be based on the latest commit in the official master branch. This helps reduce the chance of merge conflicts.
- If you are adding a feature or changing something that will be noticeable to the user, you should update the User Guide accordingly. New commands, drivers, settings, dialogs, etc. must be documented.
- Build NVDA and run from source
- Manually test the change
- Run automated tests
- Run
rununittests
(rununittests.bat
) before you open your Pull Request, and make sure all the unit tests pass. - If possible for your PR, please consider creating a set of unit or system tests to test your changes.
- The lint check ensures your changes comply with our code style expectations. Use
runlint nvaccess/master
(runlint.bat
) - Run
scons checkPot
to ensure translatable strings have comments for the translators
- Run
- Create a change log entry
- Create a Pull Request (PR)
- When you think a contribution is ready, or you would like feedback, open a draft pull request. When you would like a review, mark the PR as "ready for review".
- Please fill out the Pull Request template, including the checklist of considerations. The checklist asks you to confirm that you have thought about each of the items, if any of the items are missing it is helpful to explain elsewhere in the PR why it has been left out.
- Automated checks will be run against your PR. If these fail, please review them. Sometimes system tests fail unexpectedly. If you believe the failure is unrelated, feel free to ignore it unless it is raised by a reviewer.
- All pull requests submitted must have their "Allow edits from maintainers" checkbox ticked. This is the GitHub default for new pull requests.
- A lead developer may specifically request the pull request be made against
beta
orrc
in the case of addressing bugs introduced in the current release cycle.
- Participate in the code review process
- This process requires core NVDA developers to understand the intent of the change, read the code changes, asking questions or suggesting changes. Please participate in this process, answering questions, and discussing the changes.
- Being proactive will really help to speed up the process of code review.
- When the PR is approved it will be merged, and the change will be active in the next alpha build.
- If issues are raised with your PR, it may be marked as a draft. Please mark it as ready for review when you have addressed the review comments.
- Feedback from alpha users
- After a PR is merged, watch for feedback from alpha users / testers. You may have to follow up to address bugs or missed use-cases.
An entry intended to explain changes in NVDA to end users.
Your proposed entry should be added to the changes.t2t
file which is converted to HTML.
Change log entries are not required for changes with no/minor user impact or no developer impact.
Because the changes.t2t
file is prone to conflicts, NV Access will resolve any merge conflicts with the change log entry before merging.
These descriptions should be in the format: "{Description of change}. (#{issue number})"
.
Multiple issue numbers can be included, separated by comma.
If there is no issue number, you can use the PR number.
Optionally, you may also include your GitHub username after the issue numbers: "{Description of change}. (#{issue number}, @{GitHub username})"
.
Our processing will automatically link the issue number to the GitHub page, and your GitHub username to your contributions to NVDA.
For instance:
New features
- Added a command to announce useful thing. (#1234, #4321, @myGitHub)
Changes
- Old command, now also uses new useful command. (#1234)
You may add descriptions for multiple sections. The sections are:
- New features
- Changes
- Bug fixes
- Changes for developers
Please ensure you follow our coding standards document.
Please checkout our technical design overview.