FT-Labs / pdwm

full animation supported, easy configurable (uses shared library) dwm fork with a control center (pdwmc)
MIT License
417 stars 17 forks source link
coolui dwm linux suckless windowmanager

pdwm & phyOS-dwm

pdwm & phyOS-dwm are both suckless dwm forks. Both of them are in this repo, please read below to understand why. Also note that dwmblocks is embedded in this project, you don't need to download it from somewhere else.

For full animation support, please install phyOS-picom fork. Any other picom fork won't work.

phyOS-dwm is the oldest master branch of this project. This has been changed to pdwm branch. phyOS-dwm is just modified suckless dwm, with dwmblocks in it. Please note that this dwmblocks uses libconf library, which you can add/remove statusbar blocks with .cfg files. Also more than 10 statusbar blocks available for phyOS users. However, all of these can be installed on base arch linux too. Statusbar configuration can be made easily with pOS-make-bar script.

Settings button on top left (blue one) will open up a terminal application, which you can choose powermenu themes - colorschemes, and animation options from there. It also has some extra scripts in it to make your statusbar, choose sddm & grub themes.

Gifs

alt text alt text

Screenshots

(Alt + Tab to switch windows)

(Hide and restore windows from bottom dock (Check keys for how to do this))

(catppuccin & tokyo night theme)

(Power menu 'right one is to renew dwm without restart')

Why the change? What is pdwm?

Originally, dwm configuration options are compiled into a single binary. Therefore, to be able to change any attribute you need to edit configuration file and recompile it into dwm again. With pdwm, this changes. Since dwm is supposed to be minimalistic and performant, simply putting a configuration library to handle these options doesn't make sense. It will increase SLOC a lot. To overcome this issue, another simple method has been made: All of the configuration variables in dwm (nearly everything, except some edge cases) have been marked as extern variables. In pdwm folder, you can see all the configuration options. These options are made a shared library (.so). With this flexibility, and minor lines of code, at the execution stage of dwm, all of the variables are being loaded into dwm from an outside source, which is the shared library. This way, by just compiling the variables and renewing dwm, all options have been renewed. Without even using sudo. Note that from now on, mostly pdwm will get updated. However, the older fork, phyOS-dwm is still available on master branch. This is much of a choice now, choose whatever you prefer. The tool to configure dwm is a python program, which is called pdwmc. It is the main control center of pdwm. Link: https://github.com/FT-Labs/pdwmc

pdwm Usage

IMPORTANT: Please extend your "LD_LIBRARY_PATH" to this location: E.G: export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$HOME/.config/phyos/pdwm" You must do this, because fallback library will be in /usr/lib. Your local configurations (.so) file will be stored here, and you must extend it to this place for linux ld linker to be able to see it. As said before pdwm is a simple python program. It both has support for changing/printing any configuration options from terminal, or via QT app. Now lets get on with options.

usage: pdwmc [-h] [-w] [-b] [-g] [-s {appearance,buttons,keys,rules}]
            [-c {appr,font,button,key,rule}] [-a {font,button,key,rule}]
            [-d {font,button,key,rule}] [-q]

options:
  -h, --help            show this help message and exit
  -w, --write           Write current dwm configuration to edit [Use this before to
                        edit dwm configuration] or reset your changes
  -b, --build           Save changes to dwm
  -g, --get             Get default dwm settings (overrides current) to use pdwm,
                        also runs -w flag
  -s {appearance,buttons,keys,rules}, --show {appearance,buttons,keys,rules}
  -c {appr,font,button,key,rule}, --change {appr,font,button,key,rule}
                        Choose and change attribute
  -a {font,button,key,rule}, --add {font,button,key,rule}
                        Add new attribute
  -d {font,button,key,rule}, --delete {font,button,key,rule}
                        Delete an attribute
  -q, --qt              Run pdwm as a QT application

If you prefer a gui application, just run pdwmc -q. It is a simple and editable QT app, also catches your keypresses, which will save you some time from learning keysym's from internet. If key is not detected, simply find it from google and edit the key.

pdwmc screenshots

To be able to install these, please follow the steps below. Also if interested, you can download iso image to a vm, build it then update to system to be able to try.

These explanations are only for arch linux based distributions (any pacman using distro is okay). There are important dependencies, which I could not find all packages to fit all distributions. Later on a debian package version may come too.

Append package repo end of your /etc/pacman.conf :

[phyOS-repo]
SigLevel = Required DatabaseOptional
Server = https://FT-Labs.github.io/$repo/$arch

After adding the repo, install keyring first:

sudo pacman-key --recv-key 964FD85861C858D7
sudo pacman-key --lsign-key 964FD85861C858D7
sudo pacman -Syy phyOS-keyring
sudo pacman-key --init
sudo pacman-key --populate phyOS

