2023-03-08 08:10:57 +01:00
|
|
|
|
(define-module (oni home services picom)
|
2023-03-08 08:28:23 +01:00
|
|
|
|
#:use-module ((gnu services configuration)
|
|
|
|
|
#:select (alist?
|
|
|
|
|
define-configuration
|
|
|
|
|
serialize-configuration
|
|
|
|
|
serialize-package))
|
|
|
|
|
#:use-module ((gnu packages compton)
|
|
|
|
|
#:select (picom))
|
|
|
|
|
#:use-module ((gnu home services)
|
|
|
|
|
#:select (home-profile-service-type
|
|
|
|
|
home-xdg-configuration-files-service-type
|
|
|
|
|
service-extension
|
|
|
|
|
service-type))
|
|
|
|
|
#:use-module ((gnu home services shepherd)
|
|
|
|
|
#:select (home-shepherd-service-type
|
|
|
|
|
shepherd-service))
|
|
|
|
|
#:use-module ((guix packages)
|
|
|
|
|
#:select (package?))
|
|
|
|
|
#:use-module ((guix gexp)
|
|
|
|
|
#:select (computed-file
|
|
|
|
|
file-append
|
|
|
|
|
gexp))
|
|
|
|
|
#:use-module ((srfi srfi-1)
|
|
|
|
|
#:select (concatenate))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
|
|
|
|
#:export (home-picom-service-type
|
|
|
|
|
home-picom-configuration))
|
|
|
|
|
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(define (serialize-alist field value)
|
|
|
|
|
(string-append
|
|
|
|
|
(symbol->string field)
|
|
|
|
|
": {\n"
|
|
|
|
|
(apply string-append
|
|
|
|
|
(map (lambda (type)
|
|
|
|
|
(string-append
|
|
|
|
|
" "
|
|
|
|
|
(symbol->string (car type))
|
|
|
|
|
" = "
|
|
|
|
|
(cond
|
|
|
|
|
((list? (cdr type))
|
|
|
|
|
(string-append
|
|
|
|
|
"{ "
|
|
|
|
|
(apply string-append
|
|
|
|
|
(map (lambda (option)
|
|
|
|
|
(string-append (symbol->string (car option)) " = " (if (cdr option) "true" "false")))
|
|
|
|
|
(cdr type)))
|
|
|
|
|
" },"))
|
|
|
|
|
((string? (cdr type))
|
|
|
|
|
(string-append "\"" (cdr type) "\";"))
|
|
|
|
|
((number? (cdr type))
|
|
|
|
|
(string-append (number->string (cdr type)) ";")))
|
|
|
|
|
"\n"))
|
|
|
|
|
value))
|
|
|
|
|
"}\n"))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(define (serialize-boolean field value)
|
|
|
|
|
(string-append (symbol->string field) " = " (if value "true" "false") ";\n"))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(define (serialize-list field value)
|
|
|
|
|
(string-append (symbol->string field) " = [\n"
|
|
|
|
|
(apply string-append (map (lambda (item)
|
|
|
|
|
(string-append " \"" item "\",\n"))
|
|
|
|
|
value))
|
|
|
|
|
"];\n"))
|
|
|
|
|
|
|
|
|
|
(define (serialize-number field value)
|
|
|
|
|
(string-append (symbol->string field) " = " (number->string value) ";\n"))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(define (serialize-percentage field value)
|
|
|
|
|
(serialize-number field (/ value 100.0)))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(define (serialize-string field value)
|
|
|
|
|
(string-append (symbol->string field) " = \"" value "\";\n"))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(define (percentage? value)
|
|
|
|
|
(and (number? value)
|
|
|
|
|
(<= 0 value 100)))
|
|
|
|
|
|
|
|
|
|
(define-configuration home-picom-configuration
|
|
|
|
|
(package
|
|
|
|
|
(package picom)
|
|
|
|
|
"Package to use for setting Picom")
|
|
|
|
|
(backend
|
|
|
|
|
(string "xrender")
|
|
|
|
|
"Specify the backend to use: xrender, glx, or xr_glx_hybrid")
|
|
|
|
|
(glx-no-stencil
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"GLX backend: avoid using stencil buffer, useful if you don’t have a stencil buffer")
|
|
|
|
|
(detect-transient
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time")
|
|
|
|
|
(shadow
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Enabled client-side shadows on windows")
|
|
|
|
|
(shadow-radius
|
|
|
|
|
(number 12)
|
|
|
|
|
"The blur radius for shadows, in pixels")
|
|
|
|
|
(shadow-opacity
|
|
|
|
|
(percentage 75)
|
|
|
|
|
"The opacity of shadows")
|
|
|
|
|
(shadow-offset-x
|
|
|
|
|
(number -15)
|
|
|
|
|
"The left offset for shadows, in pixels")
|
|
|
|
|
(shadow-offset-y
|
|
|
|
|
(number -15)
|
|
|
|
|
"The top offset for shadows, in pixels")
|
|
|
|
|
(shadow-exclude
|
|
|
|
|
(list '())
|
|
|
|
|
"Specify a list of conditions of windows that should have no shadow")
|
|
|
|
|
(wintypes
|
|
|
|
|
(alist '())
|
|
|
|
|
"Window-type-specific settings")
|
|
|
|
|
(corner-radius
|
|
|
|
|
(number 0)
|
|
|
|
|
"Sets the radius of rounded window corners")
|
|
|
|
|
(inactive-opacity
|
|
|
|
|
(percentage 100)
|
|
|
|
|
"Opacity of inactive windows")
|
|
|
|
|
(active-opacity
|
|
|
|
|
(percentage 100)
|
|
|
|
|
"Default opacity for active windows")
|
|
|
|
|
(frame-opacity
|
|
|
|
|
(percentage 100)
|
|
|
|
|
"Opacity of window titlebars and borders")
|
|
|
|
|
(inactive-opacity-override
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Let inactive opacity set by -i override the _NET_WM_WINDOW_OPACITY values of windows")
|
|
|
|
|
(blur-background
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Blur background of semi-transparent / ARGB windows")
|
|
|
|
|
(blur-background-frame
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Blur background of windows when the window frame is not opaque")
|
|
|
|
|
(blur-background-fixed
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Use fixed blur strength rather than adjusting according to window opacity")
|
|
|
|
|
(blur
|
|
|
|
|
(alist '())
|
|
|
|
|
"Configure how the window background is blurred")
|
|
|
|
|
(blur-background-exclude
|
|
|
|
|
(list '())
|
|
|
|
|
"Exclude conditions for background blur")
|
|
|
|
|
(focus-exclude
|
|
|
|
|
(list '())
|
|
|
|
|
"Specify a list of conditions of windows that should always be considered focused")
|
|
|
|
|
(fading
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Fade windows in/out when opening/closing and when opacity changes, unless no-fading-openclose is set")
|
|
|
|
|
(fade-in-step
|
|
|
|
|
(percentage 2.8)
|
|
|
|
|
"Opacity change between steps while fading in")
|
|
|
|
|
(fade-out-step
|
|
|
|
|
(percentage 3)
|
|
|
|
|
"Opacity change between steps while fading out"))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
|
|
|
|
(define (home-picom-config-file config)
|
2023-03-08 08:05:58 +01:00
|
|
|
|
(computed-file
|
|
|
|
|
"picom.conf"
|
|
|
|
|
#~(call-with-output-file #$output
|
|
|
|
|
(lambda (port)
|
|
|
|
|
(display #$(serialize-configuration config home-picom-configuration-fields) port)))))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
|
|
|
|
|
(define (home-picom-files-service config)
|
2023-03-08 08:05:58 +01:00
|
|
|
|
`(("picom.conf"
|
2022-04-06 06:47:45 +02:00
|
|
|
|
,(home-picom-config-file config))))
|
|
|
|
|
|
|
|
|
|
(define (home-picom-profile-service config)
|
|
|
|
|
(list (home-picom-configuration-package config)))
|
|
|
|
|
|
|
|
|
|
(define (home-picom-shepherd-service config)
|
|
|
|
|
(list
|
|
|
|
|
(shepherd-service
|
|
|
|
|
(documentation "Start Picom")
|
|
|
|
|
(provision '(picom))
|
|
|
|
|
(auto-start? #t)
|
|
|
|
|
(start
|
2022-04-21 02:24:05 +02:00
|
|
|
|
#~(make-forkexec-constructor
|
|
|
|
|
(list #$(file-append (home-picom-configuration-package config) "/bin/picom")
|
|
|
|
|
"--config" #$(home-picom-config-file config))
|
|
|
|
|
#:log-file (format #f "~a/.local/var/log/picom.log" (getenv "HOME"))))
|
2022-04-06 06:47:45 +02:00
|
|
|
|
(stop #~(make-kill-destructor)))))
|
|
|
|
|
|
|
|
|
|
(define home-picom-service-type
|
|
|
|
|
(service-type (name 'home-picom)
|
|
|
|
|
(extensions
|
|
|
|
|
(list (service-extension
|
2022-06-14 07:11:10 +02:00
|
|
|
|
home-xdg-configuration-files-service-type
|
2022-04-06 06:47:45 +02:00
|
|
|
|
home-picom-files-service)
|
|
|
|
|
(service-extension
|
|
|
|
|
home-profile-service-type
|
|
|
|
|
home-picom-profile-service)
|
|
|
|
|
(service-extension
|
|
|
|
|
home-shepherd-service-type
|
|
|
|
|
home-picom-shepherd-service)))
|
|
|
|
|
(compose concatenate)
|
|
|
|
|
(default-value (home-picom-configuration))
|
|
|
|
|
(description "Configure Picom")))
|
|
|
|
|
|
|
|
|
|
(define (generate-home-picom-documentation)
|
|
|
|
|
(generate-documentation
|
|
|
|
|
`((home-picom-configuration
|
|
|
|
|
,home-picom-configuration-fields))
|
|
|
|
|
'home-picom-configuration))
|