Skip to content

BeanGreen247/ArchLinux-KDE-Plasma-setup-script

Repository files navigation

ArchLinux KDE Plasma setup script

Credit for neofetch theme used goes to Chick2D and his neofetch-themes project.

Credit for the note taking app used goes to Laurent Cozic and their app project Joplin.

Info

A script that automates the etire process of setting up the full KDE plasma desktop env with some additional apps and tweaks to make it more usable for my usecase.

Some pre requisites

Downloading the script

wget https://raw.githubusercontent.com/BeanGreen247/ArchLinux-KDE-Plasma-setup-script/main/setupArchLinux.sh

Executing the script

bash setupArchLinux.sh

Script variables

Please make sure to adjust for your system before running the script. I have tested in a VM so here is what the variables looked like for me

No longer needed as now the script will request user input for these vars

function main {
    ### VARS
    echo -n "Enter username: "
    read usernameinput
    username="$usernameinput"
    echo -n "Enter root password: "
    read -s password
    pass="$password"
    echo -n "Enter gpu type [intel or amd or nvidia]: "
    read gpu
    gpudriver="$gpu"
    zramsize=32768 #check Setting up zram
    ...some more code down there

VARS

  • pass - the users password or password for the root account in case use is not root user
  • username - the users username or username for the root account in case use is not root user
  • gpudriver - which GPU driver to install there are 3 options AMD or NVIDIA or INTEL and take one of these 3 inputs
    • amd - to install AMD open source drivers
    • nvidia - to install proprietary NVIDIA drivers
    • intel - to install INTEL open source drivers
  • zramsize - the size of zram in MB

zram

In this section of the script we set up zram to be used alongside swap and its size is defined by the amount in MB set up in the VARS section of the script...

echo -e "\e[1;31m[Setting up zram...]\e[1;0m\n"
echo $pass | sudo -S echo '# This config file enables a /dev/zram0 device with the default settings:' | sudo tee /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo '# - size - same as available RAM or 32GB, whichever is less' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo '#        - if your system/VM has 16GB RAM then change it from 32768 to 16384' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo '# - compression - most likely lzo-rle' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo '# To disable, uninstall zram-generator-defaults or create empty' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo '# /etc/systemd/zram-generator.conf file.' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo '[zram0]' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S echo 'zram-size = min(ram, '$zramsize')' | sudo tee -a /usr/lib/systemd/zram-generator.conf
echo $pass | sudo -S systemctl daemon-reload
echo $pass | sudo -S systemctl start /dev/zram0
echo $pass | sudo -S zramctl
echo -e "Setting up zram...\e[1;32m[DONE]\e[1;0m"

You can check if it got applied by running zramctl in the terminal.

Some more script information

There are some sections where user input is expected so please make sure to read the prompts and when promped please be ready to use you accounts details to proceed.

To expand on the autostart portion of the script

To create an autostart option Open System Settings then go into Startup and Shutdown there select the Autostart settings menu and add a Login script, navigate to the script that was created and add it, next click on properties and make sure it is executable and that everyone can wiev and execute the script, also in the command section make sure to add a . (dot) at the beginning like so

./home/test/scripts/execute-performance-mode-sh-as-root.sh

or

bash /home/test/scripts/execute-performance-mode-sh-as-root.sh

make sure to change the location of the script based on your setup, but if you used the script then the file should be located in the scripts directory as show in the example above.

The script that we added at startup/on login will set the cpu scaling governor to performance once in linux

to check run cat /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor

If it says performace one or multiple times, that means it worked.

pacman.conf

Is used to keep system stable and updates minimal.

pacman.conf

powerDownAllVMs.sh

a script that powers down a set kVM based on the name

powerDownAllVMs.sh

Please make sure to install xdotool using your package manager

sudo pacman -S xdotool

freeMem.sh

a small or shall I say tiny script to clean up memory

freeMem.sh

kVMeventIDDialog.sh

a script that creates a dialog at startup telling the user what to use in virt-manager for VM low latency inputs

kVMeventIDDialog.sh

fonts

you may want to reinstall all nerd fonts after system update

sudo pacman -S --noconfirm otf-aurulent-nerd otf-cascadia-code-nerd otf-codenewroman-nerd otf-droid-nerd otf-firamono-nerd otf-hasklig-nerd otf-hermit-nerd otf-opendyslexic-nerd otf-overpass-nerd ttf-3270-nerd ttf-agave-nerd ttf-anonymouspro-nerd ttf-arimo-nerd ttf-bigblueterminal-nerd ttf-bitstream-vera-mono-nerd ttf-cousine-nerd ttf-daddytime-mono-nerd ttf-dejavu-nerd ttf-fantasque-nerd ttf-firacode-nerd ttf-go-nerd ttf-hack-nerd ttf-heavydata-nerd ttf-iawriter-nerd ttf-ibmplex-mono-nerd ttf-inconsolata-go-nerd ttf-inconsolata-lgc-nerd ttf-inconsolata-nerd ttf-iosevka-nerd ttf-jetbrains-mono-nerd ttf-lekton-nerd ttf-liberation-mono-nerd ttf-lilex-nerd ttf-meslo-nerd ttf-monofur-nerd ttf-monoid-nerd ttf-mononoki-nerd ttf-mplus-nerd ttf-nerd-fonts-symbols-common ttf-noto-nerd ttf-profont-nerd ttf-proggyclean-nerd ttf-roboto-mono-nerd ttf-sharetech-mono-nerd ttf-sourcecodepro-nerd ttf-space-mono-nerd ttf-terminus-nerd ttf-tinos-nerd ttf-ubuntu-mono-nerd ttf-ubuntu-nerd ttf-victor-mono-nerd

and do the same for japanese fonts

sudo pacman -S --noconfirm noto-fonts-cjk noto-fonts-emoji noto-fonts

Troubleshooting

In case of any problems you could try rerunning the script more times just to be sure all got applied. If an error appears make sure to raise an Issue https://github.com/BeanGreen247/ArchLinux-KDE-Plasma-setup-script/issues with a lot of detail so that we can minize the amount of time required to fix issues.


BeanGreen247, 2023

About

A script that automates the etire process of setting up the full KDE plasma desktop env with some additional apps and tweaks to make it more usable for my usecase.

Topics

Resources

Stars

Watchers

Forks