1
0
Fork 0
mirror of synced 2025-01-08 14:11:06 -05:00

Remove unnecessary formatting

This commit is contained in:
Tim Byrne 2019-10-19 13:59:03 -05:00
parent c8e8633639
commit fd003e5b25
No known key found for this signature in database
GPG key ID: 14DB4FC2465A4B12
10 changed files with 96 additions and 96 deletions

View file

@ -5,30 +5,30 @@ permalink: /docs/overview
<a name=""></a><!-- Anchor "#" used at the ends of pagination --> <a name=""></a><!-- Anchor "#" used at the ends of pagination -->
> You've spent time tweaking your computing environment. Everything operates the > You've spent time tweaking your computing environment. Everything operates the
way you want. That's fantastic! Then your hard drive fails, and the computer way you want. That's fantastic! Then your hard drive fails, and the computer
needs to be rebuilt. **yadm** can restore you configurations. needs to be rebuilt. yadm can restore you configurations.
> You get a new computer, and you want to recreate that environment. You > You get a new computer, and you want to recreate that environment. You
probably want to keep both machines' configurations in sync. **yadm** can help probably want to keep both machines' configurations in sync. yadm can help
you coordinate the configurations between your machines. you coordinate the configurations between your machines.
> You begin experimenting with new changes to your configurations, and now > You begin experimenting with new changes to your configurations, and now
everything is broken. **yadm** can help you determine what changed or simply everything is broken. yadm can help you determine what changed or simply
revert all of your changes. revert all of your changes.
**yadm** is like having a version of Git, that only operates on your dotfiles. yadm is like having a version of Git, that only operates on your dotfiles.
If you know how to use Git, you already know how to use yadm. If you know how to use Git, you already know how to use yadm.
* It doesn't matter if your current directory is another Git-managed repository * It doesn't matter if your current directory is another Git-managed repository
* You don't have to move your dotfiles, or have them symlinked from another * You don't have to move your dotfiles, or have them symlinked from another
location. location.
* **yadm** automatically inherits all of Git's features, allowing you to branch, * yadm automatically inherits all of Git's features, allowing you to branch,
merge, rebase, use submodules, etc. merge, rebase, use submodules, etc.
As so many others, I started out with a repository of dotfiles and a few scripts As so many others, I started out with a repository of dotfiles and a few scripts
to symbolically link them around my home directory. This quickly became to symbolically link them around my home directory. This quickly became
inadequate and I looked for solutions elsewhere. I've tried other tools, but I inadequate and I looked for solutions elsewhere. I've tried other tools, but I
didn't find all of the features I personally wished for in a single tool. This didn't find all of the features I personally wished for in a single tool. This
led to **yadm** being written with the following goals: led to yadm being written with the following goals:
* Use a single repository * Use a single repository
* Few dependencies * Few dependencies
@ -36,6 +36,6 @@ led to **yadm** being written with the following goals:
* Ability to encrypt and track confidential files * Ability to encrypt and track confidential files
* Stay out of the way and let Git do what it's good at * Stay out of the way and let Git do what it's good at
Follow these links to [install](install) **yadm** Follow these links to [install](install) yadm
or or
learn some simple steps for [getting started](getting_started) with **yadm**. learn some simple steps for [getting started](getting_started) with yadm.

View file

