Git: Difference between revisions
No edit summary |
No edit summary |
||
Line 10: | Line 10: | ||
There exist several other mu2e Redmine repositories for various tools not tightly coupled to Offline. You can browse [https://cdcvs.fnal.gov/redmine/projects all Redmine projects] | There exist several other mu2e Redmine repositories for various tools not tightly coupled to Offline. You can browse [https://cdcvs.fnal.gov/redmine/projects all Redmine projects] | ||
[https://cdcvs.fnal.gov/redmine/projects/mu2e mu2e Redmine] | [https://cdcvs.fnal.gov/redmine/projects/mu2e mu2e Redmine] | ||
[https://cdcvs.fnal.gov/redmine/projects/offlinesoftwaremu2e mu2e repositories] | [https://cdcvs.fnal.gov/redmine/projects/mu2e/offlinesoftwaremu2e mu2e repositories] | ||
See [[#References|the references]] for more details on git. | See [[#References|the references]] for more details on git. |
Revision as of 18:34, 25 May 2017
Introduction
The primary source code management system for the Mu2e Offline software is a git repository that is hosted on the Fermilab Fermilab redmine site. Other Mu2e software is managed using other source code management systems.
NB, please follow these commit instructions for the mu2e conventions on commits.
Almost all of the mu2e Offline code is currently in one Redmine repository. One important piece, the BTrk UPS product, which contains our Kalman track fit code, is stored in the BTrk github repo.
There exist several other mu2e Redmine repositories for various tools not tightly coupled to Offline. You can browse all Redmine projects mu2e Redmine mu2e repositories
See the references for more details on git.
Quick Start
Please also see the basic code recipe for an introduction to setting up the environment, checking out code and building.
If you are going to commit anything, you must understand and follow the mu2e commit instructions
If this is the first time you are using git in the mu2e environment, please follow the few steps listed here under "Configure git" in order to set up your ~.gitconfig.
A more detailed introduction to mu2e repositories is mu2e here
- checkout the main repository
- readonly:
git clone http://cdcvs.fnal.gov/projects/mu2eofflinesoftwaremu2eoffline/Offline.git
- with kerberos authentication for committing code
git clone ssh://p-mu2eofflinesoftwaremu2eoffline@cdcvs.fnal.gov/cvs/projects/mu2eofflinesoftwaremu2eoffline/Offline.git
- readonly:
- checkout the head to a local working branch (recommended)
git checkout -b work
- see the history of a file
git log fileSpec
- list tags
git tag -l
- checkout a tag or branch into the working area
git checkout tagOrBranchName
- update the local repository
git fetch
- update the local repository and checkout the head into the working area
git pull
- see what the status is
git status
- command line help
git status help
- git browser (to see a graphical history of commits)
gitk --all
Please see the references below or many web resources for details on git concepts, commands and features.
If you are going to commit anything, you must understand and follow the mu2e commit instructions
Creating Redmine repositories
References
- mu2e git and CVS
- mu2e git commit instructions
- git home Documentation reference
- redmine repository browser
- Fermilab redmine
- talk at the Software and Simulation Meeting, Sept 17, 2014.
- Marc P's suggested git workflow for simple git projects
- Fermilab git workshop and related materials
- managing and creating new redmine repositories