rhq - Manages your local repositories

License: MIT Build Status Build status

rhq is a command-line repository management tool, written in Rust.

Overview

rhq provides a way to organize local repositories cloned by Git and other VCSs. You can use the command rhq clone as alternative of git clone, to clone remote repositories under a specific root directory with intuitive directory structure.

```sh $ rhq clone ubnt-intrepid/rhq

Equivalent to git clone https://github.com/ubnt-intrepid/rhq.git ~/.rhq/github.com/ubnt-intrepid/rhq

```

~/.rhq/ |- github.com/ | |- ubnt-intrepid/ | | `- rhq/ <- clones with intuitive directory structure | `- user2/ | `- repo3/ `- gitlab.com/ `- user3/ `- repo4/

rhq also provides a way to list the location of managed local repositories.

sh $ rhq list /home/username/.rhq/github.com/ubnt-intrepid/rhq /home/username/.zplug/repos/zsh-users/zsh-autosuggestions ...

Installation

You can download precompiled artifacts from GitHub releases page.

If you have already installed Rust toolchain, builing manually is available with following command: shell-session $ cargo install rhq # from crates.io $ cargo install --git https://github.com/ubnt-intrepid/rhq.git # development version

Commands

rhq clone [<query>]

Clone remote reposities into the local directory.

Arguments

Options

rhq new <query>

Create a new Git repository with intuitive directory structure.

Arguments

See rhq clone (but <query> is required)

Options

See rhq clone

rhq list

List local repositories managed by rhq.

Arguments

None

Options

None

rhq foreach <command> [<args>...]

Execute commands into each local repositories.

Arguments

Options

rhq completion <shell> [<out-file>]

Generate completion script for your shell. If out-file is omitted, dump scirpt to standard output.

Arguments

Configuration

The behaviour of rhq can change by using configuration files. The location of configuration file is ~/.rhqconfig or ~/.config/rhq/config.

See .rhqconfig for details.

Plugins

Vim

mattn/ctrlp-ghq is available. If you are vim-plug user, try as follows:

```vim Plug 'mattn/ctrlp-ghq'

let g:ctrlpghqcommand = 'rhq' let g:ctrlpghqactions = [ { "label": "Open", "action": "Explore", "path": 0 } ]

noremap g :CtrlPGhq ```

Visual Studio Code

Extensions for Visual Studio Code is available. See here for details.

Similar projects