Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/strugee/dots
Rcs, profiles, other dotfiles, I love 'em all
https://github.com/strugee/dots
configctl dotfiles emacs mutt shell zsh
Last synced: 3 months ago
JSON representation
Rcs, profiles, other dotfiles, I love 'em all
- Host: GitHub
- URL: https://github.com/strugee/dots
- Owner: strugee
- License: wtfpl
- Created: 2013-07-03T23:00:45.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2024-07-22T20:41:53.000Z (6 months ago)
- Last Synced: 2024-07-23T00:30:01.467Z (6 months ago)
- Topics: configctl, dotfiles, emacs, mutt, shell, zsh
- Language: Shell
- Size: 814 KB
- Stars: 12
- Watchers: 5
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
README
# dots
## Introduction
This repository contains my personal dotfiles. Most of it is geared towards a git-, Emacs-, and zsh-centric workflow. You'll also find some legacy files for e.g. bash that haven't been touched in ages.
This repository also contains a pretty useful script called `configctl`, which is used to manage all the files in this repository. It's very smart, fully automatic, and is pretty easy to understand (`head -25 configctl` will show a nice overview of the parameters, and you can get a nice help summary by executing `./configctl help`).
`configctl` knows how to:
* Link configurations into place
* Install tools in ~ from both git clones and tarballs
* Preinstall Emacs packages
* Migrate old configurations
* Precompile zsh scripts
* Check for common binaries that I expect to have available
* Perform other miscellaneous tasksTo put it another way, `configctl` knows how to bootstrap most of the environment I expect by itself, and it knows how to tell me what's missing for almost all of the rest.
`configctl` requires only POSIX, so it will run under almost any Unix under the sun.
## local-config
`configctl` has the capability to read in a local configuration file, `local-config`. With this file you can override the behavior of certain routines of `configctl`. `local-config` is written with one keyword per line. Here are the options:
| Option | Type | Description |
| ------------- | -------------------| -------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `no-ssh` | Configuration time | Specifies that `configctl check` should not warn if it cannot find a general-purpose SSH key. |
| `headless` | Configuration time | Specifies that `configctl check` should not warn if it cannot find programs that would only make sense to have under a graphical environment. |
| `no-nodejs` | Configuration time | Specifies that `configctl check` should assume that Node.js is not available. |
| `darwin` | Configuration time | Specifies that `configctl check` is running on a Darwin (macOS) system. Linux is assumed otherwise. |
| `secure` | Configuration time | Specifies that `configctl` is running in a high-security environment and should not attempt to download or warn (in `configctl check`) about unverified software. |
| `set-inotify` | Runtime | Specifies that `.profile` should set the maximum user inotify instances to 50,000 using `sudo`. |## License
Unless otherwise noted, the contents of this repository are licensed under [the WTFPL][1].
[1]: https://github.com/strugee/dots/blob/master/COPYING