Skip to content

Development Environments

Michael Lyle edited this page Dec 17, 2015 · 14 revisions

Development Environments

The following pages provide OS-specific instructions for setting up a development environment:

All of these platforms are fully supported and are expected to be viable environments in which to develop and test software for this project.

If you have any issues setting up a development environment, please let us know so that we can correct any mistakes and get you up and running.

Getting the code

The code for this project is stored in github. There are various ways to get the code depending on what your level of involvement is.

If you are not planning to contribute, just want to use it

You can grab a read-only clone of the source like this:

git clone git://github.com/d-ronin/dronin.git

If you would like to contribute back to the project

  • Create an account on github.
  • Go to the dRonin github page.
  • Follow the github instructions for forking the repository into your account.
    • Forks the repository
    • Shows you how to get a local clone of your fork
    • Adds a remote called upstream so you can keep up to date with the main repository

Code submissions are made easy by github's interface. Github encourages forks, so the process is easy and straightforward. If necessary, first make a new github account, and then click the "Fork" button in the top right corner. A new fork of TauLabs will be generated in your user account.

You may also want to take a look at some of the other articles in the BootCamp series at github.

Adding git remote for the dRonin project

After you create and clone your own fork, it is helpful to be able to access the primary project repository as well. To do this, execute the following commands:

git remote add upstream https://github.com/d-ronin/dronin.git
git fetch upstream

After this, you can fetch recent changes with git fetch upstream and e.g. git checkout upstream/next to get a copy of the most recent project next branch.

It is also helpful to be able to retrieve and test other peoples' pull requests. There is a neat trick to make retrieving PRs easier from github. First, from your dronin repository edit .git/config. In the [remote "upstream"] section, add a new line that says:

        fetch = +refs/pull/*/head:refs/remotes/pr/*

After this, you can run a series of commands like:

git fetch upstream
git checkout upstream/next
git merge pr/1000
git merge pr/1100

to get source code of next with PR's 1000 and 1100 applied for testing.

Adding git remotes for other developers

The github workflow for contributing means that most developers will work primarily in their own fork of the source tree. To see their feature branches, you'll need to add their fork as a "remote" in your git clone.

You can see a list of all github forks of the source tree here on the Network Members Page.

Here are the git commands to add remotes for the recently active forks (alphabetical order):

git remote add gh-mlyle git://github.com/mlyle/dronin.git
git remote add gh-tracernz git://github.com/tracernz/dronin.git
git remote add gh-mluessi git://github.com/mluessi/dronin.git
git remote add gh-dustin git://github.com/dustin/dronin.git
git remote add gh-fujin git://github.com/fujin/dronin.git
git remote add gh-BrainFPV git://github.com/BrainFPV/dronin.git

You can update all of your remotes like this:

git remote update

You can create a branch from one of these remotes like this:

git checkout -tb myfeaturebranch gh-mlyle/somebranch

Submitting Code To dRonin

Found a bug? Want to add a new feature? Please read over the Contributing Page for some helpful advice before you start coding.

Clone this wiki locally