Difference between revisions of "ROOT Analyzer/Git"

From HallCWiki
Jump to navigationJump to search
(Partial save of rewrite)
(Rewrite done. Someone please proof)
Line 45: Line 45:
 
           url = git://github.com/JeffersonLab/analyzer.git
 
           url = git://github.com/JeffersonLab/analyzer.git
 
=== Keeping personal fork up to date ===
 
=== Keeping personal fork up to date ===
 
+
The forked copy of hcana and the local copy on your machine made do not automatically stay up to date with changes made to the main development repository.  The following commands will update your local copy and the forked copy on GitHubThis update procedure should be done before using analyzer and before starting to edit some changes or additions to the code. From your hcana directory, do:
=== Editing code and contributing back ===
+
   git checkout develop
 
 
 
 
*Now the remote "origin" points to your personal copy of the hcana repository on githubAfter cloning, you will be in the "develop" branch, which is the current default branch(Formal releases will be on the master branch.)
 
*You can keep your local copy up to date with the main repository:
 
**One time, do
 
   git remote add --track develop upstream https://github.com/JeffersonLab/hcana
 
**To fetch the latest updates, do
 
 
   git fetch upstream
 
   git fetch upstream
**To merge the main development branch with your working code, do
 
 
   git merge upstream/develop
 
   git merge upstream/develop
 
+
  git push origin develop
 
+
=== Editing code and contributing back ===
== Using the analyzer ==
+
It is important that any code development be made public early and often.  We will follow the pattern here for developing code.
 
+
#Follow the above procedure to update your repository with the current state of the develop branch in the main repository.
See [[Analyzer/Compiling]] and [[Analyzer/Running]] to try out the code.
+
#Go to the develop branch with<br><code>git checkout develop</code></br>  Do not edit any files while in the develop branch.  This is so that your develop branch stays a clean copy of the main repository.
 
+
#Optional: Visit the [http://github.com/JeffersonLab/hcana/ http://github.com/JeffersonLab/hcana/] and create an "Issue" that describes the work that you are going to do.
== Using Git to develop the analyzer ==
+
#Create a new branch, with a descriptive branch name with <br><code>git checkout -b ''featurebranchname''</code>
 
+
#Do some work.
We need to have a workflow methodology for developing the Hall C analyzer"[http://sandofsky.com/blog/git-workflow.html Understanding the Git Workflow]" and "[http://thinkvitamin.com/code/source-control/git/our-simple-git-workflow/ Our Simple Git Workflow]" have some discussion of straight forward workflows.
+
#Everytime that makes sense (e.g. once a day, or everytime a logical set of changes have been made.) commit your changes with <br><code>git commit -a</code><br> or <br><code>git commit ''filename1'' ''filename2'' ...</code><br>
 
+
#Push your changes to a branch on your GitHub respository.<br><code>git push origin ''featurebranchname''</code><br> This can be done often as it does not change the main repository.
Basically if you want to develop the analyzer, clone the git archive as described above.  Then create a private branch for yourself with
+
#When ready to request that your changes be merged in with the main repository, go to your GitHub page, select the branch ''featurebranchname'' and select pull request.
 
+
#Wait for your "pull request" to be commented upon by other collaborators or accepted by a maintainerWhen the pull request has been accepted to your satisfaction, it is safe to delete ''featurebranchname'' both on your local machine and on your GitHub account.
  git checkout -b <i>myprivatebranch</i>
+
#Before starting new work, make sure you update your local and GitHub repositories as described above.
 
 
Then work on the code do <tt>git commit -a</tt> frequently. Don't worry about committing changes frequently. You will have the opportunity to clean up the revision history before pushing your changes to the public repository.
 
 
 
There are a variety of ways to share your work.  If someone you want to share it with is on the same machine (and your files are readable), he can clone or pull from your archive. If your working directory is available on the web, then anyone can clone or pull from it.  To put your changes in the public git repository, contact one of the code maintainers.
 
 
 
== Branches ==
 
 
 
