73 lines
2.7 KiB
Markdown
73 lines
2.7 KiB
Markdown
---
|
|
layout: page
|
|
title: sadedot
|
|
description: Backup all your dotfiles (and easily deploy them on another machine).
|
|
github: https://git.slc.ar/slococo/sadedot
|
|
importance: 2
|
|
category: personal
|
|
---
|
|
|
|
## Installation <a name="installation"></a>
|
|
|
|
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 <a name="usage"></a>
|
|
|
|
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 <a name="optionaldependencies"></a>
|
|
|
|
You can install `dialog` (recommended) or `libnewt` for a better experience, but they are not required.
|
|
|
|
## Updating <a name="updating"></a>
|
|
|
|
To keep the submodule up to date, you need to run:
|
|
|
|
```bash
|
|
git submodule foreach git pull
|
|
```
|
|
|
|
## Contributing <a name="contributing"></a>
|
|
PRs are welcome.
|
|
|
|
## License <a name="license"></a>
|
|
[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
|