23 releases (6 breaking)

Uses new Rust 2021

0.7.8 Apr 15, 2022
0.7.6 Mar 27, 2022
0.6.0 Dec 26, 2021
0.5.0 Nov 26, 2021

#56 in Configuration

Download history 30/week @ 2022-01-24 24/week @ 2022-01-31 12/week @ 2022-02-07 25/week @ 2022-02-14 42/week @ 2022-02-21 14/week @ 2022-02-28 14/week @ 2022-03-07 83/week @ 2022-03-14 77/week @ 2022-03-21 15/week @ 2022-03-28 60/week @ 2022-04-04 29/week @ 2022-04-11 6/week @ 2022-04-18 95/week @ 2022-04-25 162/week @ 2022-05-02 29/week @ 2022-05-09

297 downloads per month
Used in dt-cli

MIT/Apache

210KB
4.5K SLoC

DT

release tests docs crates.io

DT allows you to sync/populate configuration files at will. It currently provides a CLI tool dt-cli.

Usage

The command line interface dt-cli accepts a path to the configuration file as an argument and performs the syncing process specified in the file.

Configuration guides and detailed usages can be found in the documentations.

Example

A simple working configuration file to sync all files from ~/dt/nvim to ~/.config/nvim that matches *init.vim can be written as:

[[local]]
name = "Neovim Configs"
base = "~/dt/nvim"
sources = ["*init.vim"]
target = "~/.config/nvim"

⚠️ STOP HERE if you don't know what you are doing, or have not backed up existing files under ~/.config/nvim.

Save above config to ~/.config/dt/cli.toml and run

$ dt-cli -c ~/.config/dt/cli.toml

to start syncing. Note the path in this example (~/.config/dt/cli.toml) is also the default path, so the below command (calling dt-cli with no argument) does the same thing as above:

$ dt-cli

Other command line flags & options

Flags Description
-d|--dry-run Shows changes to be made without actually syncing files.
-h|--help Prints help information.
-q|--quiet Decreases logging verbosity.
-v|--verbose Increases logging verbosity.
-V|--version Prints version information.
Options Description
-c|--config-path <path> Specifies path to config file.
Args Description
<group-name>... Specifies name(s) of the group(s) to be processed

Install

AUR

dt-cli is in the AUR, you can install it with your favorite package manager:

$ paru -S dt-cli

Alternative ways

Alternatively, you can:

  • Download latest release from GitHub

  • Install from crates.io:

    $ cargo install dt-cli
    
  • Build from source:

    $ git clone git@github.com:blurgyy/dt.git
    $ cd dt
    $ cargo test --release
    $ cargo install --path=dt-cli
    

Contributing

There are numerous ways to help with this project. Let's get started!

License

Licensed under the the MIT license http://opensource.org/licenses/MIT or Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0, at your option. This file may not be copied, modified, or distributed except according to those terms.

Dependencies

~5–7MB
~173K SLoC