Metadata-Version: 2.1
Name: gitman
Version: 2.0a2
Summary: A language-agnostic dependency manager using Git.
Home-page: https://pypi.org/project/gitman
License: MIT
Keywords: git,version control,build systems,dependency management,submodules
Author: Jace Browning
Author-email: jacebrowning@gmail.com
Requires-Python: >=3.7,<4.0
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Topic :: Software Development
Classifier: Topic :: Software Development :: Build Tools
Classifier: Topic :: Software Development :: Version Control
Classifier: Topic :: System :: Software Distribution
Requires-Dist: datafiles (>=0.7)
Requires-Dist: minilog (>=1.2,<2.0)
Project-URL: Documentation, https://gitman.readthedocs.io
Project-URL: Repository, https://github.com/jacebrowning/gitman
Description-Content-Type: text/markdown

## Overview

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.

![demo](https://raw.githubusercontent.com/jacebrowning/gitman/develop/docs/demo.gif)

[![Unix Build Status](https://img.shields.io/travis/jacebrowning/gitman/master.svg?label=unix)](https://travis-ci.org/jacebrowning/gitman)
[![Windows Build Status](https://img.shields.io/appveyor/ci/jacebrowning/gitman/master.svg?label=window)](https://ci.appveyor.com/project/jacebrowning/gitman)
[![Coverage Status](https://img.shields.io/coveralls/jacebrowning/gitman/master.svg)](https://coveralls.io/r/jacebrowning/gitman)
[![Scrutinizer Code Quality](https://img.shields.io/scrutinizer/g/jacebrowning/gitman.svg)](https://scrutinizer-ci.com/g/jacebrowning/gitman/?branch=master)
[![PyPI Version](https://img.shields.io/pypi/v/GitMan.svg)](https://pypi.org/project/GitMan)
[![PyPI License](https://img.shields.io/pypi/l/GitMan.svg)](https://pypi.org/project/GitMan)

## Setup

### Requirements

* Python 3.6+
* Git 2.8+ (with [stored credentials](http://gitman.readthedocs.io/en/latest/setup/git/))

### Installation

Install this tool globally:

```shell
$ pip install gitman
```

or add it to your [Poetry](https://poetry.eustace.io/) project:

```shell
$ poetry add gitman
```

### Configuration

Generate a sample config file:

```shell
$ gitman init
```

or manually create one (`gitman.yml` or `.gitman.yml`) in the root of your working tree:

```yaml
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/truffleHog.py
- name: fontawesome
  repo: https://github.com/FortAwesome/Font-Awesome
  sparse_paths:
  - webfonts/*
  rev: master
- name: material-design-icons
  repo: https://github.com/google/material-design-icons.git
  rev: master
  
groups:
- name: code
  members:
  - framework
  - trufflehog
- name: resources
  members:
  - fontawesome
  - material-design-icons
```

Ignore the dependency storage location:

```shell
$ echo vendor/gitman >> .gitignore
```

## Usage

See the available commands:

```shell
$ gitman --help
```

### Updating Dependencies

Get the latest versions of all dependencies:

```shell
$ gitman update
```

which will essentially:

1. Create a working tree at `<root>`/`<location>`/`<name>`
2. Fetch from `repo` and checkout the specified `rev`
3. Symbolically link each `<location>`/`<name>` from `<root>`/`<link>` (if specified)
4. Repeat for all nested working trees containing a config file
5. Record the actual commit SHAs that were checked out (with `--lock` option)
6. 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-parse` date: `'develop@{2015-06-18 10:30:59}'`


Alternatively get the latest versions of certain dependencies or even dependency groups:

* Update a single repository

```shell
$ gitman update framework
```

* Update a dependency group

```shell
$ gitman update resources
```


### Restoring Previous Versions

Display the specific revisions that are currently installed:

```shell
$ gitman list
```

Reinstall these specific versions at a later time:

```shell
$ gitman install
```

### Deleting Dependencies

Remove all installed dependencies:

```shell
$ gitman uninstall
```