@ -6,7 +6,7 @@ permalink: /docs/install
## OSX ## OSX
**yadm** can be installed using [Homebrew](https://github.com/Homebrew/homebrew). yadm can be installed using [Homebrew](https://github.com/Homebrew/homebrew).
``` ```
brew install yadm brew install yadm
@ -18,11 +18,11 @@ Several yum repositories are on Copr. Follow this link for [repositories and ins
## Ubuntu/Debian ## Ubuntu/Debian
A version of **yadm** is available via standard package repositories. Use `apt-get` to install. A version of yadm is available via standard package repositories. Use `apt-get` to install.
## Arch Linux ## Arch Linux
**yadm** is available in the Arch User Repos and can be installed with AUR helper or Makepkg. yadm is available in the Arch User Repos and can be installed with AUR helper or Makepkg.
``` ```
yaourt -S yadm-git yaourt -S yadm-git
@ -30,7 +30,7 @@ yaourt -S yadm-git
## Gentoo Linux ## Gentoo Linux
**yadm** is available in the main gentoo portage tree, simply use `emerge` to install it. yadm is available in the main gentoo portage tree, simply use `emerge` to install it.
``` ```
emerge -atv app-admin/yadm emerge -atv app-admin/yadm
@ -38,7 +38,7 @@ emerge -atv app-admin/yadm
## Void Linux ## Void Linux
**yadm** is available in the official repository, simply use `xbps-install` to install it. yadm is available in the official repository, simply use `xbps-install` to install it.
``` ```
xbps-install yadm xbps-install yadm
@ -46,7 +46,7 @@ xbps-install yadm
## FreeBSD ## FreeBSD
**yadm** is available in the FreeBSD ports. Use `pkg` to install it from a prebuilt binary package: yadm is available in the FreeBSD ports. Use `pkg` to install it from a prebuilt binary package:
``` ```
pkg install yadm pkg install yadm
@ -54,7 +54,7 @@ pkg install yadm
## Download ## Download
You *can* simply download the **yadm** script and put it into your `$PATH`. Something like this: You *can* simply download the yadm script and put it into your `$PATH`. Something like this:
``` ```
curl -fLo /usr/local/bin/yadm https://github.com/TheLocehiliosan/yadm/raw/master/yadm && chmod a+x /usr/local/bin/yadm curl -fLo /usr/local/bin/yadm https://github.com/TheLocehiliosan/yadm/raw/master/yadm && chmod a+x /usr/local/bin/yadm
@ -64,7 +64,7 @@ Of course, you can change the file paths above to be appropriate for your `$PATH
## Clone ## Clone
You might wish to clone the **yadm** project and symlink `yadm` into your You might wish to clone the yadm project and symlink `yadm` into your
`$PATH`. `$PATH`.
``` ```
@ -72,13 +72,13 @@ git clone https://github.com/TheLocehiliosan/yadm.git ~/.yadm-project
ln -s ~/.yadm-project/yadm ~/bin/yadm ln -s ~/.yadm-project/yadm ~/bin/yadm
``` ```
Now you can pull the latest updates to **yadm** using Git. Again, adjust the Now you can pull the latest updates to yadm using Git. Again, adjust the
file paths above to be appropriate for your `$PATH` and situation. file paths above to be appropriate for your `$PATH` and situation.
## Submodule ## Submodule
If you are comfortable with how Git submodules work, another option is to add If you are comfortable with how Git submodules work, another option is to add
the **yadm** project as a submodule and symlink `yadm` into your `$PATH`. the yadm project as a submodule and symlink `yadm` into your `$PATH`.
``` ```
cd ~ cd ~
@ -95,7 +95,7 @@ When using submodules, you need to initialize them each time you do a fresh
yadm submodule update --init --recursive yadm submodule update --init --recursive
``` ```
Updating to a newer version of **yadm** would use commands similar to this. Updating to a newer version of yadm would use commands similar to this.
``` ```
cd ~/.yadm-project cd ~/.yadm-project

View file

@ -2,7 +2,7 @@
title: "Getting Started" title: "Getting Started"
permalink: /docs/getting_started permalink: /docs/getting_started
--- ---
Starting out with **yadm** should be just a few easy steps. Starting out with yadm should be just a few easy steps.
### If you don't currently have a repository ### If you don't currently have a repository
Start out with an empty local repository Start out with an empty local repository
@ -17,7 +17,7 @@ Eventually you will want to push the local repo to a remote.
yadm push -u origin master yadm push -u origin master
### If you have an existing remote repository ### If you have an existing remote repository
Clone your existing repo using **yadm**. Clone your existing repo using yadm.
yadm clone <url> yadm clone <url>
yadm status yadm status

View file

@ -3,23 +3,23 @@ title: "Common Commands"
permalink: /docs/common_commands permalink: /docs/common_commands
--- ---
Most of these operations will look like Git commands; because they are. Most of these operations will look like Git commands; because they are.
**yadm** wraps Git, allowing it to perform all of Git's operations. The yadm wraps Git, allowing it to perform all of Git's operations. The
difference is your `$HOME` directory becomes the working directory, and you can difference is your `$HOME` directory becomes the working directory, and you can
run the commands from any directory. run the commands from any directory.
Commands below which are special to **yadm** are denoted with Commands below which are special to yadm are denoted with
<i class="fa fa-fw fa-asterisk" aria-hidden="true"></i>, <i class="fa fa-fw fa-asterisk" aria-hidden="true"></i>,
and those which are passed directly through to Git are denoted with and those which are passed directly through to Git are denoted with
<i class="fab fa-fw fa-git-square" aria-hidden="true"></i>. <i class="fab fa-fw fa-git-square" aria-hidden="true"></i>.
<i class="fa fa-fw fa-asterisk" aria-hidden="true"></i> `man yadm` <i class="fa fa-fw fa-asterisk" aria-hidden="true"></i> `man yadm`
: Display **yadm**'s : Display yadm's
[manual](https://github.com/TheLocehiliosan/yadm/blob/master/yadm.md). [manual](https://github.com/TheLocehiliosan/yadm/blob/master/yadm.md).
<i class="fab fa-fw fa-git-square" aria-hidden="true"></i> `yadm status` <i class="fab fa-fw fa-git-square" aria-hidden="true"></i> `yadm status`
: Show the repository status; added, changed, removed files. Because a `$HOME` : Show the repository status; added, changed, removed files. Because a `$HOME`
directory often more than only dotfiles, by default directory often more than only dotfiles, by default
**yadm** ignores untracked files when displaying status. yadm ignores untracked files when displaying status.
<i class="fab fa-fw fa-git-square" aria-hidden="true"></i> `yadm push`, `yadm fetch` <i class="fab fa-fw fa-git-square" aria-hidden="true"></i> `yadm push`, `yadm fetch`
: Send or retrive commits to/from your remote repository . : Send or retrive commits to/from your remote repository .
@ -36,7 +36,7 @@ message or add staged changes to the previous commit.
commit. commit.
<i class="fa fa-fw fa-asterisk" aria-hidden="true"></i> `yadm list -a` <i class="fa fa-fw fa-asterisk" aria-hidden="true"></i> `yadm list -a`
: Print a list of files managed by **yadm**. The -a option will cause all managed : Print a list of files managed by yadm. The -a option will cause all managed
files to be listed. Otherwise, the list will only include files from the files to be listed. Otherwise, the list will only include files from the
current directory or below. current directory or below.

View file

@ -5,11 +5,11 @@ permalink: /docs/bootstrap
Often there is more to set up once your dotfiles repository has been cloned. For Often there is more to set up once your dotfiles repository has been cloned. For
example, if your repository has submodules, you may wish to initialize them. On example, if your repository has submodules, you may wish to initialize them. On
MacOS, you may wish to install **Homebrew** and process a `.Brewfile`. These types MacOS, you may wish to install Homebrew and process a `.Brewfile`. These types
of additional steps are generally referred to as "bootstrapping". of additional steps are generally referred to as "bootstrapping".
Though everyone may have a different set of bootstrap operations they need to Though everyone may have a different set of bootstrap operations they need to
perform, **yadm** has a standard command for executing them. perform, yadm has a standard command for executing them.
yadm bootstrap yadm bootstrap
@ -17,7 +17,7 @@ This command will execute the program named `$HOME/.yadm/bootstrap`. You must
provide this program yourself, and it must be made executable. But those are the provide this program yourself, and it must be made executable. But those are the
only constraints. only constraints.
After **yadm** successfully clones a repository, if there is a bootstrap program After yadm successfully clones a repository, if there is a bootstrap program
available, it will offer to run it for you. available, it will offer to run it for you.
Found .yadm/bootstrap Found .yadm/bootstrap
@ -37,7 +37,7 @@ in Bash, but you can use any executable file as a bootstrap.
### Initialize submodules ### Initialize submodules
If you've added repositories as submodules for the **yadm** repository, you can If you've added repositories as submodules for the yadm repository, you can
initialize them after a successful clone. initialize them after a successful clone.
```bash ```bash
@ -105,10 +105,10 @@ if [ -f "$HOME/.terminfo/custom.terminfo" ]; then
fi fi
``` ```
### Update the **yadm** repo origin URL ### Update the yadm repo origin URL
You might initially clone your repo using `https`, but ssh configurations may be You might initially clone your repo using `https`, but ssh configurations may be
available after cloning. If so, you could update the **yadm** repo origin to use available after cloning. If so, you could update the yadm repo origin to use
`ssh` instead. `ssh` instead.
```bash ```bash
@ -120,9 +120,9 @@ yadm remote set-url origin "git@github.com:MyUser/dotfiles.git"
### Install [vim](http://www.vim.org/) plugins managed with [vim-plug](https://github.com/junegunn/vim-plug) ### Install [vim](http://www.vim.org/) plugins managed with [vim-plug](https://github.com/junegunn/vim-plug)
**vim-plug** can be used in your `.vimrc` to enable plugins. The example here will vim-plug can be used in your `.vimrc` to enable plugins. The example here will
automatically download **vim-plug** and run the `:PlugInstall` command if automatically download vim-plug and run the `:PlugInstall` command if
**vim-plug** is missing when **vim** starts. vim-plug is missing when vim starts.
```vim ```vim
" download vim-plug if missing " download vim-plug if missing
@ -154,7 +154,7 @@ endif
``` ```
You can enhance this scheme by having your bootstrap program initialize You can enhance this scheme by having your bootstrap program initialize
**vim-plug** when you clone, instead of when you first run **vim**. This example vim-plug when you clone, instead of when you first run vim. This example
will install any new plugins, and also remove any plugins now deleted from your will install any new plugins, and also remove any plugins now deleted from your
`.vimrc`. `.vimrc`.

View file

@ -10,9 +10,9 @@ features and strategies for dealing with those occasions.
## Symlink alternates ## Symlink alternates
It can be useful to have an automated way of choosing an alternate version of a It can be useful to have an automated way of choosing an alternate version of a
file for a different operating system, host, or user. **yadm** implements a file for a different operating system, host, or user. yadm implements a
feature which will automatically create a symbolic link to the appropriate feature which will automatically create a symbolic link to the appropriate
version of a file, as long as you follow a specific naming convention. **yadm** can version of a file, as long as you follow a specific naming convention. yadm can
detect files with names ending in: detect files with names ending in:
| `##` | Default file linked | | `##` | Default file linked |
@ -24,10 +24,10 @@ detect files with names ending in:
| `##OS.HOSTNAME` | Matching OS & Hostname | | `##OS.HOSTNAME` | Matching OS & Hostname |
| `##OS.HOSTNAME.USER` | Matching OS, Hostname, & User | | `##OS.HOSTNAME.USER` | Matching OS, Hostname, & User |
If there are any files managed by **yadm**'s repository, or listed in If there are any files managed by yadm's repository, or listed in
`$HOME/.yadm/encrypt`, which match this naming convention, symbolic links will `$HOME/.yadm/encrypt`, which match this naming convention, symbolic links will
be created for the most appropriate version. This may best be demonstrated by be created for the most appropriate version. This may best be demonstrated by
example. Assume the following files are managed by **yadm**'s repository: example. Assume the following files are managed by yadm's repository:
$HOME/path/example.txt## $HOME/path/example.txt##
$HOME/path/example.txt##Work $HOME/path/example.txt##Work
@ -38,12 +38,12 @@ example. Assume the following files are managed by **yadm**'s repository:
$HOME/path/example.txt##Linux.host1 $HOME/path/example.txt##Linux.host1
$HOME/path/example.txt##Linux.host2 $HOME/path/example.txt##Linux.host2
If running on a Macbook named `host2`, **yadm** will create a symbolic link which If running on a Macbook named `host2`, yadm will create a symbolic link which
looks like this: looks like this:
`$HOME/path/example.txt``$HOME/path/example.txt##Darwin.host2` `$HOME/path/example.txt``$HOME/path/example.txt##Darwin.host2`
However, on another Macbook named `host3`, **yadm** will create a symbolic link However, on another Macbook named `host3`, yadm will create a symbolic link
which looks like this: which looks like this:
`$HOME/path/example.txt``$HOME/path/example.txt##Darwin` `$HOME/path/example.txt``$HOME/path/example.txt##Darwin`
@ -71,7 +71,7 @@ then no link will be created.
| **HOSTNAME** by running `hostname` and removing any domain. | **HOSTNAME** by running `hostname` and removing any domain.
| **USER** by running `id -u -n`. | **USER** by running `id -u -n`.
**yadm** will automatically create these links by default. This can be disabled using the `yadm.auto-alt` configuration. Even if disabled, links can be manually created by running **yadm** alt. yadm will automatically create these links by default. This can be disabled using the `yadm.auto-alt` configuration. Even if disabled, links can be manually created by running yadm alt.
## Wildcards ## Wildcards
@ -87,7 +87,7 @@ $HOME/path/example.txt##%.%.harvey
Class is a special value which is stored locally on each host (inside the local Class is a special value which is stored locally on each host (inside the local
repository). To use alternate symlinks using `CLASS`, you must set the value of repository). To use alternate symlinks using `CLASS`, you must set the value of
class using the configuration `local.class`. This is set like any other **yadm** class using the configuration `local.class`. This is set like any other yadm
configuration—with the `yadm config` command. The following sets the `CLASS` to configuration—with the `yadm config` command. The following sets the `CLASS` to
be "Work". be "Work".
@ -100,7 +100,7 @@ overridden using the configuration options `local.os`, `local.hostname`, and
## Jinja templates ## Jinja templates
If the `envtpl` command is available, Jinja templates will also be processed to If the `envtpl` command is available, Jinja templates will also be processed to
create or overwrite real files. **yadm** will treat files ending in `##yadm.j2` create or overwrite real files. yadm will treat files ending in `##yadm.j2`
as Jinja templates. During processing, the following variables are set according as Jinja templates. During processing, the following variables are set according
to the rules explained in the [Alternates section](alternates#symlink-alternates): to the rules explained in the [Alternates section](alternates#symlink-alternates):
@ -110,7 +110,7 @@ to the rules explained in the [Alternates section](alternates#symlink-alternates
* `YADM_USER` * `YADM_USER`
In addition `YADM_DISTRO` is exposed as the value of `lsb_release -si` if In addition `YADM_DISTRO` is exposed as the value of `lsb_release -si` if
**lsb_release** is locally available. lsb_release is locally available.
For example, a file named `whatever##yadm.j2` with the following content For example, a file named `whatever##yadm.j2` with the following content
@ -168,7 +168,7 @@ fi
However, sometimes the type of file you are using doesn't allow for this type of However, sometimes the type of file you are using doesn't allow for this type of
logic. If a configuration can do an "_include_", you can include a specific logic. If a configuration can do an "_include_", you can include a specific
alternate version using **yadm**. Consider these three files: alternate version using yadm. Consider these three files:
`.gitconfig` `.gitconfig`
@ -197,6 +197,6 @@ alternate version using **yadm**. Consider these three files:
``` ```
Configuring Git this way includes `.gitconfig.local` in the standard Configuring Git this way includes `.gitconfig.local` in the standard
`.gitconfig`. **yadm** will automatically link the correct version based on the `.gitconfig`. yadm will automatically link the correct version based on the
operating system. The bulk of your configurations can go in a single file, and operating system. The bulk of your configurations can go in a single file, and
you just put the exceptions in OS-specific files. you just put the exceptions in OS-specific files.

View file

@ -4,7 +4,7 @@ permalink: /docs/encryption
--- ---
It can be useful to manage confidential files, like SSH keys, across multiple It can be useful to manage confidential files, like SSH keys, across multiple
systems. However, doing so would put plain text data into a Git repository, systems. However, doing so would put plain text data into a Git repository,
which often resides on a public system. **yadm** implements a feature which can which often resides on a public system. yadm implements a feature which can
make it easy to encrypt and decrypt a set of files so the encrypted version can make it easy to encrypt and decrypt a set of files so the encrypted version can
be maintained in the Git repository. This feature will only work if the gpg be maintained in the Git repository. This feature will only work if the gpg
command is available. command is available.
@ -19,7 +19,7 @@ To use this feature, a list of patterns must be created and saved as
The `yadm encrypt` command will find all files matching the patterns, and The `yadm encrypt` command will find all files matching the patterns, and
prompt for a password. Once a password has confirmed, the matching files will be prompt for a password. Once a password has confirmed, the matching files will be
encrypted and saved as `$HOME/.yadm/files.gpg`. The patterns and files.gpg encrypted and saved as `$HOME/.yadm/files.gpg`. The patterns and files.gpg
should be added to the **yadm** repository so they are available across multiple should be added to the yadm repository so they are available across multiple
systems. systems.
yadm add .yadm/encrypt yadm add .yadm/encrypt

View file

@ -8,11 +8,11 @@ permalink: /docs/faq
### I just cloned my repository and conflicting data was overwritten. Why? ### I just cloned my repository and conflicting data was overwritten. Why?
Prior to cloning your repository, files managed by **yadm** already existed. For Prior to cloning your repository, files managed by yadm already existed. For
example, imagine you are logged into a system and `$HOME/.bash_profile` already example, imagine you are logged into a system and `$HOME/.bash_profile` already
exists. If you then clone your **yadm** repository—which also contains exists. If you then clone your yadm repository—which also contains
`.bash_profile`—then you will likely get a conflict. Since version 1.07, `.bash_profile`—then you will likely get a conflict. Since version 1.07,
**yadm** responds by "stashing" these conflicts. To view the stashed data, you can yadm responds by "stashing" these conflicts. To view the stashed data, you can
run `yadm stash show -p` from within your `$HOME` directory. If you want to run `yadm stash show -p` from within your `$HOME` directory. If you want to
restore the stashed data, you can run `yadm stash apply` from within your restore the stashed data, you can run `yadm stash apply` from within your
`$HOME` directory. `$HOME` directory.
@ -22,7 +22,7 @@ restore the stashed data, you can run `yadm stash apply` from within your
Whenever a Git commit is generated, Git requires information about the author of Whenever a Git commit is generated, Git requires information about the author of
the commit. This can be configured via the `git config` command. Usually the the commit. This can be configured via the `git config` command. Usually the
best approach is to configure this information globally, and then manage your best approach is to configure this information globally, and then manage your
global Git configuration via **yadm**. This allows the configuration to follow global Git configuration via yadm. This allows the configuration to follow
you wherever your dotfiles live. you wherever your dotfiles live.
``` ```
@ -32,20 +32,20 @@ git config --global "user.name" "Your Name"
yadm add ~/.gitconfig yadm add ~/.gitconfig
``` ```
However, if you want commits to your **yadm** repo to use a different author, However, if you want commits to your yadm repo to use a different author,
you can configure these settings in the **yadm** repo itself. you can configure these settings in the yadm repo itself.
``` ```
yadm gitconfig "user.email" "alternate-email@domain" yadm gitconfig "user.email" "alternate-email@domain"
yadm gitconfig "user.name" "Alternate Name" yadm gitconfig "user.name" "Alternate Name"
``` ```
Note: Configuring these settings directly in the **yadm** repo will require you Note: Configuring these settings directly in the yadm repo will require you
to configure it each time you clone the repo. to configure it each time you clone the repo.
### How can I display untracked files with a `yadm status` command? ### How can I display untracked files with a `yadm status` command?
By default, **yadm** is configured to ignore untracked files when displaying a By default, yadm is configured to ignore untracked files when displaying a
status. You can use the `-u` paramter on the status command to alter how status. You can use the `-u` paramter on the status command to alter how
untracked files are treated. `-unormal` will show untracked files and untracked files are treated. `-unormal` will show untracked files and
directories. directories.
@ -55,7 +55,7 @@ yadm status -unormal
``` ```
If you want to change the default treatment, you can change this configuration If you want to change the default treatment, you can change this configuration
on the **yadm** repository itself. on the yadm repository itself.
``` ```
yadm gitconfig --unset status.showUntrackedFiles yadm gitconfig --unset status.showUntrackedFiles
@ -71,7 +71,7 @@ yadm add -u :/
(Starting with Git 2.0, the `:/` is not necessary) (Starting with Git 2.0, the `:/` is not necessary)
### How can I change the URL of my remote **yadm** repository? ### How can I change the URL of my remote yadm repository?
This is done the same way you change the URL of any Git repository. This is done the same way you change the URL of any Git repository.
@ -79,18 +79,18 @@ This is done the same way you change the URL of any Git repository.
yadm remote set-url origin <NEW-URL> yadm remote set-url origin <NEW-URL>
``` ```
This could be useful if you manage your ssh keys in the **yadm** repository. This could be useful if you manage your ssh keys in the yadm repository.
That could make it difficult to initially clone the repository using the `ssh` That could make it difficult to initially clone the repository using the `ssh`
protocol. You can start by cloning the repository using the `https` protocol protocol. You can start by cloning the repository using the `https` protocol
(and providing a password), and then change the repository's URL after you've (and providing a password), and then change the repository's URL after you've
decrypted your ssh keys. decrypted your ssh keys.
### I've customized **yadm** configurations (stored in `~/.yadm/config`). Should I add that to my repository? ### I've customized yadm configurations (stored in `~/.yadm/config`). Should I add that to my repository?
Certainly. That is a good way to carry your **yadm** configurations around (just Certainly. That is a good way to carry your yadm configurations around (just
like the rest of your dotfiles). like the rest of your dotfiles).
### Can you point to any example **yadm** managed repositories? ### Can you point to any example yadm managed repositories?
[This page](examples) contains some examples. [This page](examples) contains some examples.
@ -108,10 +108,10 @@ clone your repository. Read [bootstrap](bootstrap) for more details.
## Encryption ## Encryption
### Can I use **yadm** without **gpg**? ### Can I use yadm without gpg?
Of course. You only need `gpg` installed if you plan on using the Of course. You only need `gpg` installed if you plan on using the
encrypt/decrypt features. **yadm** will tell you if it is missing a dependency encrypt/decrypt features. yadm will tell you if it is missing a dependency
for any command. for any command.
### Should I `yadm add` my `.yadm/encrypt` file? ### Should I `yadm add` my `.yadm/encrypt` file?
@ -123,13 +123,13 @@ you when you clone your repository.
No, you should not. Files you want encrypted should be added to the file No, you should not. Files you want encrypted should be added to the file
`.yadm/files.gpg` using the `yadm encrypt` command. Then `.yadm/files.gpg` `.yadm/files.gpg` using the `yadm encrypt` command. Then `.yadm/files.gpg`
should be added to the **yadm** repository. This way, only an encrypted should be added to the yadm repository. This way, only an encrypted
collection of those files are put into the repository. After cloning or updating collection of those files are put into the repository. After cloning or updating
your repository, you can use `yadm decrypt` to extract those files from your repository, you can use `yadm decrypt` to extract those files from
`.yadm/files.gpg`. See the `.yadm/files.gpg`. See the
[encryption help](encryption) for more details. [encryption help](encryption) for more details.
### I modified an encrypted file, but **yadm** doesn't show any modifications. Why? ### I modified an encrypted file, but yadm doesn't show any modifications. Why?
If you changed files which are matched by `.yadm/encrypt`, you must re-run `yadm If you changed files which are matched by `.yadm/encrypt`, you must re-run `yadm
encrypt` to generate a new version of `.yadm/files.gpg`. Then `.yadm/files.gpg` encrypt` to generate a new version of `.yadm/files.gpg`. Then `.yadm/files.gpg`
@ -139,17 +139,17 @@ can be added to a new commit.
If you get the error If you get the error
`command get_passphrase failed: Inappropriate ioctl for device` `command get_passphrase failed: Inappropriate ioctl for device`
when running `yadm encrypt`, **gpg** is having trouble identifying the tty to when running `yadm encrypt`, gpg is having trouble identifying the tty to
use. The environment variable `GPG_TTY` can be used to help **gpg** out. Export use. The environment variable `GPG_TTY` can be used to help gpg out. Export
this variable to your shell in your login scripts. this variable to your shell in your login scripts.
``` ```
export GPG_TTY=$(tty) export GPG_TTY=$(tty)
``` ```
### Can I use **yadm** and **git-crypt**? ### Can I use yadm and git-crypt?
There is an experimental version of **yadm** which can use **git-crypt**. You There is an experimental version of yadm which can use git-crypt. You
can find it in the [git-crypt-support branch]( can find it in the [git-crypt-support branch](
https://github.com/TheLocehiliosan/yadm/commits/git-crypt-support https://github.com/TheLocehiliosan/yadm/commits/git-crypt-support
). See the ). See the
@ -159,27 +159,27 @@ https://github.com/TheLocehiliosan/yadm/commit/efb7fd16612fe650b1286f0c696696f41
## Comparisons ## Comparisons
### How does **yadm** differ from **homeshick**? ### How does yadm differ from homeshick?
**yadm** and **homeshick** are both written in Bash, with very limited yadm and homeshick are both written in Bash, with very limited
dependencies. However, **homeshick** works by symlinking data from a repository dependencies. However, homeshick works by symlinking data from a repository
working directory into your `$HOME` directory. **yadm** instead uses your working directory into your `$HOME` directory. yadm instead uses your
`$HOME` directory _as_ its working directory. **homeshick** allows for multiple `$HOME` directory _as_ its working directory. homeshick allows for multiple
"castles" to be linked into `$HOME`, while **yadm** is designed to work with a "castles" to be linked into `$HOME`, while yadm is designed to work with a
single repository. **homeshick** requires you to change into the "castle" single repository. homeshick requires you to change into the "castle"
directory before performing any Git based commands. **yadm** allows you to directory before performing any Git based commands. yadm allows you to
perform operations regardless of your location. **yadm** also includes unique perform operations regardless of your location. yadm also includes unique
features to encrypt private data, and symlink alternate versions of files based features to encrypt private data, and symlink alternate versions of files based
on OS type or hostname. on OS type or hostname.
### How does **yadm** differ from **vcsh**? ### How does yadm differ from vcsh?
**yadm** and **vcsh** both work as a filters for standard Git commands. Both yadm and vcsh both work as a filters for standard Git commands. Both
also use your `$HOME` directory _as_ the repository's working directory. also use your `$HOME` directory _as_ the repository's working directory.
However, **vcsh** is designed to work with multiple repositories, **yadm** However, vcsh is designed to work with multiple repositories, yadm
instead uses a single repository. **vcsh** requires you to specify which instead uses a single repository. vcsh requires you to specify which
repository you want to operate on, while **yadm** only operates on one. If you repository you want to operate on, while yadm only operates on one. If you
want to use Git submodules, you _may_ have trouble using **vcsh**. This is want to use Git submodules, you _may_ have trouble using vcsh. This is
because only one repository can be the owner of the `.gitmodules` file. because only one repository can be the owner of the `.gitmodules` file.
**yadm** also includes unique features to encrypt private data, and symlink yadm also includes unique features to encrypt private data, and symlink
alternate versions of files based on OS type or hostname. alternate versions of files based on OS type or hostname.

View file

@ -4,7 +4,7 @@ permalink: /docs/examples
--- ---
<a name=""></a><!-- Anchor "#" used at the ends of pagination --> <a name=""></a><!-- Anchor "#" used at the ends of pagination -->
Need some inspiration? Here are some public dotfiles repositories managed by Need some inspiration? Here are some public dotfiles repositories managed by
**yadm**. Drop me a line if you have a dotfiles repo you'd like added to this yadm. Drop me a line if you have a dotfiles repo you'd like added to this
list. list.
* [Search github for repos tagged with `yadm`](https://github.com/search?q=topic%3Ayadm&type=Repositories) * [Search github for repos tagged with `yadm`](https://github.com/search?q=topic%3Ayadm&type=Repositories)

View file

@ -36,10 +36,10 @@ feature_row:
url: /docs/overview url: /docs/overview
excerpt: ' excerpt: '
If you know how to use Git, you already know how to use **yadm**. If you know how to use Git, you already know how to use yadm.
**yadm** helps you maintain a single repository of dotfiles, while keeping yadm helps you maintain a single repository of dotfiles, while keeping
them where they belong---in `$HOME`. them where they belong---in `$HOME`.
Anything you can do with Git, you can do using **yadm**. Anything you can do with Git, you can do using yadm.
' '
- title: Alternate Files - title: Alternate Files
@ -51,7 +51,7 @@ feature_row:
excerpt: ' excerpt: '
Sometimes you need different configurations on different systems. Sometimes you need different configurations on different systems.
**yadm** makes it possible to use alternate versions of files based on yadm makes it possible to use alternate versions of files based on
the OS or hostname of the system. the OS or hostname of the system.
' '
@ -64,7 +64,7 @@ feature_row:
excerpt: ' excerpt: '
Configurations occasionally include secrets such as passwords, Configurations occasionally include secrets such as passwords,
encryption keys, or other sensitive information. **yadm** allows you to encryption keys, or other sensitive information. yadm allows you to
add such files to an encrypted archive, which can be maintained add such files to an encrypted archive, which can be maintained
alongside your other configurations. alongside your other configurations.
@ -78,7 +78,7 @@ feature_row:
excerpt: ' excerpt: '
Define your own instructions to complete your dotfiles installation. Define your own instructions to complete your dotfiles installation.
If provided, **yadm** can execute your custom program immediately If provided, yadm can execute your custom program immediately
following a successful clone. following a successful clone.
' '