The git repository may contain several branches in addition to the default "develop" branch.  These branches may be for different experiments, or for work in progress that a developer wants to share.  To see what branches exist, type
 
 
 
  git pull origin   #Updates the local repo from the public repo
 
  git branch -a
 
 
 
from the directory you cloned the project into.  For example, at the moment, there is a branch "simon-shower" which contains code being developed for the shower counters. This branch will be listed as "remotes/origin/simon-shower". To check this branch out, type
 
 
 
  git checkout simon-shower
 
 
 
The master branch is reserved for major releases.
 
 
 
== Publishing Changes ==
 
 
 
It is important that any code development be made public early and often.  There are two ways of sharing your changes.
 
 
 
=== Push directly to a branch on a repository ===
 
If you have previously retrieved the analyzer from github, you need to change to the hallc git server to be able to push code.  To setup the ability publish your work to the public repository, you must modify the remote named "origin". You can do this by running the command
 
 
 
        git remote -v  # just to list what the remotes look like beforehand
 
        git remote set-url --push origin git@hallcgit.jlab.org:hcana.git
 
        git remote -v  # just to see what the remotes look like after modification
 
 
 
or you edit the file "hcana/.git/config"Find the sectioon <tt>[remote "origin"]</tt>.  Then replace "url" line after it with
 
 
 
        url = git@hallcgit.jlab.org:hcana.git
 
 
 
Gitweb will have to be told to allow access from your account.  To do this, contact Steve Wood.
 
 
 
To publish changes, make sure you are doing your work in a branch other than develop.  When you are ready to post it, do
 
 
 
git push origin branchname
 
 
 
Then let Steve Wood know and he will merge your code into the develop branch.
 
  
 
=== Read only access ===
 
=== Read only access ===
Line 121: Line 73:
 
   git clone https://github.com/JeffersonLab/hcana.git
 
   git clone https://github.com/JeffersonLab/hcana.git
  
 +
== Using the analyzer ==
  
=== Send a pull request to the maintainer (safe method) ===
+
See [[Analyzer/Compiling]] and [[Analyzer/Running]] to try out the code.
 
 
This method is a bit more safe and you don't need any special permission.
 
 
 
