# Contributing to Eclipse Trace Compass

Thanks for your interest in this project. This page explains how to contribute code to the Trace Compass project.

## Terms of Use

This repository is subject to the [Terms of Use of the Eclipse Foundation][terms].

## Code of Conduct

This project is governed by the [Eclipse Community Code of Conduct](CODE_OF_CONDUCT.md).
By participating, you are expected to uphold this code.

## Eclipse Development Process

This Eclipse Foundation open project is governed by the [Eclipse Foundation
Development Process][dev-process] and operates under the terms of the [Eclipse IP Policy][ip-policy].

## Eclipse Contributor Agreement

In order to be able to contribute to Eclipse Foundation projects you must
electronically sign the [Eclipse Contributor Agreement (ECA)][eca].

The ECA provides the Eclipse Foundation with a permanent record that you agree
that each of your contributions will comply with the commitments documented in
the Developer Certificate of Origin (DCO). Having an ECA on file associated with
the email address matching the "Author" field of your contribution's Git commits
fulfills the DCO's requirement that you sign-off on your contributions.

For more information, please see the [Eclipse Committer Handbook][commiter-handbook].

## Setting up the development environment

To setup the environment to build Trace Compass from within Eclipse, follow the
instruction in the [DEVELOPMENT_ENV_SETUP](DEVELOPMENT_ENV_SETUP.md) file.

## Building the application

In order to build the application from command-line, Maven is used. For more 
information about building the application see the description in the
[BUILDING](BUILDING.md) file.

## Source code tree

This source tree contains the source code for the Trace Compass plugins for
Eclipse.

The plugins are categorized as follows:

    analysis/    | Generic extensions to the base framework
    btf/         | Best Trace Format (BTF) integration
    common/      | Generic utilities that can be used by other plugins
    ctf/         | Common Trace Format (CTF) reader library
    doc/         | Documentation and code examples
    gdbtrace/    | Support for reading and viewing GDB traces
    lttng/       | LTTng integration
    pcap/        | libpcap integration
    rcp/         | Code specific to the RCP version
    releng/      | Releng-related plugins
    statesystem/ | State System library
    tmf/         | Core framework

See the [components.svg](components.svg) file for a diagram showing the dependencies between the
different components.

## When to submit patches

Remember that contributions are always welcome!

If you have a simple and straightforward fix to an obvious bug, feel free to push
it directly to the project's GitHub (see below).

This project uses GitHub issues to track ongoing development and issues. In order
to contribute, please first [open an issue][issues] that clearly describes the
bug you intend to fix or the feature you would like to add. Make sure you provide
a way to reproduce the bug or test the proposed feature.

If you wish to work on a larger problem or feature, it would be a good idea to 
[contact us](#contact) first. It could avoid duplicate work in case somebody is
already working on the same thing. For substantial new features, it is always good
to discuss their design and integration first.

Be sure to search for existing bugs before you create another one. 

Note that before migrating to GitHub issues ongoing development and issues were
tracked using Bugzilla. The bugs were not batch migrated. Only selected issues
have been migrated to GitHub issues. You can search for [here][bugzilla]
for Bugzilla issues.

## Where to submit

The Trace Compass project uses GitHub pull requests for submitting patches and review contributions

Once you have your code ready for review, please  [open a pull request][pull-requests]. Please follow
the [pull request guidelines][pr-guide]. If you are new to the project, the
[new contributors][new-contributors] section provides useful information to get you started. A
committer of the Trace Extension will then review your contribution and help to get it merged.

### The review process

We will try to give feedback to new patches in a reasonable amount of time, usually in the following days. Smaller patches makes the review go faster.

With the exception of “trivial patches”, as in, patches that either don’t change the compiled code (e.g., comments, commit messages), we try to have two (2) committers review every patch that goes in. For a patch from a committer, this means a second committer should review it, even for the trivial ones. For a patch from a non-committer, one committer should do a thorough review, and at least a second one should give a quick look.

A committer may update the patch being submitted, then the original author must review it. This is useful if the author has minor nits to fix, e.g., spaces.

For a patch to be approved, it needs to be marked as `Approved` and all automatic checks need to be successful. Code Review means the patch "looks" good, it follows the coding style, uses relevant algorithms and data structures, etc. Verified in general means that the patch technically works, it compiles, the tests pass, and it does what it is supposed to do.

A reviewer may request changes if pull request needs updates or if verfication reasons.

The meanings of each score are listed below. 

## Code Review

`Approved:` The reviewer considers that the patch follows the coding style, and implements the expected functionality correctly. Reviewers are strongly encouraged to run and verify the contribution of the pull requests, except very trivial ones. At least one `Approved` is required for the patch to go in. Only committers can give this score.

`Commented:` The reviewer considers that this patch is good, but that someone else should also take a look at parts or the totality of the patch. Should be accompanied with a comment indicating what is missing to approve it if the review is from a committer. Anybody with write access can give this score.

`Changes Requested:` There are some things that should be fixed first. Should always be accompanied with general and/or inline comments indicating areas of the code that need improvement. All comments that are given are expected to be either A) fixed in a subsequent patchset or B) replied to with explanation/justification. If the overall direction of the patch is not the right one and it warrants further discussion, the reviewer needs to state that in the pull request. Meaning discussions on the pull request, GitHub issues, the mailing list, or in person. 

