108 lines
2.6 KiB
Markdown
108 lines
2.6 KiB
Markdown
# homesick
|
|
|
|
[](https://git.hrafn.xyz/aether/gosick/actions/workflows/push-validation.yml)
|
|
[](https://git.hrafn.xyz/aether/gosick/actions/workflows/pr-validation.yml)
|
|
[](https://git.hrafn.xyz/aether/gosick/actions/workflows/tag-build-artifacts.yml)
|
|
[](https://s3.hrafn.xyz/aether-workflow-report-artefacts/gosick/branch/main/coverage.html)
|
|
|
|
Your home directory is your castle. Don't leave your dotfiles behind.
|
|
|
|
This repository now contains a Go implementation of Homesick. A dotfiles repository is called a castle and should contain a `home/` directory with files to link into your `$HOME`.
|
|
|
|
## Build
|
|
|
|
Build with just:
|
|
|
|
```bash
|
|
just go-build
|
|
```
|
|
|
|
Or directly with Go:
|
|
|
|
```bash
|
|
go build -o dist/gosick ./cmd/homesick
|
|
```
|
|
|
|
## Commands
|
|
|
|
Implemented commands:
|
|
|
|
- `clone URI [CASTLE_NAME]`
|
|
- `list`
|
|
- `show_path [CASTLE]`
|
|
- `status [CASTLE]`
|
|
- `diff [CASTLE]`
|
|
- `link [CASTLE]`
|
|
- `unlink [CASTLE]`
|
|
- `track FILE [CASTLE]`
|
|
- `pull [CASTLE]`
|
|
- `push [CASTLE]`
|
|
- `commit -m MESSAGE [CASTLE]`
|
|
- `destroy [CASTLE]`
|
|
- `cd [CASTLE]`
|
|
- `rc [CASTLE]`
|
|
- `version`
|
|
|
|
### rc behavior
|
|
|
|
- Runs executable scripts in `<castle>/.homesick.d/` in lexicographic order.
|
|
- Executes scripts with the castle root as the current working directory.
|
|
- Forwards script stdout/stderr to command output.
|
|
- If `<castle>/.homesickrc` exists and `<castle>/.homesick.d/parity.rb` does not, generates `parity.rb` before execution.
|
|
- Never overwrites an existing `parity.rb` wrapper.
|
|
|
|
Not yet implemented:
|
|
|
|
- `open`
|
|
- `exec`
|
|
- `exec_all`
|
|
- `generate`
|
|
|
|
## Outstanding Feature Checklist
|
|
|
|
Command parity:
|
|
|
|
- [x] `pull`
|
|
- [x] `push`
|
|
- [x] `commit`
|
|
- [x] `destroy`
|
|
- [x] `cd`
|
|
- [ ] `open`
|
|
- [ ] `exec`
|
|
- [ ] `exec_all`
|
|
- [ ] `generate`
|
|
|
|
Historical flag/behavior parity:
|
|
|
|
- [ ] `pull --all`
|
|
- [ ] `rc --force`
|
|
- [ ] Evaluate whether global `pretend`/`quiet` modes should be restored
|
|
|
|
## Behavior Suite
|
|
|
|
The repository includes a Docker-based behavior suite that validates filesystem and git outcomes for the implemented commands.
|
|
|
|
Run behavior suite:
|
|
|
|
```bash
|
|
just behavior
|
|
```
|
|
|
|
Verbose behavior suite output:
|
|
|
|
```bash
|
|
just behavior-verbose
|
|
```
|
|
|
|
## Testing
|
|
|
|
Run all Go tests:
|
|
|
|
```bash
|
|
just go-test
|
|
```
|
|
|
|
## License
|
|
|
|
See `LICENSE`.
|