First you have to be hosting a public repository. You can set up your own (which can be difficult) or you can use one of many (free) online services like [http://www.github.com github]. Once you have an account you can create a fork by going [https://github.com/sawjlab/hcana here] and clicking on fork in the upper right. This creates a copy of the repository of your own.
 
 
 
To add the remote you can do the following
 
 
 
      git remote add github git@github.com:USERNAME/hcana.git
 
 
 
Now you can push your changes to your repository (and browse on the web).
 
 
 
      git push github SOME_BRANCH
 
 
 
Then you send a "pull request" to the maintainer. This can be done with a simple email pointing them to the public repo and branch or using github.com's online pull request feature.
 
 
 
Either way, the maintainer inspects your changes before merging.
 
  
 
== Git References ==
 
== Git References ==

Revision as of 16:06, 8 October 2013

Hall C uses the Git version control system to manage development of the Hall C 12 Gev analysis software. The Hall C analyzer uses the framework of the Hall A PODD analyzer.

Some general information on how to work with git can be found on the Git Howto page, and at #Git References.

The git repository of hcana on the web at github.com.

Setting up Git

You should have git, with at least version 1.5.3 installed on your computer. Most linux systems will have git installed.

  • NOTE: git 1.7.x (or newer) is much, much better. We should have this rolled out on most machines at JLab and it is typically the default on personal installations. If you find an older version on a JLab-controlled machine you are advised to request an upgrade by submitting a JLab CCPR.

Personalize git on your machine with

 git config --global user.name "Firstname Lastname"
 git config --global user.email "your_email@youremail.com"

By default, git pops up the vi editor for the user write comments when making commits. If you prefer emacs, do

 git config --global core.editor "emacs"

Retrieving the Hall C analyzer with git

The following instructions are for users who plan to contribute to developing the analyzer, either for general use, or for a specific experiment. Establish an account on github.com is required. See the section "Read-only access" below for how to retrieve the code without needing an account.

Setup and creating a personal fork of the analyzer

  1. If you don't already have one, create a personal account on github.com.
  2. Follow the directions on the github.com for storing your public ssh key on the site. (NOTE: The github instructions ask you to install a program called "xclip" to help upload your public key. This is unnecessary - you can just "click and paste".)
  3. Go to https://github.com/JeffersonLab/hcana.
  4. Optionally select Watch to be notified of changes to hcana.
  5. Click the Fork buton to create your own copy of the hcana repository on github.
  6. On the computer that you plan to run and develop the analyzer, type:
    git clone git@github.com:GitHub-Username/hcana.git
    where GitHub-Username is the name of the account that you created.
  7. Do
    cd hcana
  8. Execute the command
    git remote add --track develop upstream git@github.com:/JeffersonLab/hcana
    This will be needed to keep your forked copy and local machine copy of the code up to date with the main development repository.

PODD submodule

hcana is written as an extension to Hall A analyzer, often known as podd. The source code to the Hall A analyzer is required to build the Hall C analyzer. The Hall A code is not automatically downloaded with the "git clone" command. Before proceeding, from your working directory do

 git submodule init
 git submodule update

If your version of git is too old, this last command may give an error. In that case, edit the file ".git/config", find [submodule "podd"] section and edit it to look like:

 [submodule "podd"]
          url = git://github.com/JeffersonLab/analyzer.git

Keeping personal fork up to date

The forked copy of hcana and the local copy on your machine made do not automatically stay up to date with changes made to the main development repository. The following commands will update your local copy and the forked copy on GitHub. This update procedure should be done before using analyzer and before starting to edit some changes or additions to the code. From your hcana directory, do:

 git checkout develop
 git fetch upstream
 git merge upstream/develop
 git push origin develop

Editing code and contributing back

It is important that any code development be made public early and often. We will follow the pattern here for developing code.

  1. Follow the above procedure to update your repository with the current state of the develop branch in the main repository.
  2. Go to the develop branch with
    git checkout develop
    Do not edit any files while in the develop branch. This is so that your develop branch stays a clean copy of the main repository.
  3. Optional: Visit the http://github.com/JeffersonLab/hcana/ and create an "Issue" that describes the work that you are going to do.
  4. Create a new branch, with a descriptive branch name with
    git checkout -b featurebranchname
  5. Do some work.
  6. Everytime that makes sense (e.g. once a day, or everytime a logical set of changes have been made.) commit your changes with
    git commit -a
    or
    git commit filename1 filename2 ...
  7. Push your changes to a branch on your GitHub respository.
    git push origin featurebranchname
    This can be done often as it does not change the main repository.
  8. When ready to request that your changes be merged in with the main repository, go to your GitHub page, select the branch featurebranchname and select pull request.
  9. Wait for your "pull request" to be commented upon by other collaborators or accepted by a maintainer. When the pull request has been accepted to your satisfaction, it is safe to delete featurebranchname both on your local machine and on your GitHub account.
  10. Before starting new work, make sure you update your local and GitHub repositories as described above.

Read only access

If you want to download the code to read it or use it, but do not plan to contribute changes back, retrieve the analyzer with:

 git clone git://github.com/JeffersonLab/hcana.git

In some places the "git" protocol may be blocked by a firewall. In that case use:

 git clone https://github.com/JeffersonLab/hcana.git

Using the analyzer

See Analyzer/Compiling and Analyzer/Running to try out the code.

Git References

Brad's Hall C wiki Git_Howto page

Brad's "Git Cheat-sheet": 7 steps to developing with git.

Graphical cheatsheet: 1 page reference

Git Magic: An online book about using Git.

The Git Community Book: The official book introducing Git.

Understanding the Git Workflow

Our Simple Git Workflow

Git flow used by GitHub

We will try to follow the branching model described in: A successful Git branching model