Contribute
Interested in making ghostwriter even better? Please read the sections below to see how you can contribute.
Bugs Reports
Found a bug? Please report it on the GitHub issue tracker here. Please be sure to fill out all answers to the questions in the bug report template.
Warning: Failing to provide the information required in the bug report template will result in the bug report being automatically closed.
New Features and Bug Fixes
Do you know how to code? Follow these steps:
- Submit an issue for your feature or bug on the GitHub issue tracker here.
Note: This step is necessary to ensure that the new feature meets the project goals or that the bug isn't really a feature. You will also want to coordinate what areas of code you will be updating to avoid merge conflicts in case someone else is working on that same area of code as well. - After discussion for your new issue, code your feature or bug fix. Please follow the KDE Frameworks coding style guide.
- Submit a pull request against the master branch with your code updates.
Important: Please squash your commits in git before submitting the pull request! - Wait for a brief code review and at least two other volunteers to test your feature or bug fix.
- Make updates to your pull request as you receive feedback.
- Once your pull request is approved by at least two other volunteer testers, your pull request will be merged.
Code Reviews
Do you know how to code and have an eye for detail? Volunteer to peer review new pull requests!
- Look for a new pull request, and add a comment that you are volunteering to code review it.
- Submit code review comments.
- Wait for updates to the pull request (if needed).
- Continue providing feedback until you are confident the code is sound.
- Leave a comment with your approval of the pull request.
- Once at least two volunteer testers submit their approval, the pull request will be merged.
Here are some tips of what to look for in code reviews:
-
Does the submitted code follow the KDE Frameworks coding style guide?
-
Is the code readable, with comments explaining any non-obvious lines?
-
Is the code "pessimistic"? In other words, does it check for invalid values before using them and handle possible error conditions?
-
Are multiple comparisons or statements wrapped in parentheses within
if
statements to prevent accidents with order of operations? Examples:// Wrong if (a == b || c > d); // Correct if ((a == b) || (c > d));
-
Are literals on the left side of the
==
operator to prevent a typo with the=
operator from escaping the compiler's notice? Examples:// Wrong if (variable == 1); // Reason: What if there's a typo? // The compiler will not catch it! if (variable = 1); // Oops! // Correct if (1 == variable); // Reason: This time the compiler will catch // the typo. if (1 = variable); // Oops!
Testing
Volunteer to review code and test new features and bug fixes! Follow these steps:
- Look for a new pull request, and add a comment that you are volunteering to test it.
- Build the pull request on your platform.
- Test the feature/bug fix and try to break it!
- Provide feedback on test results in the pull request.
- Wait for updates to the pull request (if needed).
- Continue testing and providing feedback until you are confident the code is working.
- Leave a comment with your approval of the pull request.
- Once at least on other volunteer tester submits their approval, the pull request will be merged.
Translations
With Qt Linguist, you can translate ghostwriter into other languages, or update an existing translation file. The translations/
directory within the source code repository contains all the .ts
files you need to get started.
Wiki Documentation
Found a workaround for a common issue? Have any useful tips? Please document your insights on the project's wiki.
Tech Support
Knowledgeable about Linux or building for MacOS? Know how to fix that one issue others keep running into? Your answering user questions and troubleshooting in the GitHub issue tracker would be much appreciated!
Automated Builds
The ghostwriter project uses continuous integration for its Windows and Linux builds to provide regular releases. Sadly, this capability has not been implemented for MacOS.
If you are familiar with MacOS, please consider creating automated builds. These builds will ideally provide an installer for the application.
Also, the current Windows build does not provide an installer (setup.exe
or .msi
). If you are familiar with making Windows installers for Qt apps in AppVeyor, please consider contributing to the project's appveyor.yml file.