Guix + StumpWM Setup

Hey System Crafters,

I just joined as I will be taking the beginners course on Guile Scheme and thought I would post a link to my Guix system/home config for others to see:

This repo contains all of my Lisp configurations: Emacs, Nyxt, and StumpWM with Guix (a lot is influenced by System Crafter concepts). I have to say this definitely wasn’t an easy journey. I followed David’s prescription (GUI) for installing Guix and then StumpWM which had a lot of hickups along the way (contrib loading issues etc), not to mention configuring Xorg which was quite difficult. I still don’t really understand much about Guix yet, but at least my config is functional/useable at this point. Even currently using Nyxt to access this forum - which looks great by the way!

I am hoping others who want a similar system setup can learn from my mistakes and many many hours looking through gnu bug emails, nongnu Guix bug logs (Xorg lag issue) etc.

Also, not sure if I am doing the Guix System/Home right - still not sure how to incorporate manifests… and well the Guix manual hasn’t been of much help.

Cheers!

3 Likes

Congratulations for making it this far :smiley: We now share a very similar setup.

Wondering what problems you faced with the regular stumpwm setup, but oh well, if it is now working for you.

1 Like

Regarding %system-services, it has

(set-xorg-configuration
 (xorg-configuration
   (keyboard-layout keyboard-layout)))

which refers to keyboard-layout field of operating-system record that cannot be accessed in this way outside of that record.

You should write either

(set-xorg-configuration
 (xorg-configuration
   (keyboard-layout (keyboard-layout "us"))))

or

(define my-os
  (operating-system
    (keyboard-layout
     (keyboard-layout "us"))
    (services %system-services)
    ...))

(define %system-services
  ...
  (set-xorg-configuration
   (keyboard-layout
    (operating-system-keyboard-layout my-os))
  ...))

my-os

Possible reason for confusion is that we have three different keyboard-layouts here:
→ one from xorg-configuration record;
→ one from operating-system record;
→ and a procedure that we can pass on to others two above.

2 Likes

One possible futher improvement is to move more things into .scm files. Your configuration can be written entirely in scheme if you find it convenient.

I also recommend you the rde channel which contains a lot of useful stuff, such as home-emacs-service-type, home-xresources-service-type, home-nyxt-service-type and so on.

1 Like

Thanks mrok - appreciate the feedback. the stuff defined in %system-services is not used as I am not passing it to (services …) currently.

I thought the same, and what’s odd is that those two instances of keyboard-layout is what my initial setup from the installer put there! (why? shouldn’t it know better?). After consulting the manual is seems that I needs both instances (?), which is confusing or rather the manual is still highly confusing for me…

Thanks for the reference, I did stumble across andrew tropin’s rde channel, but it’s a bit more advanced than my current understanding of guix and in the manual it seemed positioned for sway.

That’s my goal to nest as much of my “base” configuration in scheme, then keep optional modules as files in their corresponding directories, then also tell guix to put copy/link them in those locations.

Thanks sls! Hopefully we can chat more as we figure things out!

The main issues I faced with StumpWM and Guix was figuring out a way to use common lisp contrib modules, since on other distros they are installed with quicklisp but on guix you want to use guix :slight_smile: to install them. When starting the default guix built stumpwm executable from .xsession, it would try to compile the common lisp contrib stuff and then error out with a read only error. I then found this was a known issue - here on the gnu bug mail archives. I applied the workaround in that email and all is well :slight_smile: at least for now.

Also found out that the Guix Cookbook was misleading in how to setup StumpWM - it outright doesn’t work (at all). Also, in order for the workaround mentioned above to work, you have to install StumpWM in your guix home and not at the system-wide level.

The installer did everything right.

(set-xorg-configuration
 (xorg-configuration
   (keyboard-layout keyboard-layout)))

won’t work only if you put it outside of operating-system. The installer puts it inside.

One more thing you can do:

(define my-keyboard-layout
  (keyboard-layout "us"))

(define %system-services
  (cons* (set-xorg-configuration
          (xorg-configuration
            (keyboard-layout my-keyboard-layout)))
         %desktop-services))

(operating-system
  (keyboard-layout my-keyboard-layout)
  (service %system-services))

And, in fact, the keyboard-layouts from operating-system and xorg-configuration default to US English, so you probably don’t need to write anything at all.

1 Like

The Stumpwm section in the Cookbook is likely out of date and was written before Guix Home was created.

This worked, thank you!

It’s still a bit unclear as to why this works, is it because when (keyboard-layout "us") is defined outside in %system-services, it is considered a different object than the expression that is specified in operating-system, hence you need to define a variable for it to pass to both instances for it to be recognized as the same?

I suggested this option because I thought it might be convenient. You don’t have to create a separate variable for (keyboard-layout "us") if you don’t want to. All you have to do is access (operating-system (keyboard-layout)) correctly from outside (operating-system) or not access it at all. So the first two options I suggested will work too.

