diff --git a/README.org b/README.org
index cead6bf..4449f9f 100644
--- a/README.org
+++ b/README.org
@@ -1,10 +1,9 @@
#+TITLE: Phundrak’s dotfiles
#+AUTHOR: Lucien "Phundrak” Cartier-Tilet
#+EMAIL: phundrak@phundrak.fr
-#+HTML_HEAD:
-#+HTML_HEAD:
-#+HTML_HEAD:
#+OPTIONS: H:4 broken_links:mark email:t ^:{} auto_id:t
+
+# ### LaTeX ####################################################################
#+LATEX_CLASS: conlang
#+LaTeX_CLASS_OPTIONS: [a4paper,twoside]
#+LATEX_HEADER_EXTRA: \usepackage{tocloft} \setlength{\cftchapnumwidth}{3em}
@@ -17,7 +16,12 @@
#+LATEX_HEADER_EXTRA: \usepackage{multicol}
#+LATEX_HEADER_EXTRA: \usepackage{indentfirst}
#+LATEX_HEADER_EXTRA: \sloppy
+
+# ### HTML #####################################################################
#+HTML_DOCTYPE: html5
+#+HTML_HEAD_EXTRA:
+#+HTML_HEAD_EXTRA:
+#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
@@ -27,8 +31,7 @@
#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
-#+INFOJS_OPT: view:info toc:1 home:https://langue.phundrak.fr toc:t
-
+#+INFOJS_OPT: view:info toc:1 home:https://phundrak.fr/ toc:t
#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
#+HTML_HEAD_EXTRA:
@@ -41,28 +44,28 @@
- [[#dependencies][Dependencies]]
- [[#installation][Installation]]
- [[#install-arch-linux][Install Arch Linux]]
+ - [[#get-the-latest-live-system-with-fast-mirrors][Get the latest live system with fast mirrors]]
+ - [[#install-the-system][Install the system]]
+ - [[#install-yay-if-it-hasnt-been-done-during-the-system-installation][Install =yay= if it hasn’t been done during the system installation]]
- [[#update-the-system][Update the system]]
- - [[#install-yay-and-all-the-official-repos-packages][Install =yay= and all the official repos’ packages]]
- [[#set-up-yadm][Set up =yadm=]]
- [[#get-the-dotfiles][Get the dotfiles]]
+ - [[#update-the-remotes][Update the remotes]]
+ - [[#get-our-git-submodules][Get our git submodules]]
- [[#generate-the-alt-dotfiles][Generate the alt dotfiles]]
- [[#set-up-emacs][Set up Emacs]]
- - [[#download-spacemacs][Download Spacemacs]]
- - [[#set-the-custom-layers][Set the custom layers]]
- - [[#symlink-the-emacs-config][Symlink the Emacs config]]
- - [[#install-the-fish-shell][Install the Fish shell]]
- - [[#install-fisher][Install fisher]]
- - [[#install-the-fish-config-and-custom-functions][Install the fish config and custom functions]]
- - [[#install-the-dotfiles][Install the dotfiles]]
- - [[#update-the-submodules][Update the submodules]]
- - [[#update-the-remotes][Update the remotes]]
- - [[#symlink-the-dotfiles][Symlink the dotfiles]]
+ - [[#install-our-needed-packages][Install our needed packages]]
+ - [[#enable-and-start-some-services][Enable and start some services]]
+ - [[#install-fisher-and-our-fish-shell-extensions][Install Fisher and our fish shell extensions]]
- [[#install-packages-from-git][Install packages from git]]
- [[#install-i3-gaps-rounded][Install =i3-gaps-rounded=]]
- [[#install-polybar-battery][Install Polybar Battery]]
- [[#download-revealjs][Download Reveal.JS]]
+ - [[#set-your-locale][Set your locale]]
+ - [[#launch-x][Launch X]]
- [[#install-rust][Install Rust]]
- [[#install-the-toolchains][Install the toolchains]]
+ - [[#install-some-utilities][Install some utilities]]
- [[#clean-the-pacman-and-yay-cache][Clean the =pacman= and =yay= cache]]
- [[#licence][Licence]]
@@ -88,10 +91,16 @@
* Screenshots
+ #+ATTR_HTML: :width 100%
+ #+CAPTION: Desktop with Neofetch in the terminal
[[./img/neofetch.png]]
+ #+CAPTION: Desktop with Emacs opened
+ #+ATTR_HTML: :width 100%
[[./img/emacs.png]]
+ #+CAPTION: Desktop with Rofi
+ #+ATTR_HTML: :width 100%
[[./img/rofi.png]]
* Dependencies
@@ -128,211 +137,236 @@
I usually install Arch from the [[https://www.archlinux.org/download/][vanilla ISO]], however I began using [[https://github.com/MatMoul/archfi][archfi]] to
install easily the distro (I’ve done it so many times, I know how it works
now). Usually, my distros will be installed on at least two partitions, one
- dedicated to =/home=, the other to the root partition =/=. When you boot into
- the live ISO, execute the following command:
- #+BEGIN_SRC sh :exports code
- wget archfi.sf.net/archfi
- # Or from matmoul.github.io/archfi if SourceForge is down
- sh archfi
- #+END_SRC
- Then, follow the instructions and install Arch Linux.
+ dedicated to =/home=, the other to the root partition =/=.
-** Update the system
- First of all, let’s make sure we have a sorted mirrorlist for pacman.
- #+BEGIN_SRC fish :exports code :dir /sudo::
- pacman -Sy reflector
- reflector --country France --country Germany --latest 200 \
- --protocol http --protocol httpqs --sort rate \
- --save /etc/pacman.d/mirrorlist
- #+END_SRC
+ If the computer supports EFI bootloaders, the EFI partition will be mounted
+ on =/boot=. I generally use rEFInd as my boot manager, but if you are more
+ comfortable with another one, just install what you want. Be aware that if
+ you format your =/boot= partition, you will delete all boot managers that
+ already exist; so, if you are dual-booting, *DO NOT FORMAT IT*. Yes, I made
+ the mistake of wiping the Windows boot manager.
- Now, let’s update the system in order to be sure to have the latest
- version.
- #+BEGIN_SRC fish :dir /sudo:: :exports code
- sudo pacman -Syu --noconfirm
- sudo pacman -S git emacs --needed --noconfirm
- #+END_SRC
+ The swap partition is always at least 4GB large, and I should have a total of
+ 12GB of combined RAM and swap. This means on my main computer I have 16GB of
+ RAM and 4GB of swap, but on my thinkpad I have 4GB of RAM and 8GB of swap.
-** Install =yay= and all the official repos’ packages
- Next step is to install the AUR helper =yay= (DO NOT use =yaourt=, it is
- discontinued, seriously updated and represents a serious security flaw).
- Let’s clone it in a folder =fromGIT= that will be in our home folder. This is
- also where we’ll download every other packages we’ll install from git.
- #+BEGIN_SRC fish :dir ~ :exports code
+
+*** Get the latest live system with fast mirrors
+ When you boot into the live ISO, execute the following command:
+ #+BEGIN_SRC sh :exports code
+ pacman -Syu reflector
+ reflector --country France --country Germany --latest 200 \
+ --protocol http --protocol https --sort rate \
+ --save /etc/pacman.d/mirrorlist
+ #+END_SRC
+ This will update the packages from your live ISO, and you will get the best
+ mirrors for your installation. Of course, change the countries accordingly
+ to your location.
+
+*** Install the system
+ Then you can use a custom script to ease your installation of Arch if you do
+ not wish to do it manually. Personally, I’ve done it several times already,
+ I know how the distro works, I just want to be able to install my distro
+ quickly now.
+ #+BEGIN_SRC sh :exports code
+ wget archfi.sf.net/archfi
+ # Or from matmoul.github.io/archfi if SourceForge is down
+ sh archfi
+ #+END_SRC
+ Then, follow the instructions and install Arch Linux. Take the opportunity
+ to install as many packages as you need, mainly =yay= which I use as my
+ package manager (it is just a wrapper for =pacman=) and AUR helper.
+
+ Once your system is installed, reboot and remove your installation media
+ from your computer.
+
+** Install =yay= if it hasn’t been done during the system installation
+ Next step is to install the AUR helper =yay=. *DO NOT* use =yaourt=, it is
+ discontinued, seriously updated and represents a serious security flaw.
+
+ Let’s clone =yay= in a folder =fromGIT= that will be in our home folder. This
+ is also where we’ll download every other packages we’ll install from git.
+ #+BEGIN_SRC sh :dir ~ :exports code
mkdir -p fromGIT
cd fromGIT
git clone https://aur.archlinux.org/yay.git
cd yay
makepkg -si --noconfirm
#+END_SRC
+ We now have our AUR helper!
- Now, we can install all the packages I usually have installed on my computer.
- #+BEGIN_SRC fish :dir /sudo:: :exports code
- yay -S --needed --noconfirm asar ascii aspell-en aspell-fr assimp \
- autoconf automake awesome-terminal-fonts bash bat biber binutils bison \
- bleachbit bluez-firmware bluez-utils bookworm boost bzip2 chromium clisp \
- compton-tryone-git coreutils cppcheck cppreference cppreference-devhelp \
- cpupower cronie cryptsetup cups device-mapper dhcpcd diffutils\
- discord-canary discount ditaa dmenu dmenu-lpass docker docker-compose \
- doxygen dwarffortress e2fsprogs emacs exfat-utils fakeroot feh \
- ffmpegthumbnailer file filesystem findutils fingerprint-gui firefox fish \
- flake8 flex font-mathematica fontforge freeglut fzf gawk gcc gcc-libs gdb \
- gettext gimp git glibc gnome-disk-utility gnome-epub-thumbnailer \
- gnu-free-fonts gnuplot go-tools grep gzip htop i3-gaps i3lock-blur \
- i3status icecat-bin igdm-bin inetutils intel-ucode iproute2 iputils \
- j4-dmenu-desktop jfsutils lastpass-cli less libnewt libtool licenses \
- light linux linux-firmware linux-headers lldb logrotate lsof lvm2 m4 make \
- man-db man-pages mate-polkit mdadm meson minted mpc mpd \
- mpd-rich-presence-discord-git mpv mupdf-tools nano nasm ncdu ncmpcpp \
- nemo-fileroller nemo-preview neofetch netctl networkmanager \
- networkmanager-openvpn nm-connection-editor nnn nomacs noto-fonts-emoji \
- npm ntfs-3g openmp openssh p7zip pacman pacman-contrib pandoc-bin patch \
- pavucontrol pciutils pcurses pdfpc perl pkgconf polybar procps-ng psmisc \
- pulseaudio-bluetooth python-envtpl-git python-pip python-pywal qemu r \
- raw-thumbnailer redshift refind-efi reflector reiserfsprogs rofi \
- rofi-wifi-menu-git rsync rtv rustup s-nail samba scrot sdl2_gfx \
- sdl2_image sdl2_mixer sdl2_ttf sed sent shadow siji-git \
- simplescreenrecorder speedcrunch sshfs st-luke-git sudo sysfsutils \
- systemd-sysvcompat tar texinfo texlive-bibtexextra texlive-bin \
- texlive-core texlive-fontsextra texlive-formatsextra texlive-games \
- texlive-humanities texlive-langchinese texlive-langcyrillic \
- texlive-langextra texlive-langgreek texlive-langjapanese \
- texlive-langkorean texlive-latexextra texlive-music texlive-pictures \
- texlive-pstricks texlive-publishers texlive-science tmux tree \
- ttf-arphic-uming ttf-baekmuk ttf-bitstream-vera ttf-dejavu \
- ttf-google-fonts-opinionated-git ttf-joypixels ttf-liberation
- ttf-material-design-icons-git ttf-ms-fonts ttf-symbola \
- ttf-tibetan-machine ttf-twemoji-color ttf-unifont unicode unicode-emoji \
- unrar usbutils util-linux valgrind vi vim vulkan-headers w3m wget which \
- whois x11-ssh-askpass xclip xdg-user-dirs-gtk xf86-input-wacom \
- xf86-video-intel xfce4-power-manager xfsprogs xorg-server xorg-xinit \
- xss-lock yadm graphviz
+** Update the system
+ Congrats, Arch is now installed on your system! But we are not done yet.
+ Let’s update the system, just in case some packages were updated during the
+ installation. And let’s install =yadm= (our dotfiles manager) and =emacs=
+ while we’re at it.
+ #+BEGIN_SRC sh :exports code
+ yay -Syua yadm emacs
#+END_SRC
- Given how many packages will be install from the AUR, I’ll probably have to
- type my password a few times.
-
** Set up =yadm=
=yadm= is my dotfiles manager. It has some very interesting, including host
and machine-specific files and file content, as can be seen in
- =dotfiles/.config/i3/config##yadm.j2=.
+ =.config/i3/config##yadm.j2=. It also manages some files system-wide (well,
+ actually =home=-wide), so you usually don’t have to symlink anything.
+
+ For some reason, when I’m in i3, polybar crashes when I run any =yadm=
+ command, so I made the =C-S-p= shortcut to relaunch it at will.
*** Get the dotfiles
You should clone the dotfiles with the help of =yadm=. For that purpose, you
can execute either of the two following commands.
- From [[https://labs.phundrak.fr/phundrak/dotfiles][labs.phundrak.fr]]:
- #+BEGIN_SRC fish :dir ~ :exports code
+ #+BEGIN_SRC sh :dir ~ :exports code
yadm clone https://labs.phundrak.fr/phundrak/dotfiles.git
#+END_SRC
- From [[https://github.com/phundrak/dotfiles][Github]]:
- #+BEGIN_SRC fish :dir ~ :exports code
+ #+BEGIN_SRC sh :dir ~ :exports code
yadm clone https://gitlab.com/phundrak/dotfiles.git
#+END_SRC
-*** Generate the alt dotfiles
- =yadm= will need to generate the host-specific dotfiles. To do so, you can
- run the following command:
- #+BEGIN_SRC fish :dir ~ :exports code
- yadm alt
- #+END_SRC
-
-** Set up Emacs
- The first thing to do after setting up our system is setting up Emacs.
-
-*** Download Spacemacs
- First, let’s download Spacemacs.
- #+BEGIN_SRC fish :dir ~ :exports code
- git clone https://github.com/syl20bnr/spacemacs ~/.emacs.d
- #+END_SRC
-
- Let’s switch Spacemacs’ branch to =develop=.
- #+BEGIN_SRC fish :dir ~/.emacs.d :exports code
- git checkout develop
- #+END_SRC
-
-*** Set the custom layers
- As mentionned above, I use some custom layers. Let’s symlink these to the
- private folder of our =.emacs.d/= folder.
- #+BEGIN_SRC fish :dir ~/.emacs.d/private :exports code
- for d in ~/dotfiles/spacemacs-layers/*
- ln -s $d
- end
- #+END_SRC
-
-*** Symlink the Emacs config
- Let’s not forget our Spacemacs/Emacs config, we’ll symlink it to our home
- directory.
- #+BEGIN_SRC fish :dir ~ :exports code
- ln -s ~/dotfiles/.spacemacs
- #+END_SRC
-
-** Install the Fish shell
- As mentionned above, I use the fish shell as my main shell. And I use some
- extensions too that I installed from fisher, and custom functions.
-
-*** Install fisher
- Let’s install fisher:
- #+BEGIN_SRC fish :exports code
- curl https://git.io/fisher --create-dirs -sLo \
- ~/.config/fish/functions/fisher.fish
- #+END_SRC
-
- Awesome! Now, onto the fisher packages:
- #+BEGIN_SRC fish :exports code
- fisher add edc/bass franciscolourenco/done jethrokuan/fzf jethrokuan/z \
- jorgebucaran/fish-getopts laughedelic/pisces \
- matchai/spacefish tuvistavie/fish-ssh-agent
- #+END_SRC
-
-*** Install the fish config and custom functions
- I will be symlinking my fishfile to its location =~/.config=.
- #+BEGIN_SRC fish :dir ~/.config/ :exports code
- ln -s ~/dotfiles/config.fish
- #+END_SRC
-
- Now, in the =functions= subdirectory, let’s symlink all of my custom
- functions.
- #+BEGIN_SRC fish :dir ~/.config/fish/functions :exports code
- for f in ~/dotfiles/fishfunctions/*.fish
- ln -s $f
- end
- #+END_SRC
-
-** Install the dotfiles
-*** Update the submodules
- Alright, let’s do something about all these dotfiles laying around. First,
- let’s symlink those that are in our home directory.
- #+BEGIN_SRC fish :exports code
- yadm submodule update
- #+END_SRC
-
*** Update the remotes
Now, let’s make sure we have the correct remotes set up for the dotfiles.
#+BEGIN_SRC fish :exports code :dir ~/dotfiles
- yadm remote set-url origin "git@labs.phundrak.fr:phundrak/dotfiles.git"
- yadm remote set-url github "git@github.com:phundrak/dotfiles.git"
+ yadm remote set-url origin "https://labs.phundrak.fr/phundrak/dotfiles.git"
+ yadm remote add-url github "https://github.com/phundrak/dotfiles.git"
+ #+END_SRC
+ You can swap the two links if you feel more comfortable with Github as the
+ =origin= remote, just rename the =github= remote to something like
+ =phundraklabs= or something like that.
+
+ If you have already generated (or copied, but don’t do that) your SSH keys
+ and uploaded them to Github and/or to Phundrak Labs, you can use the
+ following urls instead as the remotes’ urls.
+ #+BEGIN_SRC text
+ git@labs.phundrak.fr:phundrak/dotfiles.git
+ git@github.com:phundrak/dotfiles.git
#+END_SRC
-*** Symlink the dotfiles
- Let’s now symlink our dotfiles. First, we’ll take care of those that should
- be symlinked to our home directory.
- #+BEGIN_SRC fish :dir ~ :exports code
- ln -s ~/dotfiles/.Xresources
- ln -s ~/dotfiles/.gitignore_global
- ln -s ~/dotfiles/.nanorc
- ln -s ~/dotfiles/rustfmt.toml
- ln -s ~/dotfiles/.signature
- ln -s ~/dotfiles/.tmux.conf.local
- ln -s ~/dotfiles/tmux/.tmux.conf
- ln -s ~/dotfiles/.config/i3 .i3
+*** Get our git submodules
+ Our dotfiles rely on a couple of submodules we should get. Let’s download
+ them.
+ #+BEGIN_SRC sh :dir ~ :exports code
+ yadm submodule update --init --recursive
#+END_SRC
- Finally, let’s symlink everything that belongs to the =~/.config= folder.
- #+BEGIN_SRC fish :dir ~/.config :exports code
- for elem in ~/dotfiles/.config/*
- ln -s $elem
- end
+*** Generate the alt dotfiles
+ =yadm= will need to generate the host-specific dotfiles. To do so, you can
+ run the following command:
+ #+BEGIN_SRC sh :dir ~ :exports code
+ yadm alt
#+END_SRC
+ And with that, we should have all of our dotfiles placed where they need to
+ be!
+
+** Set up Emacs
+ Now that we have our dotfiles installed, let’s set up Emacs. First, let’s
+ download Spacemacs.
+ #+BEGIN_SRC sh :dir ~ :exports code
+ git clone https://github.com/syl20bnr/spacemacs ~/.emacs.d
+ #+END_SRC
+
+ In our =.emacs.d= directory, let’s switch Spacemacs’ branch to =develop=.
+ #+BEGIN_SRC sh :dir ~/.emacs.d :exports code
+ git checkout develop
+ #+END_SRC
+ The rest of this README’s code blocks should now be executable from Emacs
+ itself, and we should be able to have a perfectly running Emacs installation.
+ That’s the power of Org-mode!
+
+** Install our needed packages
+ Now, we can install all the packages I usually have installed on my computer.
+ #+BEGIN_SRC sh :dir /sudo:: :exports code
+ yay -S --needed asar ascii aspell-en aspell-fr assimp autoconf automake \
+ awesome-terminal-fonts bash bat biber binutils bison bleachbit \
+ bluez-firmware bluez-utils bookworm boost bzip2 chromium clisp compton \
+ coreutils cppcheck cppreference cppreference-devhelp cpupower cronie \
+ cryptsetup cups device-mapper dhcpcd diffutils discord-canary discount \
+ ditaa dmenu dmenu-lpass docker docker-compose doxygen dwarffortress \
+ e2fsprogs emacs exfat-utils fakeroot feh ffmpegthumbnailer file \
+ filesystem findutils fingerprint-gui firefox fish flake8 flex \
+ font-mathematica fontforge freeglut fzf gawk gcc gcc-libs gdb gettext \
+ gimp git glibc gnome-disk-utility gnome-epub-thumbnailer gnu-free-fonts \
+ gnuplot go-tools grep gzip htop i3-gaps i3lock-blur i3status icecat-bin \
+ igdm-bin inetutils intel-ucode iproute2 iputils j4-dmenu-desktop \
+ jfsutils lastpass-cli less libnewt libtool licenses light linux-headers \
+ lldb logrotate lsof lvm2 m4 make man-db man-pages mate-polkit mdadm \
+ meson minted mpc mpd mpd-rich-presence-discord-git mpv mupdf-tools nano \
+ nasm ncdu ncmpcpp nemo-fileroller nemo-preview neofetch netctl \
+ networkmanager networkmanager-openvpn nm-connection-editor nnn nomacs \
+ noto-fonts-emoji npm ntfs-3g openmp openssh p7zip pacman pacman-contrib \
+ pandoc-bin patch pavucontrol pciutils pcurses pdfpc perl pkgconf polybar \
+ procps-ng psmisc pulseaudio-bluetooth python-envtpl-git python-pip \
+ python-pywal qemu r raw-thumbnailer redshift refind-efi reflector \
+ reiserfsprogs rofi rofi-wifi-menu-git rsync rtv rustup s-nail samba \
+ scrot sdl2_gfx sdl2_image sdl2_mixer sdl2_ttf sed sent shadow siji-git \
+ simplescreenrecorder speedcrunch sshfs st-luke-git sudo sysfsutils \
+ systemd-sysvcompat tar texinfo texlive-bibtexextra texlive-bin \
+ texlive-core texlive-fontsextra texlive-formatsextra texlive-games \
+ texlive-humanities texlive-langchinese texlive-langcyrillic \
+ texlive-langextra texlive-langgreek texlive-langjapanese \
+ texlive-langkorean texlive-latexextra texlive-music texlive-pictures \
+ texlive-pstricks texlive-publishers texlive-science tmux tree \
+ ttf-arphic-uming ttf-baekmuk ttf-bitstream-vera ttf-dejavu \
+ ttf-google-fonts-opinionated-git ttf-joypixels ttf-liberation \
+ ttf-material-design-icons-git ttf-ms-fonts ttf-symbola \
+ ttf-tibetan-machine ttf-twemoji-color ttf-unifont unicode unicode-emoji \
+ unrar usbutils util-linux valgrind vi vim vulkan-headers w3m wget which \
+ whois x11-ssh-askpass xclip xdg-user-dirs-gtk xf86-input-wacom \
+ xf86-video-intel xfce4-power-manager xfsprogs xorg-server xorg-xinit \
+ xss-lock yadm graphviz xorg-xprop
+ #+END_SRC
+ Given how many packages will be install from the AUR, I’ll probably have to
+ type my password a few times.
+
+ For some reasons, if you directly install =compton-tryone-git= without
+ installing =compton= first, the package won’t work, which is why I made you
+ install =compton= in the command above. Now you can install
+ =compton-tryone-git=. It will replace =compton=, so say “yes” when it warns
+ you about the package conflict and whether =compton= should be removed.
+ #+BEGIN_SRC fish :exports code
+ yay -S compton-tryone-git
+ #+END_SRC
+
+** Enable and start some services
+ As you can see above, docker has been installed. Let’s enable and start its
+ service.
+ #+BEGIN_SRC fish :dir /sudo:: :exports code
+ systemctl enable docker
+ systemctl start docker
+ #+END_SRC
+ I also usually add myself as a member of the =docker= group because I don’t
+ like prefixing every single docker command with =sudo=. So let’s execute this
+ command:
+ #+BEGIN_SRC fish :exports code
+ sudo usermod -aG docker $USER
+ #+END_SRC
+
+ Depending on my machine, I might enable the SSH server shipped with
+ =openssh=. Edit your =/etc/ssh/sshd_config= file as needed, then let’s do
+ that here:
+ #+BEGIN_SRC fish :dir /sudo:: :exports code
+ systemctl enable sshd
+ systemctl start sshd
+ #+END_SRC
+
+** Install Fisher and our fish shell extensions
+ As mentionned above, I use the fish shell as my main shell. And I use some
+ extensions too that I installed from fisher, and custom functions.First,
+ let’s install fisher:
+ #+BEGIN_SRC fish :exports code
+ curl https://git.io/fisher --create-dirs -sLo \
+ ~/.config/fish/functions/fisher.fish
+ #+END_SRC
+
+ Awesome! Now, onto the fisher packages:
+ #+BEGIN_SRC fish :exports code
+ fisher add edc/bass franciscolourenco/done jethrokuan/fzf jethrokuan/z \
+ jorgebucaran/fish-getopts laughedelic/pisces matchai/spacefish \
+ tuvistavie/fish-ssh-agent
+ #+END_SRC
+ Now our fish shell is ready to rock! Plus, we already have our custom
+ functions installed from our dotfiles!
** Install packages from git
Now, we move on to the installation of git-based packages.
@@ -375,30 +409,73 @@
git clone https://github.com/hakimel/reveal.js.git
#+END_SRC
+** Set your locale
+ Arch’s default locale configuration is crap. Like… really. It took me a while
+ to figure out why some elements in polybar didn’t work along with some other
+ pieces of software. So, go and uncomment the locales you’ll use in
+ =/etc/locale.gen=. I personally have =en_US.UTF-8=, =fr_FR.UTF-8= and
+ =ja_JP.UTF-8= uncommented, but what you choose is really up to you. Then run
+ the following command as sudo.
+ #+BEGIN_SRC fish :dir /sudo:: :exports code
+ locale-gen
+ #+END_SRC
+
+ Now you can edit your =/etc/locale.conf= file. Mine looks like this, edit it
+ to fit your needs.
+ #+BEGIN_SRC conf :exports code
+ LANG=en_US.UTF-8
+ LC_COLLATE=C
+ LC_NAME=fr_FR.UTF-8
+ LC_NUMERIC=fr_FR.UTF-8
+ LC_IDENTIFICATION=fr_FR.UTF-8
+ LC_TELEPHONE=fr_FR.UTF-8
+ LC_MONETARY=fr_FR.UTF-8
+ LC_PAPER=fr_FR.UTF-8
+ LC_ADDRESS=fr_FR.UTF-8
+ LC_TIME=fr_FR.UTF-8
+ LC_MEASUREMENT=fr_FR.UTF-8
+ #+END_SRC
+
+** Launch X
+ Aaaand we should finally be good to launch X for the first time! My
+ installation logs me in the tty by default, and I do this by choice, I don’t
+ really like display managers or desktop environments. So, to launch i3, let’s
+ run =startx=.
+
** Install Rust
*** Install the toolchains
When using rust, I bounce between two toolchains, the =stable= toolchain and
the =nightly= toolchain. To install them, I will use =rustup= which has
already been installed.
#+BEGIN_SRC fish :exports code
- rustup default stable
+ rustup default nightly
#+END_SRC
- This will both download the stable toolchain and set it as the default one.
- Now to install the nightly toolchain, let’s run this:
+ This will both download the nightly toolchain and set it as the default one.
+ Yup, I like to live dangerously. Now to install the stable toolchain, let’s
+ run this:
#+BEGIN_SRC fish :exports code
- rustup toolchain install nightly
+ rustup toolchain install stable
#+END_SRC
- This one is updated about daily (hence the name), so we’ll often have to run
- the following command:
+ The nightly toolchain is ironically updated about daily (hence the name…
+ sort of?), so we’ll often have to run the following command:
#+BEGIN_SRC fish :exports code
rustup update
#+END_SRC
+*** Install some utilities
+ We’ll need some utilities when developing Rust from Emacs, namely =rustfmt=
+ and =racer=. Let’s install them with =cargo=.
+ #+BEGIN_SRC fish
+ cargo install rustfmt racer
+ #+END_SRC
+
** Clean the =pacman= and =yay= cache
Finally, we are almost done! Let’s clean the cache of =pacman= and =yay=
#+BEGIN_SRC fish :dir /sudo:: :exports code
yay -Sc --noconfirm
#+END_SRC
+ You should now run a system pretty close to the one I have on my main
+ computer and my thinkpad.
* Licence
All of my dotfiles (and my dotfiles only) are available under the GNU GPLv3