#git-repository #git-clone #git #command-line-tool #version-control #utility #root-directory

bin+lib souko

A simple command line utility that provides an easy way to organize clones of remote git repositories

5 unstable releases

0.2.0 Sep 17, 2023
0.1.2 Sep 3, 2023
0.1.1 Sep 2, 2023
0.1.0 Sep 2, 2023
0.0.0 Aug 9, 2022

#2578 in Command line utilities

Download history 57/week @ 2023-12-15 51/week @ 2023-12-22 7/week @ 2023-12-29 1/week @ 2024-02-23 1/week @ 2024-03-01 3/week @ 2024-03-08 5/week @ 2024-03-15 57/week @ 2024-03-22 37/week @ 2024-03-29

102 downloads per month

MIT/Apache

105KB
2.5K SLoC

souko

Maintenance: actively-developed License: MIT OR Apache-2.0 crates.io docs.rs Rust: ^1.70.0 GitHub Actions: CI Codecov

Souko is a simple command line utility that provides an easy way to organize clones of remote git repositories.

VS Code extension souko-vscode is also available.

When you clone a remote repository with souko, souko creates a directory under a specific root directory (~/.local/share/souko/root by default) containing the hostname and path of the remote repository's URL.

$ souko clone https://github.com/gifnksm/souko
# => creates local clone at ~/.local/share/souko/root/github.com/gifnksm/souko

You can also list all repositories that have been cloned.

$ souko list
# => list of absolute paths of all repositories cloned with souko

By combining souko, fuzzy finder, and shell functions, you can easily jump between repositories (TODO: add shell script example).

Configuration

Configuration is done via a TOML file located at ~/.config/souko/config.toml by default.

[[root]]
name = "default"
path = "~/.local/share/souko/root"

[[root]]
name = "repos"
path = "~/repos"

[query]
default_scheme = "github"

[query.scheme_alias]
gh = "github"
gl = "gitlab"

[query.custom_scheme]
github = "https://github.com/{path}.git"
gitlab = "https://gitlab.com/{path}.git"

Installation

There are multiple ways to install souko. Choose any one of the methods below that best suits your needs.

Distribution packages

Following packages are available:

Pre-built binaries

Executable binaries are available for download on the GitHub Release page.

You can also install the binary with cargo-binstall command.

# Install pre-built binary
$ cargo binstall souko

Build from source using Rust

To build souko executable from the source, you must have the Rust toolchain installed. To install the rust toolchain, follow this guide.

Once you have installed Rust, the following command can be used to build and install souko:

# Install released version
$ cargo install souko

# Install latest version
$ cargo install --git https://github.com/gifnksm/souko.git souko

Minimum supported Rust version (MSRV)

The minimum supported Rust version is Rust 1.70.0. At least the last 3 versions of stable Rust are supported at any given time.

While a crate is a pre-release status (0.x.x) it may have its MSRV bumped in a patch release. Once a crate has reached 1.x, any MSRV bump will be accompanied by a new minor version.

License

This project is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

See CONTRIBUTING.md.

Dependencies

~28–44MB
~753K SLoC