Thank you for your interest in contributing to Organic Maps (OM)!
There are things to do for everyone:
- For translators
- For UI/UX and graphic designers
- For developers
- Day-to-day activities like user support, testing, issue management, community relations, etc.
- Submitting your work
If you'd like to help in any other way or if there are any related questions - please contact us.
Submit an issue and describe your feature idea or report a bug. Please check if there are no similar issues already submitted by someone else.
When reporting a bug please provide as much information as possible: OS and application versions, list of actions leading to a bug, a log file produced by the app.
When using Organic Maps app on a device, use the built-in "Report a bug" option: on Android it creates a new e-mail with a log file attached. Your issue will be processed much faster if you send it to bugs@organicmaps.app. Enabling logs in Organic Maps settings on Android before sending the bug report also helps us a lot with debugging.
If your idea is very broad or raw then instead of a specific feature request consider starting a discussion thread.
OM is available in 35 languages already, but some of them are incomplete and existing translations need regular updates as the app evolves. See translations instructions for details.
Organic Maps has a strong focus on easy to use UI and smooth user experience. Feel free to join UI/UX discussions in relevant issues. Mockups are very welcome! Check some existing designs.
If you're into graphic design then OM needs good, clear and free-to-use icons for hundreds of map features / POIs. Check OM's graphic resources and design guidelines and existing requests for icons. Post your icons onto relevant issues or take a next step and integrate them yourself.
Check the map styling instructions and work on adding new map features and other open styles requests.
Please follow instructions in INSTALL.md to set up your development environment. You will find a list of issues for new contributors here to help you get started with simple tasks. If you want to focus on the most important issues, please check this label or our Milestones.
We do not assign issues to first-time contributors. Any such request notifies our contributors and the development team, and creates unnecessary noise that distracts us from the work. Just make a PR - and it will be reviewed.
Sometimes it's better to discuss and confirm your vision of the fix or implementation before working on an issue. Our main focus is on simplicity and convenience for everyone, not only for geeks.
Please learn how to use git rebase
(or rebase via any git tool with a graphical interface, e.g. Fork for Mac is quite good) to amend your commits in the PR and maintain a clean logical commit history for your changes/branches.
While we strive to help onboard new developers we don't have enough time to guide everyone step-by-step and explain in detail how everything works (in many cases we have to study the code ourselves). You'll need to be largely self-sufficient, expect to read a lot of code and documentation.
- Pull Request Guide.
- How to write a commit message.
- Directories structure
- C++ Style Guide.
- Java Style Guide.
- Objective-C Style Guide.
...and more in the docs folder of the repository.
Please help us:
- processing users questions and feedback in chats, app stores, email and social media and creating follow-up issues or updating existing ones
- reproducing and triaging reported bugs
- testing upcoming features and bug fixes for Android, iOS and desktop versions
- keeping github issues in order (check for duplicates, organize, assign labels, link related issues, etc.)
- composing nice user-centric release notes and news items
- etc.
All contributions to Organic Maps repositories should be submitted via Github pull requests and signed-off with the Developers Certificate of Origin.
Each pull request is reviewed by OM maintainers to ensure its quality. Sometimes the review process even for smallest commits can be very thorough.
When contributing to this project, you must agree that you have authored 100% of the content, that you have the necessary rights to the content and that the content you contribute may be provided under the project license.
To contribute you must assure that you have read and are following the rules stated in the Developers Certificate of Origin (DCO). We have borrowed this procedure from the Linux kernel project to improve tracking of who did what, and for legal reasons.
To sign-off a patch, just add a line in the commit message saying:
Signed-off-by: Some Developer <somedev@example.com>
Git has a flag that can sign a commit for you. An example using it is:
git commit -s -m 'An example commit message'
Use your real name or on some rare cases a company email address, but we disallow pseudonyms or anonymous contributions.
The OM community abides by the CNCF code of conduct.