Code: Difference between revisions
No edit summary |
|||
Line 5: | Line 5: | ||
== Building code == | == Building code == | ||
<blockquote> | |||
There is one main mu2e code git repository which holds our simulation and reconstruction modules and algorithms, and fcl files. You can run the code out of a tagged and pre-built release, by building the entire repository locally, or by build part of the repository locally in a satellite release. You can build it optimized (prof) or in debug. | |||
</blockquote> | |||
* [[CodeRecipe|Basic Recipe]] for setup, checkout and build | |||
* For quick cut and paste... | * For quick cut and paste... | ||
checking out the main repository, ''with kerberos authentication for committing'': | checking out the main repository, ''with kerberos authentication for committing'': | ||
Line 10: | Line 15: | ||
checking out the main repository, ''readonly'': | checking out the main repository, ''readonly'': | ||
<nowiki>git clone http://cdcvs.fnal.gov/projects/mu2eofflinesoftwaremu2eoffline/Offline.git</nowiki> | <nowiki>git clone http://cdcvs.fnal.gov/projects/mu2eofflinesoftwaremu2eoffline/Offline.git</nowiki> | ||
* git | * [[git]] | ||
* scons | * [[scons]] | ||
* Satellite Releases - building only the part of the code base you need | * [[SatelliteRelease|Satellite Releases]] - building only the part of the code base you need | ||
* Base releases and test releases. | * Base releases and test releases. | ||
Revision as of 16:47, 15 February 2017
example page for git documentation
Building code
There is one main mu2e code git repository which holds our simulation and reconstruction modules and algorithms, and fcl files. You can run the code out of a tagged and pre-built release, by building the entire repository locally, or by build part of the repository locally in a satellite release. You can build it optimized (prof) or in debug.
- Basic Recipe for setup, checkout and build
- For quick cut and paste...
checking out the main repository, with kerberos authentication for committing:
git clone ssh://p-mu2eofflinesoftwaremu2eoffline@cdcvs.fnal.gov/cvs/projects/mu2eofflinesoftwaremu2eoffline/Offline.git
checking out the main repository, readonly:
git clone http://cdcvs.fnal.gov/projects/mu2eofflinesoftwaremu2eoffline/Offline.git
- git
- scons
- Satellite Releases - building only the part of the code base you need
- Base releases and test releases.
References and How-to's
- Mu2e Geometry: The Big Picture
- Notes on the geometry files
- Using random numbers:
- Basic Instructions
- Complete Instructions
- Magnetic Field Maps.
- Conditions Data
- products and modules
- Which names need to match each other.
- The Mantra for making data products.
- listing products and printing their contents
- What are Services?
- Services distributed with the framework.
- Deprecated art services
- About handles.
- Filter Modules.
- Inter-Product References: art::Ptr, art::PtrVector, art::Assns
- cet::map_vector: a new class template
- Exceptions: Mu2e policy, CMS guide to managing exceptions.
Configuring fcl
- SimpleConfig
- Run-time Configuration (.fcl files)
- Trigger_paths, end_paths and reconstruction on demand.
- Configuring input and output modules
- Search path for some run-time files.
- Using and configuring the message logger
Code Management
mu2e uses git for all code management. There is one main repository for code (with BTrk, the Kalman fit, in a separate respository) and a few smaller repositories for tools. Built releases are distributed worldwide, including remote institutions and the grids with the cvmfs distributed disk system. The code is built after every commit, and built and validated every night on the Jenkins build platform.
- The Mu2e git page
- Jenkins - a central build platform
- CVMFS - a distributed disk system to serve tagged, static code builds and products
- Download - pull a local copy to remote institutions or laptops
- BTrk - the KalMan fitter code is in this non-standard product
Standards and Practices
- Editors: Emacs, vim; policy of not using tab characters.
- CMS code references: Home Offline WorkBook SW Guide
- Units and Coordinate Systems
External Packages
- UPS/UPD as used by Mu2e
- Setting up ROOT by itself
- Mu2e code
- art
- CMS Framework
- Root (v5.28)
- Geant4 DOxygen(v9.4.p01)
- Geant4 LXR
- CLHEP(v.2.2.0.4)
- HepPDT
- fhicl-cpp
- cetlib
- Message Facility
- cpp0x
- BTrk
- LXR browsers for many Fermilab projects
- The art redmine wiki, art-users archive
- Other external software used by Mu2e with links to documentation.