Jetty Logo
Version: 9.4.5.v20170502
Contact the core Jetty developers at www.webtide.com

private support for your internal/customer projects ... custom extensions and distributions ... versioned snapshots for indefinite support ... scalability guidance for your apps and Ajax/Comet projects ... development services for sponsored feature development

Contributing Patches

Sign an Eclipse Contributor Agreement (ECA)
Configuring Git
Making the Commit
The Pull Request
Our Policies

We love seeing people contribute patches to the Jetty project and the process is relatively simple. The requirements to commit are modest but very important to the Eclipse Foundation and the intellectual property of the open source project. The following is the general process by which we operate.

Not everything is specifically relevant since we are at GitHub but the crux of things are detailed there. The ECA is critically important to the process.

Sign an Eclipse Contributor Agreement (ECA)

The Eclipse Foundation has a strong Intellectual Property policy which tracks contributions in detail to ensure that:

  1. Did the contributor author 100% of the content?
  2. Does the contributor have the rights to contribute this content to Eclipse?
  3. Is the contribution under the project’s license(s) (e.g. EPL)

A contributor needs to e-sign a Eclipse Contributor Agreement (for more explanation see the Eclipse ECA FAQ ) regardless of how their contribution patch is provided. You can familiarize yourself with the Eclipse wiki page at Contributing via Git. In order to have a pull request accepted by any Eclipse project you must complete this agreement.

Tip

Log into the Eclipse home page (you will need to create an account with the Eclipse Foundation if you have not already done so), click on "Eclipse ECA", and complete the form. Be sure to use the same email address when you create any Git commit records.

Configuring Git

GitHub has copious amounts of quality documentation on how to interact with the system and you will minimally need to configure the user.email property. Check out the following guide on GitHub for more information.

Making the Commit

When making the commit for the pull request it is vital that you "sign-off" on the commit using git commit -s option. Without this sign-off, your patch cannot be applied to the Jetty repository because it will be rejected.

You can check out the guide at Github for more information.

Tip

One way to think of this is that when you sign the ECA you are indicating that you are free to contribute to eclipse, but that doesn’t mean everything you ever do can be contributed. Using the commit signing mechanism indicates that your commit is under the auspices of your agreement.

If a pull request is for a particular issue in our repository then the format of the commit message is important. The message should follow the form "Issue #123 <description of the commit>". When the Jetty project runs releases we have an automated process that scans for commits with this format for inclusion in our VERSION.txt file.

> git commit -s -m "Issue #123 resolving the issue by adding widget"

The Pull Request

Pull requests are very much a GitHub process so best explained by Github.

Our Policies

We wholeheartedly welcome contributions to Jetty and will do our best to process them in a timely fashion. While not every contribution will be accepted, our commitment is to work with interested parties on the things they care about. With that in mind, we can only handle pull requests with actively engaged parties. We reserve the right to abandon pull requests whose authors do no respond in a timely fashion.

We will generally adhere to the following time frames for contributions:

  • Invalid Pull Requests - 1 week

    • These pull requests do not follow the contribution requirements for some reason, be it missing contributor agreement or the wrong email.
    • We will try and follow up with the pull request author to resolve the issue but much of this is out of our hands and are between committer and the Eclipse Foundation.
    • If we do not hear from the contributor after a week we will close the pull request.
  • Valid Pull Requests - 2 weeks

    • These pull requests have a green check mark after the commit title.
    • If the pull request can be immediately applied we will do so.
    • There may need to be some conversation on the issue in which case a committer will follow up with the author in the pull request.
    • If the original contributor does not respond within 2 weeks we may close the commit.
    • If we see value in the commit yet the author has not responded after 2 weeks we may make some variation of the commit ourselves.

See an error or something missing? Contribute to this documentation at Github!(Generated: 2017-05-02)