## Jenkins review

For each submitted pull request a Jenkins verification job is triggered which executes a full build including JUnit tests. The verification results will be shown in the `Checks` section of the pull request.

## Pull request guidelines

**Changes to the project** are made by submitting code with a pull request (PR).

* [How to write and submit changes][creating-changes]

**Good commit messages** make it easier to review code and understand why the changes were made.
Please include a:

* `Title:` Concise and complete title written in imperative (e.g. "Update Gitpod demo screenshots"
or "Single-click to select or open trace")
* `Problem:` What is the situation that needs to be resolved? Why does the problem need fixing?
Link to related issues (e.g. "Fixes #317").
* `Solution:` What changes were made to resolve the situation? Why are these changes the right fix?
* `Impact:` What impact do these changes have? (e.g. Numbers to show a performance improvement,
screenshots or a video for a UI change)
* [*Sign-off:*][sign-off] Use your full name and a long-term email address. This certifies that you
have written the code and that, from a licensing perspective, the code is appropriate for use in open-source.

Other commit information:

* [How to format the message][commit-message-message]
* Your patch should not introduce any error or warning.
* Follow the project's [coding style][code-style]. It is defined in Eclipse project settings, which are committed in the tree, so simply hitting Ctrl+Shift+F in Eclipse should auto-format the current file.
  * Basically, 4 spaces for indentation, opening brackets on the same line.
  * We've turned off the auto-wrapping and unwrapping of lines, because it was doing more harm than good. Please wrap lines to reasonable lengths (100-120 is a good soft limit). Do NOT wrap after '.' (method invocations), it makes the code less readable. After '(' or ',' is usually good.
* Split your larger contributions in smaller, independent pull requests 'that could go in independently of each other'. It is not unusual to have patch #1 go in quickly, but then have patch #2 go through many rounds of review. Smaller commits make the process faster for everyone (remember, the time taken to review a patch is ''n^2'', where ''n'' is the number of lines in the patch!)
* Not a hard requirement, but we normally prefix the commit titles with the name of the component to which the patch applies, in lowercase. This normally corresponds to the plugin name, so "lttng: xxxx" or "tmf: xxxx".
* If the patch is significant enough to have a mention in the New & Noteworthy, annotate the patch with `[Fixed]`, `[Added]`, `[Changed]`, `[Deprecated]`, or `[Security]` with a short description of what the change does.

## API policy

For more information about the API policies, read the [API_POLICY](API_POLICY.md) file.

## Contact

Contact the project developers via the [project's "dev" mailing list][mailing-list] or open an [issue tracker][issues].

[bugzilla]: https://bugs.eclipse.org/bugs/buglist.cgi?product=Tracecompass
[code-style]: https://github.com/eclipse-tracecompass/org.eclipse.tracecompass/wiki/Coding_style
[commit-message-message]: https://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html
[commiter-handbook]: https://www.eclipse.org/projects/handbook/#resources-commit
[creating-changes]: https://www.dataschool.io/how-to-contribute-on-github/
[dev-process]: https://eclipse.org/projects/dev_process
[eca]: http://www.eclipse.org/legal/ECA.php
[ip-policy]: https://www.eclipse.org/org/documents/Eclipse_IP_Policy.pdf
[issues]: https://github.com/eclipse-tracecompass/org.eclipse.tracecompass/issues
[mailing-list]: https://dev.eclipse.org/mailman/listinfo/tracecompass-dev
[pr-guide]: #pull-request-guidelines
[pull-requests]: https://github.com/eclipse-tracecompass/org.eclipse.tracecompass/pulls
[sign-off]: https://git-scm.com/docs/git-commit#Documentation/git-commit.txt---signoff
[terms]: https://www.eclipse.org/legal/termsofuse.php