A Rust GitOps/symlinkfarm orchestrator inspired by GNU Stow.
Find a file
Christina Sørensen db6e905cbc
Added arm to match statement for waranty in main
Added an arm to the match statement for parsing flags in main.

Using the pattern and hopefully ongoing convention of making
unimplemented arms indicated by using the unimplemented!() macro.

Signed-off-by: Christina Sørensen <christina@cafkafk.com>
2023-06-09 17:25:15 +02:00
src Added arm to match statement for waranty in main 2023-06-09 17:25:15 +02:00
tst initial commit 2023-06-08 18:50:09 +02:00
.gitignore initial commit 2023-06-08 18:50:09 +02:00
Cargo.lock initial commit 2023-06-08 18:50:09 +02:00
Cargo.toml initial commit 2023-06-08 18:50:09 +02:00
CODE_Of_CONDUCT.md initial commit 2023-06-08 18:50:09 +02:00
install initial commit 2023-06-08 18:50:09 +02:00
install_debug initial commit 2023-06-08 18:50:09 +02:00
LICENSE initial commit 2023-06-08 18:50:09 +02:00
README.org initial commit 2023-06-08 18:50:09 +02:00
shell.nix initial commit 2023-06-08 18:50:09 +02:00

gg - git gut

A Rust GitOps/symlinkfarm orchestrator inspired by GNU Stow. Useful for dealing with "dotfiles", and with git support as a first class feature. Configuration is done throug a single yaml file, giving it a paradigm that should bring joy to those that use declarative operating systems and package managers.

Although this isn't really a case where it matters that much for performance, being written in rust instead of e.g. janky scripting languages does also mean it is snappy and reliable, and the extensive testing helps ensure regressions aren't introduced.

That said, we're in 0.0.Z, here be dragons for now.

Installation

$ git clone https://github.com/cafkafk/git
$ ./install

Configuration

If you want a template, you can copy the file from tst/config.yaml:

$ cp tst/config.yaml ~/.config/gg/config.yaml

You should seriously change this file before running any commands.

The configuration format will likely break regularly in versions 0.Y.Z.