mirror of
https://github.com/donovanglover/nix-config.git
synced 2025-01-23 14:18:37 +01:00
Clean up README.md with new format
This commit is contained in:
parent
39e1b8a49d
commit
f99cb6ca14
101
README.md
101
README.md
@ -1,10 +1,18 @@
|
||||
# New Start - Less is More.
|
||||
# New Start
|
||||
|
||||
> Vim is my editor, \*nix is my IDE.
|
||||
|
||||
TODO: Put images here
|
||||
|
||||
## Usage
|
||||
## Table of Contents
|
||||
|
||||
- [A Brief History](#a-brief-history)
|
||||
- [Design Goals](#design-goals)
|
||||
- [Usability Goals](#usability-goals)
|
||||
- [Getting Started](#getting-started)
|
||||
- [Contributing](#contributing)
|
||||
|
||||
## A Brief History
|
||||
|
||||
Some important things to note:
|
||||
|
||||
@ -13,79 +21,44 @@ Some important things to note:
|
||||
3. 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.
|
||||
4. You have complete control over your software. There is no need to insult your computer. If something doesn't work, it's more often than not user error.
|
||||
|
||||
### Design Goals
|
||||
## Getting Started
|
||||
|
||||
Simplicity. Minimalism. Elegance.
|
||||
Stuff you may want:
|
||||
|
||||
1. **Simplicity.** It should be trivial to find and edit the things you're looking for.
|
||||
2. **Reproducability.** It should be trivial to reconfigure all of your settings from a fresh install.
|
||||
3. **Minimal.** It should only have what you need and nothing else.
|
||||
- `app/` - All the files used to run my local server
|
||||
- `dotfiles/` - All the dotfiles used to configure the system
|
||||
- `etc/` - Other config files that don't exactly have definite paths
|
||||
- `userChrome.css` - A bare-minimum browser that emphasizes keyboard usage
|
||||
- `grub/` - A nice theme for grub
|
||||
- `help/` - All the important things I want to remember when using my system
|
||||
- `vim.md` - A complete reference to everything I know (and find worth mentioning) about vim
|
||||
- `src/` - Small programs I use to handle my specific needs
|
||||
|
||||
### Usability Goals
|
||||
Summary of the other directories:
|
||||
|
||||
1. **Everything just works.** There is no need to configure anything. You simply go through the installation and you're looking at an identical workspace as before.
|
||||
2. **Automation.** Important things like making backups and cleaning up should be automatic.
|
||||
3. **Virtualization.** It should be trivial to setup a fresh working environment in a brand new virtual machine.
|
||||
4. **Configuration is self-documenting.** It is trivial for someone to view and understand how the dotfiles work.
|
||||
- `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
|
||||
- `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
|
||||
|
||||
## Build from Source
|
||||
## Design Goals
|
||||
|
||||
**Important:** Do *not* attempt to run this script on your physical machine. This script was made for and has only been tested in a fresh new virtual machine running the Arch Linux ISO.
|
||||
1. **Simplicity.** It should be trivial to find and edit the things you're looking for; to get things done. Once mastered, the interface should not get in the way.
|
||||
2. **Reproducability.** It should be trivial to reproduce your previous environment from a fresh install.
|
||||
3. **Universality.** All functionality should be handled through the terminal.
|
||||
|
||||
Boot into the Arch Linux ISO. Then, run the following commands:
|
||||
## Usability Goals
|
||||
|
||||
```
|
||||
wget https://raw.githubusercontent.com/GloverDonovan/new-start/master/install.sh
|
||||
chmod +x install.sh
|
||||
./install.sh <HOSTNAME> <LOCALUSER>
|
||||
```
|
||||
|
||||
Replace `<HOSTNAME>` with your preferred hostname and `<LOCALUSER>` with the name of the user account to create.
|
||||
|
||||
The default password for your new account is the same as your username. Upon reboot, the X server should automatically start at login. Then:
|
||||
|
||||
1. Change the root password with `passwd`
|
||||
2. Change the local account password with `passwd <username>`
|
||||
|
||||
That's it! You're now ready to use your shiny new system!
|
||||
|
||||
The install includes a variety of languages by default, including C, C++, Perl, Go, Ruby, Lua, Java, PHP, Python, Crystal, Elixir, and Rust.
|
||||
|
||||
Note that this list is not exhaustive. Other languages like Markdown, HTML, CSS, and Sass also work by default.
|
||||
|
||||
For a list of all packages installed and why they were installed, please see `install/packages.sh`.
|
||||
1. **Configuration is self-documenting.** It is trivial for someone to view and understand how the dotfiles work.
|
||||
2. **Everything just works.** The configuration is simple enough that the possibility for edge cases are extremely limited.
|
||||
|
||||
The default wallpaper is [Arch Adapta](https://www.reddit.com/r/UnixWallpapers/comments/71lcxo/). The [original](https://github.com/adapta-project/adapta-backgrounds) was made by [Tista](https://github.com/tista500) and is released under the [Creative Commons Share-Alike 3.0](https://creativecommons.org/licenses/by-sa/3.0/) license.
|
||||
|
||||
By default I keep track of the many useful commands and other features I use on a daily basis. Please not that these are not a replacement for reading the man pages of said software.
|
||||
|
||||
## A Note on Free Software
|
||||
One thing that always annoyed me was viewing the dotfiles of other people. Many people leave all the default settings in their dotfiles, when the same exact settings are going to be sourced anyway before calling the config file. Your dotfiles should only have what you're changing and nothing else.
|
||||
|
||||
Often as end-users we come across a variety of roadblocks that prevent us from doing what we want to get done. "If only this program could do X" or "if only my operating system was better at handling Y".
|
||||
|
||||
**Proprietary software** forces us to accept whatever inconveniences we face as a matter of fact. We will have to deal with these inconveniences until the upstream developers decide to do something with it. Proprietary software may also change at any time, forcing the end-user to conform to new practices whether they like it or not.
|
||||
|
||||
**Free software**, on the other hand, allow us to have complete control of our computers. If something doesn't work, we can fix it. If we want to change something, we can change it. We're not waiting for or trusting anyone else to do it. We have the power to change the things we don't like and redistribute them for others to use.
|
||||
|
||||
Free software promotes innovation. How? Anyone is allowed to contribute to the upstream project. If someone doesn't agree with the direction a piece of software is going, they have the freedom to modify the software and redistribute those modifications to the community. If a particular piece of software goes downstream or starts promoting malicious activities, it is trivial for users to switch to the modified software.
|
||||
|
||||
Free software is a competitive environment decided by the people. Vendor lock-in is limited; if your software doesn't conform to the user's wants--the user's needs, another piece of software will.
|
||||
|
||||
Do not confuse free software with freeware. **Freeware** is any piece of software that is distributed with no price; however, freeware is *not* free software. **Free software**, in comparison, *may* come with a price. Free software in this context refers to the freedom to do anything with the software you obtain, whether you have to pay for it or not.
|
||||
|
||||
Compare this to **proprietary software**, which often impose restrictions on how you can use the software *even after you purchase it*. Legally speaking, your rights to the software are restricted before you even decide to buy it. If you don't like something and want to change it, you're not able to, even if you paid for it.
|
||||
|
||||
A software *S* is said to be **free software** if and only if:
|
||||
|
||||
1. You have the freedom to use the software as you wish, for any purpose.
|
||||
2. You have the freedom to study how the program works, and change it so the program works for you and not the other way around.
|
||||
3. You have the freedom to redistribute copies of the software, similar to sharing your music with a friend, but with software.
|
||||
4. You have the freedom to distribute modified versions of the software to others. This makes it possible for everyone else to benefit from your changes.
|
||||
|
||||
A software that does not adhere to the above conditions is said to be **nonfree software**. Nonfree software includes freeware, that is, software offered at no price but does not grant the four freedoms.
|
||||
|
||||
It is important to note that **open source software** is *not* free software. Anyone can publish their code online. This code is still limited by the terms set forth in the **software license**.
|
||||
|
||||
Freedom is a powerful thing. You don't realize what you don't have. But when you have it, you never want to lose it. Freedom works the same way. Once you experience the freedom of being able to change any part of your system, at any time and for any reason, without anyone or anything else restricting you otherwise, you start to wonder how you ever managed without such freedoms.
|
||||
|
||||
The age-old saying still goes: with great power comes great responsibility. You aren't hindered by any external limits; only yourself. There are no handlebars. Anything you do is done. You are responsible for your own software. You have complete control.
|
||||
## Contributing
|
||||
|
Loading…
Reference in New Issue
Block a user