My NixOS configuration with Nix Flakes, Home Manager, Stylix, and Hyprland.
Go to file
2017-12-25 21:44:43 -05:00
app Move serv/ to app/ 2017-12-21 20:08:17 -05:00
dotfiles Add colors.vim and split .vimrc into multiple files 2017-12-25 18:07:46 -05:00
etc Move user.js to etc/user.js and add other disabled content 2017-12-12 23:47:17 -05:00
external Fix spacing in normalize.css 2017-12-13 17:36:46 -05:00
help Add patch information to git.md 2017-12-19 23:47:44 -05:00
install Move grub/ to install/grub/ 2017-12-25 21:44:43 -05:00
spec Add base maid_spec.cr 2017-12-20 21:15:04 -05:00
src Remove output directories from the repository 2017-12-25 21:34:37 -05:00
.editorconfig Add .editorconfig 2017-12-22 23:22:00 -05:00
.gitignore Remove output directories from the repository 2017-12-25 21:34:37 -05:00
.travis.yml Add crystal spec to .travis.yml 2017-12-22 23:43:16 -05:00
install.sh Add base crystal-ctags installation to install.sh 2017-11-21 18:18:26 -05:00
LICENSE.md Add license 2017-10-23 00:11:29 -04:00
Makefile Add bin/theme to Makefile 2017-12-23 23:32:24 -05:00
README.md Add more links to README.md 2017-12-20 17:59:14 -05:00
shard.lock Add shard.lock 2017-12-21 18:53:32 -05:00
shard.yml Add shard.yml 2017-12-21 13:16:45 -05:00

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.

  1. 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.
  2. 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.
  3. 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".
  4. 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).

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!

etc/

All config files that don't have definite paths in ~ end up here.

  • userChrome.css - A bare-minimum browser that emphasizes keyboard usage
  • user.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 basis
  • git.md - There's a lot more to Git than you think (no pun intended)
  • gpg.md - Everything you need to know about GPG
  • profanity.md - A primer on using XMPP with Profanity
  • vim.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 of git blame
  • maid.cr - This program is in charge of managing all my dotfiles
  • mktex.cr - This program handles compiling my LaTeX files into PDF papers. It keeps intermediary files in a separate directory from everything else
  • pass.cr - A simple password manager
  • server.cr - Handles the logic behind my local server
  • theme.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 from src
  • docs/ - Output directory for compiled documentation from src
  • external/ - Also known as "not my files", these files reside in the external directory so they don't count towards GitHub's language algorithm
  • grub/ - A nice theme for grub
  • install/ - Scripts to automate installing the system with the Arch ISO
    • packages.sh - All of the packages I use (and why) from the official repos
  • lib/ - Output directory for the libraries used by src
  • spec/ - Tests for the files in src 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.