Skip to content
Sandro edited this page Sep 14, 2016 · 8 revisions

First of all, thank you for helping! :) This page attempts to set some guidelines on how to contribute to the code base.

We will base our development guidelines on GitFlow. If you want to work on one of the issues, assign yourself to it or at least leave a comment that you are working on it and how.
If you have an idea for a new feature, make an issue first, assign yourself to it, then start working.
Please make sure you have read the Developer's Certificate of Origin, further down on this page!

  1. Fork the main lookup repository on GitHub.
  2. Clone this fork onto your machine (git clone <your_repo_url_on_github>).
  3. From the latest revision of the master branch, make a new feature branch from the latest revision. Name the branch something meaningful, for example fix-RestApiParams (git checkout master -b fix-RestApiParams).
  4. Make changes and commit them to this branch.
  • Please commit regularly in small batches of things "that go together" (for example, changing a constructor and all the instance creating calls). Putting a huge batch of changes in one commit is bad for code reviews.
  • In the commit messages, summarize the commit in the first line using not more than 70 characters. Leave one line blank and describe the details in the following lines, preferably in bullet points, like in 7776e31....
  1. When you are done with a bugfix or feature, rebase your branch onto lookup/master (git pull --rebase origin master, where origin is the name of the official lookup remote). Resolve possible conflicts and commit.
  2. Push your branch to GitHub (git push upstream fix-RestApiParams), where upstream is the name of your remote.
  3. Send a pull request from your feature branch into lookup/master via GitHub.
  • In the description (not in the title), mention the associated issue(s) (for example, "Fixes #123 by ..." for issue number 123, the # sign allows you to point to specific issues in lookup).
  • Your changes will be reviewed and discussed on GitHub.
  • In addition, Travis-CI will test if the merged version passes the build.
  • If there are further changes you need to make, because Travis said the build fails or because somebody caught something you overlooked, go back to item 4. Stay on the same branch (if it is still related to the same issue). GitHub will add the new commits to the same pull request.
  • Finally, when everything is fine, your changes will be merged into lookup/master

Please keep in mind:

More tips:

Important: Developer's Certificate of Origin

By sending a pull request to the main lookup repository on GitHub, you implicitly accept the following:

    Developer's Certificate of Origin 1.1

    By making a contribution to this project, I certify that:

    (a) The contribution was created in whole or in part by me and I
        have the right to submit it under the open source license
        indicated in the file; or

    (b) The contribution is based upon previous work that, to the best
        of my knowledge, is covered under an appropriate open source
        license and I have the right under that license to submit that
        work with modifications, whether created in whole or in part
        by me, under the same open source license (unless I am
        permitted to submit under a different license), as indicated
        in the file; or

    (c) The contribution was provided directly to me by some other
        person who certified (a), (b) or (c) and I have not modified
        it.

    (d) I understand and agree that this project and the contribution
        are public and that a record of the contribution (including all
        personal information I submit with it, including my sign-off) is
        maintained indefinitely and may be redistributed consistent with
        this project or the open source license(s) involved.

(source: http://elinux.org/Developer_Certificate_Of_Origin)

Other ways to contribute

If you think you can contribute in any other way, please send us an e-mail at [email protected]. You could

  • contribute a new language version
  • contribute evaluation data
  • contribute infrastructure
  • donate

Disclaimer: this page is a copy of DBpedia Spotlight contributing page. Thanks that team to provide it to us.

Clone this wiki locally