ol-cesium
Version:
OpenLayers Cesium integration library
122 lines (75 loc) • 4.41 kB
Markdown
# Contributing to Ol-Cesium
Thanks for your interest in contributing to Ol-Cesium.
## Contributing Code
Our preferred means of receiving contributions is through [pull requests](https://help.github.com/articles/using-pull-requests). Make sure
that your pull request follows our pull request guidelines below before submitting it.
This page describes what you need to know to contribute code to ol-cesium as a developer.
## Contributor License Agreement
Your contribution will be under our [license](https://raw.githubusercontent.com/openlayers/ol-cesium/master/LICENSE)
as per [GitHub's terms of service](https://help.github.com/articles/github-terms-of-service/#6-contributions-under-repository-license).
## Setting up development environment
You will obviously start by
[forking](https://github.com/openlayers/ol-cesium/fork) the ol-cesium repository.
### Cloning the repository
Make sure you clone the repositiory using `git clone --recursive` command.
## Working with the build tool
As an ol-cesium developer you will need to use the `make` command in order
to run the linter, the compiler, the tests, etc.
The targets can be invoked using:
$ make <target>
where `<target>` is the name of the target you want to execute. For example:
$ make dist
## Pull request guidelines
Your pull request should follow the OpenLayers guidelines.
### The `check` build target
It is strongly recommended that you run
$ make check
before every commit. This will catch many problems quickly.
The `check` build target runs a number of quick tests on your code. These
include:
* Lint
* Compile
* Tests
### Follow OpenLayers coding style
The OpenLayers coding style should be followed except as specified below.
For readablitiy, testing for `undefined` and `null` must be handled as follows:
- In the case of numbers, strings and booleans: use `object !== undefined`;
- In the case of objects: use `the object itself`;
- In all cases where the type is unknown, like with templates: use `object !== undefined && object !== null`.
### Address a single issue or add a single item of functionality
Please submit separate pull requests for separate issues. This allows each to
be reviewed on its own merits.
### Contain a clean history of small, incremental, logically separate commits, with no merge commits
The commit history explains to the reviewer the series of modifications to the
code that you have made and breaks the overall contribution into a series of
easily-understandable chunks. Any individual commit should not add more than
one new class or one new function. Do not submit commits that change thousands
of lines or that contain more than one distinct logical change. Trivial
commits, e.g. to fix lint errors, should be merged into the commit that
introduced the error. See the [Atomic Commit Convention on Wikipedia](http://en.wikipedia.org/wiki/Atomic_commit#Atomic_Commit_Convention) for more detail.
`git apply --patch` and `git rebase` can help you create a clean commit
history.
[Reviewboard.org](http://www.reviewboard.org/docs/codebase/dev/git/clean-commits/)
and [Pro GIT](http://git-scm.com/book/en/Git-Tools-Rewriting-History) have
explain how to use them.
### Use clear commit messages
Commit messages should be short, begin with a verb in the imperative, and
contain no trailing punctuation. We follow
http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html
for the formatting of commit messages.
Git commit message should look like:
Header line: explaining the commit in one line
Body of commit message is a few lines of text, explaining things
in more detail, possibly giving some background about the issue
being fixed, etc etc.
The body of the commit message can be several paragraphs, and
please do proper word-wrap and keep columns shorter than about
74 characters or so. That way "git log" will show things
nicely even when it's indented.
Further paragraphs come after blank lines.
Please keep the header line short, no more than 50 characters.
### Be possible to merge automatically
Occasionally other changes to `master` might mean that your pull request cannot
be merged automatically. In this case you may need to rebase your branch on a
more recent `master`, resolve any conflicts, and `git push --force` to update
your branch so that it can be merged automatically.