Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jreinke/modgit

Shell script for Git module deployment with include/exclude filters.
https://github.com/jreinke/modgit

Last synced: about 2 months ago
JSON representation

Shell script for Git module deployment with include/exclude filters.

Awesome Lists containing this project

README

        

# Deploy multiple Git repositories in an unique folder

`modgit` is a shell script for deploying multiple Git repositories in root folder of any project, which is not possible with default `git submodule` command. A common use case would be the easy installation of Magento modules that need to be deployed in root folder.

## Installation

### curl installation

$ curl https://raw.githubusercontent.com/jreinke/modgit/master/modgit > modgit
$ chmod +x modgit
$ mv modgit /usr/local/bin

### wget installation

$ wget -O modgit https://raw.githubusercontent.com/jreinke/modgit/master/modgit
$ chmod +x modgit
$ mv modgit /usr/local/bin

### Manual download
* Download shell script [here](https://raw.github.com/jreinke/modgit/master/modgit)
* Copy modgit file to `/usr/local/bin` (or any folder in your $PATH)
* Run `chmod +x modgit`

## Usage

### Install a module

$ cd /path/to/project
$ modgit init
$ modgit add [-n] [-t tag_name] [-b branch_name]

### Update a module

$ modgit up [-n]

### Update all modules

$ modgit up-all [-n]

### Remove a module

$ modgit rm [-n]

### Remove all modules

$ modgit rm-all [-n]

### List installed modules

$ modgit ls

### Show information about an installed module

$ modgit info

### Show deployed files of an installed module

$ modgit files

### Show help

$ modgit help

## Advanced usage

### Dry run mode

$ modgit add -n scheduler https://github.com/fbrnc/Aoe_Scheduler.git
=> show what would be done

### Include filter

$ modgit add -i lib/ elastica git://github.com/ruflin/Elastica.git
=> will deploy only lib/ folder

### Include filter with custom target

$ modgit -i lib/:library/ add elastica git://github.com/ruflin/Elastica.git
=> will deploy only lib/ (remote folder) to library/ (local folder)

### Exclude filter

$ modgit add -e tests/ atoum https://github.com/atoum/atoum.git
=> will deploy all remote files and folders, except tests/ folder

### Automatic modman compatibility

$ modgit add debug https://github.com/madalinoprea/magneto-debug.git
=> will parse remote modman file for files and folders mapping