================================ Contributing to Apache Clownfish ================================ MAKE A PLAN: Clownfish is developed by the Apache Lucy community. http://lucy.apache.org/ If you propose to make non-trivial changes to Clownfish, especially changes to the public API, send a note to the Lucy developer's list describing your plans: http://lucy.apache.org/mailing_lists.html GET THE CODE: Clownfish's codebase is available via Git from git-wip-us.apache.org. Start by creating a clone of the repository: git clone https://git-wip-us.apache.org/repos/asf/lucy-clownfish.git There is also a mirror on Github. https://github.com/apache/lucy-clownfish Follow the instructions in INSTALL to set up your local workspace. MAKE CHANGES: Edit the source code as you see fit, then build and run tests. Please bear the following in mind: * All code will eventually need to be portable to multiple operating systems and compilers. (This is a complex requirement and it should not block your contribution.) * All public APIs must be documented. * Code should be formatted according to the style guidelines at . * All unit tests must pass. * New code needs to be accompanied by new unit tests. * Simplicity, both in terms of API and implementation, is highly valued within the Lucy development community; the simpler the contribution, the more quickly it can be reviewed and integrated. OPEN AN ISSUE: Clownfish uses Lucy's issue-tracker/bug-tracker installation, which runs Atlassian JIRA. We generally use the term "issue" rather than "bug" because not every contribution fixes a "bug". https://issues.apache.org/jira/browse/LUCY 1. Create a JIRA account for yourself and sign in. 2. Once you have signed in, the "create new issue" link will appear. Either use it to open a new issue or navigate to an existing one as appropriate. 3. To attach files to an issue, use the menu command 'More Actions > Attach Files'. Attaching a file to an issue causes an email notification to be sent to the lucy-issues list signalling that a patch has arrived. Please be patient but persistent while engaging with the Lucy committers who review and apply such patches. CONTRIBUTE A PATCH: The easiest way to create a patch with Git is to capture the output of `git diff`: git diff > my_changes.patch The resulting patch file can then be attached to a JIRA issue. GITHUB PULL REQUESTS Github users may submit pull requests against our mirror: https://github.com/apache/lucy-clownfish An email notifying the Lucy developers list of your pull request will be triggered automatically.