diff --git a/README.md b/README.md index b6c849d..6e49c2d 100644 --- a/README.md +++ b/README.md @@ -1,40 +1,188 @@ -# Installation Guide +# Ricing Arch Linux + +## Foreword + +### Who is this guide for? + +Those who are interested in ricing or would like to know what it is, whether they are experienced Linux users or complete beginners. + +Those who want control over the way their desktop environment [DE] looks, far beyond the offerings of Windows and OS X. + +Those who dislike extra/unneeded features cluttering their DE. With ricing and Linux in general, you can keep what you want/need and remove everything else. This is especially helpful for older systems. + +### Hold up... "ricing"? + +If the term confuses you, you aren't alone. You're probably thinking, what does rice have to do with computers, at all? Below is the definition of ricing taken from [u/unixporn](https://www.reddit.com/r/unixporn/): + +> "Rice" is a word that is commonly used to refer to making visual improvements and customizations on one's desktop. It was inherited from the practice of customizing cheap Asian import cars to make them appear to be faster than they actually were - which was also known as "ricing". Here on /r/unixporn, the word is accepted by the majority of the community and is used sparingly to refer to a visually attractive desktop upgraded beyond the default. + +## What You'll Be Creating Today ![The Setup](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/master/images/finishedsetup.png) -## Installing Arch Linux -If you already have Arch installed, install i3 and Urxvt: `sudo pacman -S i3 rxvt-unicode`. +There's not a lot going on, right? Yeah, that was the whole point. I mostly use Firefox and Vim. I don't need much. It's my personal setup and what I'm using at the time of writing. If you want more, this guide will teach you the basics and provide a set-up to 'improve' on with your own needs in mind. -If you do not have Arch installed, you can follow the [installation guide ](https://wiki.archlinux.org/index.php/installation_guide)or use [Arch-Anywhere](https://arch-anywhere.org/download/). Either way, use netctl for managing your wireless connection. If you use Arch-Anywhere, I will assume you selected i3 and rxvt-unicode during installation. +Visit [u/unixporn](https://www.reddit.com/r/unixporn/) to see what others have created. -## First Boot/Log-In +### Overview of Setup -You will be prompted to select the windows or alt key as a modifier. The modifier key is used for controlling the window manager. After this, select yes to creating a config file. +#### Time Commitment -Open the terminal by pressing mod+enter, then run `sudo wifi-menu` to create a wireless profile and remember its name. Then run `sudo netctl enable `. This automatically connects you to wifi on each boot. Now run `reboot`. +You should be done in an hour, however, it may take longer depending on your internet connection. -If you installed a login manager, make sure to select i3 as the desktop environment. For example, the gnome login manager has a small settings/cog icon that lets you do so. +#### Arch Linux -If you didn't install a login manager, type your user username and then password. Once you've done that, type `startx` and hit enter to start i3. +In a nutshell, [Arch](https://www.archlinux.org/) is an independently developed general-purpose GNU/Linux distribution. The main reason you would choose this over other distributions is that it comes with the bare minimum and zero bloat. This allows you to have a lean system from the beginning. -Your screen resolution may be incorrect. Run `xrandr` and identify your display. Then run `xrandr --output --mode 2560x1440 --rate ` For me it is `xrandr --output DP1-8 --mode 2560x1440 --rate 59.95`. If you have multiple monitors, check out the [documentation](https://wiki.archlinux.org/index.php/Xrandr). The xrandr setting isn't permanent for now, we'll get to that later. +If you've heard of Arch, you may have heard the installation isn't so simple. You may even find it to put you off. Don't worry about that. [Arch-Anyhwere](https://arch-anywhere.org/) makes installation easy. The only difference is that Arch-Anywhere has an installer. -## Lets Get Cooking! +Installing Arch manually is outside the scope of this guide. If you prefer to install it manually, visit the [installation guide](https://wiki.archlinux.org/index.php/installation_guide). Otherwise, use [Arch-Anywhere](https://arch-anywhere.org/download/). + +*Tip: To save time, download Arch/Arch-Anywhere while you read on.* -![Range and Dmenu in use](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/master/images/ranger-dmenu.png) +#### Window Manager -Firstly, you will install Dmenu, Vim and Ranger. As seen above, dmenu is a GUI application launcher and Ranger is a terminal filemanager. Vim is the text editor you seen in the image at the start of this guide. +We will be using [i3](https://i3wm.org/) as our WM. It is a dynamic window tiling manager. This means, when a window is opened, it takes up the whole desktop. When you open another window, the new and existing one will be resized to be equal. This happens each time you open a new window. Mathematically, when two windows are open, each will take one-half of screen space. When a third window is opened, they'll each take one-third of screen space and so on. The same applies if they are opened vertically. Windows can be resized, arranged in tabs and stacks. They can also be floated, meaning you can move and resize windows how you would in Windows and OS X. -To install said packages, run: `sudo pacman -S dmenu vim ranger`. +![Example of i3WM tiling](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/master/images/i3wm-example.png) -Dmenu is used pressing mod+d, then typing in the package you want to use. This will only work if the package has a GUI. To use Ranger, run `ranger` in the terminal. +You'll be given a mini tutorial on how to manipulate and rearrange windows once i3 has been installed. -### Installing Pacaur +#### Package Installer + +Besides Pacman, the default package installer shipped with Arch. We will be installing [Pacaur](https://github.com/rmarquis/pacaur): -Taken from the [Pacaur repository](https://github.com/rmarquis/pacaur): > Pacaur is an Arch User Repository (AUR) helper aiming at speed and simplicity and is designed to minimize user prompt interaction. -By using Pacaur, you can install packages from AUR without going through the manual build process each time. +All you need to know for now is, it saves you a lot of time in the long-term. Without it, you would need to go through the manual build process for each package that can't be installed through Pacman. This is one of those things you wish you knew when you were starting out. + +#### Terminal Emulator + +We'll be using rxvt-unicode, also known as urxvt. It's fast, lightweight and highly customizable. Furthermore, Wal can automatically apply a generated colorscheme to urxvt. + +#### Status Bar + +The Polybar repository tells it best: + +> A fast and easy-to-use tool for creating status bars. +> +> Polybar aims to help users build beautiful and highly customizable status bars for their desktop environment, without the need of having a black belt in shell scripting. Here are a few screenshots showing you what it can look like: + +Polybar is modular. Meaning, if you want to see what workspace you're on and which ones have an open window, you add a module for said functionality. If you want to see the time and date, you add another module. The one I have configured and is included in this guide is very minimal, since I don't need other modules. For examples with more modules, visit the Polybar [repository](https://github.com/jaagr/polybar) and/or u/unixporn with a [restrcited search](https://www.reddit.com/r/unixporn/search?q=polybar&restrict_sr=on) to see what can be achieved. + +#### Application Launcher/Dynamic Menu and File Manager + +Personally, I love application launchers. It makes your workflow noticeably more efficient, than if you were to go onto a list of applications and click on the one you need to open. We will be going with dmenu. A simple, fast and lightweight dynamic menu. + +[Ranger](https://github.com/ranger/ranger) is a Vim inspired CLI file-manager and is very quick to use once you get the hang of it. Besides, it can match your colour scheme. More on that later. + +![Dmenu and ranger in action](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/master/images/ranger-dmenu.png) + +*Note: i3 by default does not have a feature where you can see all your applications.* + +#### Themeing + +Two ways in which the colour scheme can be altered is through the .Xresources file and Wal. We will be using the Python version of Wal, called [Pywal](https://github.com/dylanaraps/pywal). + +Taken from the [Arch Wiki](https://wiki.archlinux.org/index.php/x_resources): + +> Xresources is a user-level configuration dotfile, typically located at ~/.Xresources. It can be used to set X resources, which are configuration parameters for X client applications. +> +> They can do many operations, including: +> * defining terminal colours +> * configuring terminal preferences +> * setting DPI, antialiasing, hinting and other X font settings +> ... + +Taken from the Pywal repository: +> `wal` is a script that takes an image (or a directory of images), generates a colour scheme (using `imagemagick`) and then changes all of your open terminal's colours to the new colour scheme on the fly. wal then caches each generated colour scheme so that cycling through wallpapers while changing colour schemes is instantaneous. +> +> `wal` also merges the new colour scheme into the Xresources database so that programs on your system such as `Rofi` or `i3` use the new colours automatically. `wal` finally exports the colors into various formats so that you can use the colours in web pages, scripts, other programs etc. + +Polybar can also use the colour scheme generated by Wal if you configure it to. + +##### Fonts + +We will be using [Overpass](http://overpassfont.org/) by [Red Hat](https://www.redhat.com/). It comes with 8 weight variants and a monospaced version, named Overpass Mono, which you can see in the status bar. + +![Overpass Font](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/master/images/font.png) + +#### Neofetch + +Taken from the [Neofetch](https://github.com/dylanaraps/neofetch) repository: + +> Neofetch is a CLI system information tool written in BASH. Neofetch displays information about your system next to an image, your OS logo, or any ASCII file of your choice. The main purpose of Neofetch is to be used in screenshots to show other users what OS/Distro you're running, what Theme/Icons you're using etc. + +Although not necessary, I will be showing you how to work with Neofetch since it's so popular. + +#### Text Editor + +Throughout this guide, we'll be using [Vim](http://www.vim.org/), a powerful yet lightweight text editor. For those who don't know how to use it, I'll be including the commands needed to follow this guide. + +## Lets Get Cooking! + +### Getting Started + +Firstly, you need to install Arch. If you're doing the manual installation, the Arch guide will walk you through formatting your USB. For those using Arch-Anywhere, see below on how to make a bootable USB depending on the OS you are currently using. + +#### Windows + +Download [Rufus](https://rufus.akeo.ie/) and open it up. Select your USB and down in Format Options, press the button with the disk/hard-drive and select the ISO. + +Rufus should now match what's in the below screenshot, with the exception of the "Dvice", "New volume label" and the ISO image information at the very bottom. + +![Rufus Setup](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/dev/images/Rufus.PNG) + +When you're ready, press start. If are asked for permission to download additional files, allow it. + +#### OS X + +Download and use [Etcher](https://etcher.io/). Select the ISO file and USB, then hit Flash. + +![Etcher Usage.](https://etcher.io/static/screenshot.gif) + +*Note: The '.gif' above is taken directly from the Etcher site, so excuse the Live Image name.* + +#### Linux + +Google it. + +### Pre-Installation Notes + +For the purpose of this guide, I will assume you are using 'netctl' for managing your wireless connection. + +Now go ahead and install Arch. + +### If You ALready Have Arch Installed + +To follow this guide, you'll need i3, rxvt-unicode and dmenu. Fire up your terminal and run `sudo pacman -S i3 rxvt-unicode dmenu vim`. + +### First Boot/Log-In + +If you installed a login manager, make sure to select i3 as the desktop environment. For example, the gnome login manager has a small settings/cog icon that lets you do so. If you didn't install a graphical login manager, you'll see what appears to be a fullscreen terminal. Enter your username and press enter, then do the same with your password. Once you are logged in, type `startx` and press enter to launch i3. + +You will be prompted to select the windows or alt key as a modifier. The modifier key is used for controlling the window manager. After this, select yes to creating a config file. + +Open the terminal by pressing `mod+enter`, then run sudo wifi-menu to create a wireless profile and remember its name. Then run `sudo netctl enable `. This automatically connects you to wifi on each boot. Now run `reboot`. + +### Screen Resolution + +Your screen resolution may be incorrect. Run `xrandr` and identify your display. Then run `xrandr --output --mode 2560x1440 --rate ` For me it is `xrandr --output DP1-8 --mode 2560x1440 --rate 59.95`. If you have multiple monitors, check out the [documentation](https://wiki.archlinux.org/index.php/Xrandr). The xrandr setting isn't permanent for now, we'll get to that later. + + +### Guide Dependencies + +Before we get to the ricing, we need to install a few things first. + +#### Install Dmenu, Vim and Ranger + +`sudo pacman -S dmenu vim ranger` + +To use Dmenu, press `mod+d`. Only packages that have a GUI will appear if selected through Dmenu, otherwise it'll seem as if it's not working. This is normal. + +To Use Ranger, run `ranger`. + +#### Install Pacaur ``` cd ~ @@ -55,10 +203,7 @@ cd ~ rm -r /tmp/pacaur_install ``` -### Installing Pywal -Taken from [Pywal repositry](https://github.com/dylanaraps/pywal): - -> wal is a script that takes an image (or a directory of images), generates a colorscheme (using imagemagick) and then changes all of your open terminal's colors to the new colorscheme on the fly. wal then caches each generated colorscheme so that cycling through wallpapers while changing colorschemes is instantaneous. +#### Install Pywal Python 3.5 or above is required, so ensure it's installed by running `python -V`. If it isn't, install it: `pacaur -S python`. @@ -67,9 +212,8 @@ When you're good to go: sudo pacman -S feh imagemagick python-pip pacaur -S python-pywal ``` -Note: You don't need to view package build. If you decide to view it, it'll be displayed in Vim. Type `:q` to exit Vim. +*Note: You don't need to view package build. If you decide to view it, it'll be displayed in Vim. Type `:q` to exit Vim.* -#### Using Pywal ![Wallpaper](https://github.com/IbrahimButt/Direwolf-Arch-Rice/blob/master/images/wallpaper.jpg) Right click on the image above and save as `bg1.jpg`. Now do the following: @@ -80,17 +224,15 @@ mv ~/Downloads/bg1.jpg ~/Pictures/Wal/ wal -i ~/Pictures/Wal/bg1.jpg ``` -### Installing Polybar -Taken from the [Polybar repository](https://github.com/jaagr/polybar): -> A fast and easy-to-use tool for creating status bars... Polybar aims to help users build beautiful and highly customizable status bars for their desktop environment, without the need of having a black belt in shell scripting. +#### Install Polybar -To install, first you'll need to install the dependencies and then Polybar itself: +First you'll need to install the dependencies and then Polybar itself: ``` sudo pacman -S cairo libxcb python2 xcb-proto xcb-util-image xcb-util-wm xcb-util-xrm jsoncpp pacaur -S polybar-git ``` -### Installing My Dot Files and .Xresources +#### Install Dot Files ``` cd ~ @@ -100,22 +242,22 @@ cp -r ~/Direwolf-Arch-Rice/.config/ ~/ cp -r ~/Direwolf-Arch-Rice/.Xresources ~/ xrdb .Xresources ``` -You will need to run `wal -i ~/Pictures/Wal/bg1.jpg` again here, so Urxvt used the colorscheme. +You will need to run wal -i ~/Pictures/Wal/bg1.jpg again here, so Urxvt uses the colorscheme. Refresh i3 by pressing mod+r. -Only terminals and windows opened after this point will have the changes applied to them. +Only terminals and windows opened after this point will have those two changes applied to them. -### Install Fonts +#### Install Fonts `pacaur -S otf-overpass` -Refresh i3 to see changes. +Refresh i3 to load changes. ### Make Changes To i3 Config Read through the whole config file and understand what's happening. Change anything that's necessary. The comments will give you hints as to what you may want to change. Do not skip this step. It'll teach you got to use i3. -### Preview Imasges In Ranger +### Preview Images In Ranger Install w3m: `sudo pacman -S w3m`. Then run `vim ~/.config/ranger/rc.conf`. Read it and understand it. Lastly, run `ranger --copy-config=scope`. @@ -140,3 +282,5 @@ Your set up should be identical to mines now. ## Known Issues The xrandr setting needs to be set on each boot if you're using startx. Therefore, I've added it as an `exec_always` in the i3 config. Refresh i3 to apply it on each boot. I'm currently in the process of figuring this out. If you have any other issues, feel free to raise it on here.. + + diff --git a/images/Rufus.PNG b/images/Rufus.PNG new file mode 100644 index 0000000..51a30e1 Binary files /dev/null and b/images/Rufus.PNG differ