= dotcontrol: a dot file manager

== install

cargo install dotcontrol

== a little glossary

== commands

=== .c

Show info about current profile.

=== .c profile

Switch to profile profile, create first if didn't exist. Obviously, don't name it after following commands.

=== .c i profile [profile...]

Show info about specified profile(s), all if -a.

=== .c ia

Show info about all profiles.

=== .c + path [path...] [-p profile[,profile...]] [-a]

Add or update one or more dots.

If -p, add to specified profile(s).

If -a, add to all profiles.

=== .c ++ app [app...]

Add or update dots following preset app(s).

=== .c - path [path...] [-p profile[,profile...]] [-a]

Delete one or more dots, i.e. stop tracking.

If -p, delete in specified profile(s).

If -a, delete in all profiles.

=== .c -- app [app...]

Delete dots following preset app(s).

=== .c lp

List available presets.

=== .c p- profile [profile...]

Delete one or more profiles.

=== .c p= type remote

Clone remote profile, setting it up as remote.

=== .c =+ type remote [name]

Set up sync. Optionally name it, remote by default.

=== .c =- name [name...]

Shut down specified sync.

=== .c = [profile [profile...]] [-a]

Show sync info for current, specified or all (-a) profile(s).

=== .c ==

Sync currently staged changes. Push to remote if local is newer, and vice versa.

If given arguments, pass to underlying sync program.

=== .c =]

Push changes to remote.

If given arguments, pass to underlying sync program.

=== .c [=

Pull changes from remote.

If given arguments, pass to underlying sync program.

== license

BSD-3-Clause

(c) 2021 Blair Noctis