Unix: Windows:
Metrics:
Usage:
GitMan is a language-agnostic dependency manager using Git. It aims to serve as a submodules replacement and provides advanced options for managing versions of nested Git repositories.
- Python 3.5+
- Git 2.8+ (with stored credentials)
Install GitMan with pip:
$ pip install gitmanor directly from the source code:
$ git clone https://github.com/jacebrowning/gitman.git
$ cd gitman
$ python setup.py installGenerate a sample config file:
$ gitman initor manually create one (gitman.yml or .gitman.yml) in the root of your working tree:
location: vendor/gitman
sources:
- name: framework
repo: https://github.com/kstenerud/iOS-Universal-Framework
rev: Mk5-end-of-life
- name: coverage
repo: https://github.com/jonreid/XcodeCoverage
rev: master
link: Tools/XcodeCoverage
- name: trufflehog
repo: https://github.com/dxa4481/truffleHog
rev: master
scripts:
- chmod a+x truffleHog.py
- name: fontawesome
repo: https://github.com/FortAwesome/Font-Awesome
sparse_paths:
- fonts/*
rev: masterIgnore the dependency storage location:
$ echo vendor/gitman >> .gitignoreSee the available commands:
$ gitman --helpGet the latest versions of all dependencies:
$ gitman updatewhich will essentially:
- Create a working tree at
<root>/<location>/<name> - Fetch from
repoand checkout the specifiedrev - Symbolically link each
<location>/<name>from<root>/<link>(if specified) - Repeat for all nested working trees containing a config file
- Record the actual commit SHAs that were checked out (with
--lockoption) - Run optional post-install scripts for each dependency
where rev can be:
- all or part of a commit SHA:
123def - a tag:
v1.0 - a branch:
master - a
rev-parsedate:'develop@{2015-06-18 10:30:59}'
Display the specific revisions that are currently installed:
$ gitman listReinstall these specific versions at a later time:
$ gitman installRemove all installed dependencies:
$ gitman uninstall