(define my-keyboard-layout
  (keyboard-layout "us"))

(define %system-services
  (cons* (set-xorg-configuration
          (xorg-configuration
            (keyboard-layout my-keyboard-layout)))
         %desktop-services))

(operating-system
  (keyboard-layout my-keyboard-layout)
  (service %system-services))

I find this solution most aesthitically pleasing - really appreciate your feedback and committed that solution to my repo! :wink:

PS - edited this post, your previous post finally made sense regarding the three different keyboard-layouts (xorg-configuration, operating-system, and a procedure…). I get it now - when defining it outside of (operating-system) we need to use the procedure, which in tern can be pass to to the previous two as you stated.

1 Like

Wanted to provide an Update - I’ve recently come back to this setup after distro-hoping to see what other Linux Distros were like: NixOS, Arch, Fedora 40 (Workstation and Silverblue). But, none provided an experience that Guix could provide - so here I am back and riding the last few waves of X11 before Wayland fully takes over… Though, StumpWM shall survive through Mahogany (GitHub - stumpwm/mahogany: A stumpwm like Wayland compositor).

At any rate, this configuration is nearing completion, and with help as one can see from help above. Just need a few tweaks to get Bluetooth functioning and to remove deploy shell scripts and let Guix do all the heavy lifting, perhaps via home-xdg-configuration-file-service-type

I’ve been religiously using David’s Beginners to Guile course literature as reference for Guile writing, was definitely worth doing the course - though I was only able to keep up the first 4 weeks, as work and personal stuff took over, but nevertheless it’s there for me to come back to and pickup where I left off.

PS: I named the repo guix-craft as homage to this wonderful community: guix-craft/README.org at main · logoraz/guix-craft · GitHub

2 Likes

Yet another update! This post has effectively become a blog of my journey into Guix System, Lisp (guile + Common Lisp), and wanted to share.

Throughout my development of Guix+StumpWM, Phundrak’s Blog was my inspiration. Also, the website is amazingly composed and well written for noobs and probably even experts.

I finally hit the benchmark! My config borrowed many features but tailored it to suit my style - took a while to use and update the code offered in Phundrak’s blog. Posting a screenshot here for any of those interested!

1 Like

Just wanted to say that blog link is a really good find. I wanted to ask how is stumpwm? I’m always curious what the workflow is like for others.

ps. your setup/screenshots look really cool

Hey @iamtired,

I personally like StumpWM workflow, though the only other window manager setup I’ve used was EXWM - StumpWM is much better in my use case. I also like it better than Gnome.

My workflow is framed out with what I do: HOME (aka Emacs/Files Stuff), TERM (now DEV - dev/terminal system administration stuff), WWW (web related), ETC (other things, like Gimp or other apps), and PRIV (financial stuff …), haven’t played around much yet with window/frame manipulation, but usually just do a two to 4 window split.

Thanks - I wasted most of my time trying to making the limited features configured as nice/beautiful as possible!

Hey, your config looks great!
I’m trying to imitate that, but I’m getting an error:

could not load or find module ttf fonts 

The sbcl repl says:

> (require 'clx-truetype)
#<SB-SYS:FD-STREAM for "file /gnu/store/fzd5882vj7clw1n9f0xp3w4n3kk2y4pp-sbcl-clx-0.7.6-1.69f2ebb/lib/common-lisp/sbcl/clx/package.fasl" {1001A4B5C3}>
is a fasl file compiled with SBCL 2.4.10, and can't be loaded into SBCL 2.4.7..

I don’t know what to do, any help would be appreciated :slight_smile:

Hey thank you!

It’s bits and pieces borrowed and tied together from many great Common Lispers…

Ahh I know exactly what that is - that is from me playing around with package transformations to trial out the latest release of sbcl. The problem is sbcl-clx-truetype expects the version of sbcl currently available in Guix. This is stemming from the package transformation that pulls in sbcl 2.4.10 (in config/system/system.config):

just comment out or remove:

(define latest-sbcl
  (options->transformation
   '((with-latest . "sbcl"))))

and change (latest-sbcl sbcl) to just sbcl in the packages definition, i.e.

(define stumpwm-base-packages
  (list sbcl
        stumpwm+slynk))

I believe that should resolve that issue… When experimenting, it worked for me, b/c I already had previous cached fasls for the older sbcl, however, when I remove them to start from a clean slate I encountered the same problem as you… just forgot to update my code… And then moved to sway to give wayland a try until stumpwm/mahogany is in a usuable state.

Let me know if that works!

I fixed the code btw as stated above. Note that I migrated my repos over to Codeberg:

This is where any active development will occurr on this project. Haven’t yet decided if I will mirror on GitHub. Also, if you are interested in Sway, I’ve set up a pretty cool Guix setup that is much more optimized and tested than my StumpWM setup, it’s repo is my dotfiles if there is any interest (loraz/dotfiles: Custom Guix System Distribution + Sway Configuration. - Codeberg.org).

A few screenshots of it: