# sadedot
Backup all your dotfiles (and easily deploy them on another machine).
## Table of contents
- [Installation ](#installation-)
- [Usage ](#usage-)
- [Optional dependencies ](#optionaldependencies-)
- [Updating ](#updating-)
- [Contributing ](#contributing-)
- [License ](#license-)
## Installation
This repo is supposed to be used as a submodule. So, if you already have a git repo with your dotfiles:
```bash
git submodule add git@git.slc.ar:slococo/sadedot.git
git submodule update --init
```
And if you don't, you can [fork][1] my dotfiles repo on git.
## Usage
You have to move all your dotfiles to a folder named `dotfiles` (see [my repo][3] for an example) and then the script will do the symbolic links. Doing it this way, you can now push them to your git repo (so you have a backup of them).
You should note that all of these dotfiles (files or folders) will be symlinked in `$HOME`. So, if you want to symlink, for example, something in `/etc`, you have to put it in the `dotfiles/other` folder. Here you have to be careful as they will be installed in `/`. You can see an example [here][2].
So, to run the script:
```bash
sh scripts/bootstrap.sh
```
By default, the script will run with `dialog`. However, the script can use either `dialog` or `whiptail` (`libnewt`) as a way to display dialog boxes, so if you want to use `whiptail`, you must use `-w` as a parameter.
Also, for compatibility reasons, the script will choose not to use `dialog` or `whiptail` if you don't have them installed. You can force this using the `-t` parameter.
Finally, you can run the script with `-l` if you want to print the log to the `sadedot.log` file (it will be created inside the `sadedot` folder).
Note that you can add shell scripts to a folder named `scripts` (see [my repo][3]) if you want to run them when `scripts/bootstrap.sh` is run. By default, it will not run these scripts, so you must use the `-p` flag (they will run at the end).
As an example, I will show [my repo][3] directories in a tree-like format (note that the folder named `sadedot` is this repository as a submodule):
```
.
├── dotfiles
│ └── ...
├── sadedot
│ └── ...
└── scripts
└── ...
```
## Optional dependencies
You can install `dialog` (recommended) or `libnewt` for a better experience, but they are not required.
## Updating
To keep the submodule up to date, you need to run:
```bash
git submodule foreach git pull
```
## Contributing
PRs are welcome.
## License
[MIT](https://git.slc.ar/slococo/sadedot/raw/branch/master/README.md)
[1]: https://git.slc.ar/slococo/cdotfis/fork
[2]: https://git.slc.ar/slococo/cdotfis/tree/master/dotfiles/other
[3]: https://git.slc.ar/slococo/cdotfis