app | ||
bin | ||
docs | ||
dotfiles | ||
etc | ||
external | ||
grub | ||
help | ||
install | ||
lib | ||
spec | ||
src | ||
.gitignore | ||
.travis.yml | ||
install.sh | ||
LICENSE.md | ||
Makefile | ||
README.md | ||
shard.lock | ||
shard.yml |
New Start
Vim is my editor, *nix is my IDE.
TODO: Put images here
New Start is built on top of Arch GNU/Linux and consists of my dotfiles, install scripts, help files, and custom software.
Before You Begin
These are some important things I believe any potential user of New Start should know.
- Linux is not an operating system. It is simply a kernel used as part of an operating system. Do not say that you use "Linux"; rather, you use the GNU system with Linux, or GNU plus Linux. All the so-called Linux distributions are actually distributions of GNU/Linux.
- Arch GNU/Linux is rolling-release. You will always have the latest software. There is no such thing as having to install a new version of Arch.
- Free software gives you complete control over your computing. If something doesn't work, it's more often than not user error. You no longer have the luxury of blaming your computer for "not working".
- Keep it simple. At the end of the day, you only need to use your computer for a few specific tasks, such as listening to music, writing software, sending messages, and using the internet. Don't overcomplicate things.
This system was built with reproducability in mind. The entire system resolves around being able to install it from scratch and have the exact same configuration as before.
Additionally, the design philosophy behind this system is quite different than what you'd expect if you're coming from a traditional point-click system. There is no such thing as "clicking the close button" here, or clicking anything for that matter.
Once mastered, the interface should not get in the way. Everything just works.
Getting Started
The size of this repository may seem intimidating at first, but making use of New Start is really simple. I explain each directory in detail below, as well as link some files that you may like.
If you're just here for the dots, skip to the dotfiles/ section. If, however, you want to dig deeper instead then continue reading.
app/
This directory holds all the files I use for my local server, with the exception of the "controller" itself (see src/server.cr
).
views/index.ecr
- Simple home page, clean and elegant
dotfiles/
I know how frustrating it is to see a setup and not have access to the dotfiles. I also know how frustrating it is to go through dotfiles with default config settings everywhere or dotfiles with little to no documentation at all.
My goal here is simple: use as few config settings as possible required to make everything work, and document the settings that I do use. Your "config" file shouldn't be a man
page!
cmus/rc
fontconfig/fonts.conf
feh/keys
gtk-3.0/gtk.css
- mpv/
- polybar/
.zshrc
.zsh_aliases
.zsh_functions
.zprofile
.ctags
.dircolors
.mailcap
.tmux.conf
.xmodmap
etc/
All config files that don't have definite paths in ~
end up here.
userChrome.css
- A bare-minimum browser that emphasizes keyboard usageuser.js
- Settings to make using the browser a more pleasurable experience
help/
Help files are a way for me to keep track of all the useful commands I learn about certain software. They're compiled in easy-to-read files so I don't have to search the same thing over and over.
commands.md
- The majority of terminal commands I use on a daily basisgit.md
- There's a lot more to Git than you think (no pun intended)gpg.md
- Everything you need to know about GPGprofanity.md
- A primer on using XMPP with Profanityvim.md
- A complete reference to everything I know (and find worth mentioning) about vim
src/
This directory holds custom software that I made specifically for my use case. Feel free to use them for inspiration.
git-blame.cr
- A colorful version ofgit blame
maid.cr
- This program is in charge of managing all my dotfilesmktex.cr
- This program handles compiling my LaTeX files into PDF papers. It keeps intermediary files in a separate directory from everything elsepass.cr
- A simple password managerserver.cr
- Handles the logic behind my local servertheme.cr
- Easily change color schemes across everything, including polybar, termite, and open terminal windows. Support for base16 color schemes as well as custom color schemes
Note that you should run crystal docs
in the root directory if you want to view the documentation for these files in a nice format.
Other Directories
The other directories may not be as interesting to go through, but each one has a purpose.
bin/
- Output directory for compiled binaries fromsrc
docs/
- Output directory for compiled documentation fromsrc
external/
- Also known as "not my files", these files reside in the external directory so they don't count towards GitHub's language algorithmgrub/
- A nice theme for grubinstall/
- Scripts to automate installing the system with the Arch ISOpackages.sh
- All of the packages I use (and why) from the official repos
lib/
- Output directory for the libraries used bysrc
spec/
- Tests for the files insrc
to make sure that nothing breaks
Contributing
This is a big project; I may have let some things slip through such as typos or other errors. If you want to improve the help files or other parts of the project then please file an issue first. Pull requests are accepted, but I'd prefer if you made an issue first!
Many users mistakenly use "Linux" without knowing that they're actually using GNU. I was a victim of this. I used a variety of "Linux" distributions in the past and had no idea what a "GNU" even was. Please help spread the word about the GNU Project.
Free software is more than just gratis. We need to educate our population about free software. A lot of the software I preferred to use in the past was free software yet I never understood the true meaning of "free software" nor the philosophy behind it.