Now install necessary packages (This will install most of the phyOS packages, if you which packages to choose simply install them, this is a general guide): sudo pacman -Syy curl https://raw.githubusercontent.com/FT-Labs/phyOS-Aug-22/master/packages.x86_64 | sed -e '/\#/d' | tr -s "\n" | xargs sudo pacman -S --noconfirm After the installation, please reboot your computer. Now you will need dotfiles, please move your current dots to somewhere else if they are important. Run: phyup dots --force to get latest dotfiles. This is required to set your .xinitrc, .xprofile and picom options etc. correctly. Anyway, if you want you can just check dotfiles repo and choose whatever is required from there. pdwm Packages: pdwm pdwmc phyOS-dwm (classic compiled dwm) packages: phyOS-dwm

Running:

Simply run startx from tty, or use a display manager. Desktop file is automatically made and installed.

NOTE: Caps Lock == Win

NOTE: Caps Lock is also equal to ESC in terminal (vim etc..)

Program Keys (man dwm will work too, or try keys sheet):

Key Combination | Action ----------------- | ---------- Win + q | Quit focused Win + Return | Terminal(st) Win + ESC | Power menu Win + Shift + Return | Scratchpad (Terminal) [Press again to toggle] Win + w | $BROWSER(default ungoogled chromium) Win + r | File Browser (lf) Win + a | Execute Applications (rofi) Win + b | Toggle status bar (hide) Win + d | Jump to directory with terminal (check 'bm' script to add bookmarks) Win + Shift + a | Execute Any Runnable (dmenu) Win + p | passmenu (pass password manager) Alt + p | stress test and monitor (s-tui) Win + F4 | pulsemixer (audio input) Win + F5 | set multiple monitors and choose refresh rate Win + F9 | mount drive Win + F10 | unmount drive Win + F11 | Camera Win + Shift + s | Screenshot (choose area or screen) Printscreen | Screenshot fullscreen Shift + Printscreen | Screenshot (choose area or screen) Win + \` | Choose emoji and copy
## Terminal keybinds
Key Combination | Action ----------------- | ---------- Alt + Shift + j | Decrease font size (zoom -) Alt + Shift + k | Increase font size (zoom +) Alt + o | Copy output of command Alt + ; | Cycle fonts
## Window Movement
Key Combination | Action ----------------- | ---------- Win + Tab | Choose window from current desktop Alt + Tab | Choose any window and focus Win + j | Focus next Win + Shift + j | Move focused to next Win + k | Focus previous Win + Shift + k | Move focused to previous Win + l | Resize master + Win + Shift + h | Next Tag Win + h | Resize master - Win + Shift + h | Previous Tag Win + s | Sticky window toggle (show window in all tags) Win + f | Fullscreen (toggle) Win + g | Toggle gaps Win + x | Decrease gaps Win + Shift + x | Increase gaps Win + Shift + g | Set default gaps Win + m | Increase master (just try it to understand) Win + Shift + m | Decrease master (just try it to understand) Win + Space | Set focused as master Win + Shift + Space | Toggle floating window
## Layouts ### You can Right Click RMB on ' []= ' in status bar to choose layout with mouse
Key Combination | Action ----------------- | ---------- Alt + 1 | Tiling (Default) Alt + 2 | Backstack Alt + 3 | Monocle (windows top of each) Alt + 4 | Deck layout Alt + 5 | Spiral Alt + 6 | Dwindle Alt + 7 | Centered master Alt + 8 | Centered floating master Alt + 9 | Floating (windows 10 style) Win + Right | Cycle layout next Win + Left | Cycle layout previous
## Tag operations ### You can Left Click LMB on 1-9 in status bar to focus tag ### You can Right Click RMB on 1-9 in status bar to select multiple tags
Key Combination | Action ----------------- | ---------- Win + 1 .. 9 | Go to tag **number** Win + WheelUp | Go to next tag Win + WheelDown | Go to previous tag Win + Shift + 1 .. 9 | Send focused window to tag **number**
## Utility keys
Key Combination | Action ----------------- | ---------- Sound Up | Increase sound Sound Down | Decrease sound Brightness Down | Decrease brightness Brightness Up | Increase brightness fn + TouchpadToggle | Toggle touchpad fn + Kbd Backlight Up | Increase keyboard backlight fn + Kbd Backlight Down | Decrease keyboard backlight
## Mouse actions
Key Combination | Action ----------------- | ---------- RMB | Open Dropdown Menu (On Root Window) Win + RMB | Open Dropdown Menu (On Any Client) Win + LMB | Move window with mouse (sets window to floating mode) Win + MMB | Resize window with mouse (sets window to floating mode) Alt + LMB | Hide focused window (iconic state, restore it from dock) Alt + RMB | Toggle dock