2024-06-15 09:57:11 +02:00
|
|
|
;; use example:
|
|
|
|
|
2024-06-18 18:05:39 +02:00
|
|
|
;; (workspace-grid-configure #:rows 2 #:columns
|
|
|
|
;; '(("ws-o1-1" "ws-o1-2" "ws-o1-3" "ws-o1-3")
|
|
|
|
;; ("ws-o2-1" "ws-o2-2" "ws-o2-3" "ws-o2-3")
|
|
|
|
;; ("ws-o3-1" "ws-o3-2" "ws-o3-3" "ws-o3-3")))
|
2024-06-15 09:57:11 +02:00
|
|
|
;; (workspace-grid-init)
|
|
|
|
|
|
|
|
(define-module (modules workspace-grid)
|
|
|
|
#:use-module (swayipc records)
|
|
|
|
#:use-module (swayipc info)
|
|
|
|
#:use-module (swayipc dispatcher)
|
|
|
|
#:use-module (swayipc events)
|
|
|
|
|
2024-06-18 16:15:44 +02:00
|
|
|
#:export (WORKSPACES
|
2024-06-15 09:57:11 +02:00
|
|
|
COLUMNS
|
|
|
|
ROWS
|
2024-06-18 14:21:36 +02:00
|
|
|
workspace-grid-configure
|
2024-06-15 09:57:11 +02:00
|
|
|
get-active-workspace-index
|
|
|
|
switch-workspace-up
|
|
|
|
switch-workspace-right
|
|
|
|
switch-workspace-down
|
|
|
|
switch-workspace-left
|
|
|
|
move-container-to-workspace-up
|
|
|
|
move-container-to-workspace-right
|
|
|
|
move-container-to-workspace-down
|
|
|
|
move-container-to-workspace-left
|
|
|
|
valid-grid?
|
|
|
|
workspace-grid-init))
|
|
|
|
|
|
|
|
;; The order in which the outputs are organized, it's important that
|
|
|
|
;; the order of outputs match the order of workspaces in `WORKSPACE`
|
|
|
|
(define WORKSPACES '())
|
|
|
|
|
|
|
|
;; number of rows in the grid
|
|
|
|
(define ROWS 1)
|
|
|
|
;; number of columns in the grid
|
|
|
|
(define COLUMNS 1)
|
|
|
|
|
2024-06-18 14:21:36 +02:00
|
|
|
(define* (workspace-grid-configure #:key rows columns workspaces)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Configure workspace grid.
|
|
|
|
Parameters:
|
|
|
|
- rows: number of rows in the grid.
|
|
|
|
- columns: number of columns in the grid
|
|
|
|
- workspaces: list of list of workspaces. should match the amount of outputs.
|
|
|
|
|
|
|
|
Example: configuring a 2x2 workspace grid for 3 monitors.
|
|
|
|
This means 3x2x2= 12 workspaces should be provided.
|
|
|
|
|
|
|
|
(workspace-grid-configure #:rows 2 #:columns
|
|
|
|
'((\"ws-o1-1\" \"ws-o1-2\" \"ws-o1-3\" \"ws-o1-3\")
|
|
|
|
(\"ws-o2-1\" \"ws-o2-2\" \"ws-o2-3\" \"ws-o2-3\")
|
|
|
|
(\"ws-o3-1\" \"ws-o3-2\" \"ws-o3-3\" \"ws-o3-3\")))"
|
2024-06-18 14:21:36 +02:00
|
|
|
(when rows (set! ROWS rows))
|
|
|
|
(when columns (set! COLUMNS columns))
|
|
|
|
(when workspaces (set! WORKSPACES workspaces)))
|
2024-06-15 09:57:11 +02:00
|
|
|
|
|
|
|
(define* (get-active-workspace-name #:optional (workspaces (sway-get-workspaces)))
|
2024-06-18 18:05:39 +02:00
|
|
|
"Return name of active workspace."
|
2024-06-15 09:57:11 +02:00
|
|
|
(cond
|
|
|
|
((null? workspaces) #f)
|
|
|
|
((equal? (sway-workspace-focused (car workspaces)) #t)
|
|
|
|
(sway-workspace-name (car workspaces)))
|
|
|
|
(else (get-active-workspace-name (cdr workspaces)))))
|
|
|
|
|
2024-06-18 18:05:39 +02:00
|
|
|
(define* (get-output-index workspace-name #:optional (workspaces WORKSPACES) (index 0))
|
2024-06-22 13:04:14 +02:00
|
|
|
"Return output index of target workspace name"
|
2024-06-15 09:57:11 +02:00
|
|
|
(cond
|
2024-06-22 13:04:14 +02:00
|
|
|
((null? workspace-name) 0)
|
|
|
|
((null? workspaces) 0)
|
2024-06-18 18:05:39 +02:00
|
|
|
((member workspace-name (car workspaces)) index)
|
|
|
|
(else (get-output-index workspace-name (cdr workspaces) (+ index 1)))))
|
2024-06-15 09:57:11 +02:00
|
|
|
|
2024-06-18 18:05:39 +02:00
|
|
|
(define* (get-workspace-index workspace-name #:optional
|
2024-06-15 09:57:11 +02:00
|
|
|
(workspaces
|
2024-06-18 18:05:39 +02:00
|
|
|
(list-ref WORKSPACES (get-output-index workspace-name))))
|
2024-06-22 13:04:14 +02:00
|
|
|
"Return index of target workspace name."
|
2024-06-18 18:05:39 +02:00
|
|
|
(let* ((memberls (member workspace-name workspaces)))
|
2024-06-22 13:04:14 +02:00
|
|
|
(if memberls (- (length workspaces) (length memberls)) 0)))
|
2024-06-15 09:57:11 +02:00
|
|
|
|
|
|
|
(define (get-active-workspace-index)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Return index of active/focused workspace."
|
2024-06-22 13:04:14 +02:00
|
|
|
(let* ((workspace (get-active-workspace-name (sway-get-workspaces))))
|
|
|
|
(if workspace (get-workspace-index workspace) 0)))
|
2024-06-15 09:57:11 +02:00
|
|
|
|
|
|
|
;; available directions, up, right, down, left
|
2024-06-22 13:04:14 +02:00
|
|
|
(define* (get-workspace-direction direction #:optional index)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Return the index the target workspace after applying the given direction.
|
|
|
|
Parameters:
|
|
|
|
- direction: can be one of \"up\", \"right\", \"down\", \"left\".
|
|
|
|
- index: the index of the workspace to get the direction from (current by default)."
|
2024-06-22 13:04:14 +02:00
|
|
|
(let* ((index (or index (get-active-workspace-index)))
|
2024-06-15 09:57:11 +02:00
|
|
|
(current-row (floor (/ index COLUMNS)))
|
|
|
|
(current-column (modulo index COLUMNS))
|
|
|
|
(target-row
|
|
|
|
(cond ((equal? direction "up") (- current-row 1))
|
|
|
|
((equal? direction "down") (+ current-row 1))
|
|
|
|
(else current-row)))
|
|
|
|
(target-column
|
|
|
|
(cond ((equal? direction "left") (- current-column 1))
|
|
|
|
((equal? direction "right") (+ current-column 1))
|
|
|
|
(else current-column))))
|
|
|
|
(+ (* COLUMNS (modulo target-row ROWS))
|
|
|
|
(modulo target-column COLUMNS))))
|
|
|
|
|
|
|
|
(define* (get-workspace-name #:optional
|
|
|
|
(workspace (get-active-workspace-index))
|
|
|
|
(output (get-output-index (get-active-workspace-name))))
|
2024-06-18 18:05:39 +02:00
|
|
|
"Get workspace name from a given workspace index.
|
|
|
|
Parameters:
|
|
|
|
- workspace: workspace index as in configuraiton (by default, current active workspace index).
|
|
|
|
- output: output index as in configuraiton (by default, current active output index).
|
|
|
|
|
|
|
|
Note: returned name is based on configured variable WORKSPACES."
|
2024-06-15 09:57:11 +02:00
|
|
|
(list-ref (list-ref WORKSPACES output) workspace))
|
|
|
|
|
|
|
|
;; exposed command for easier access
|
|
|
|
(define (switch-workspace-up)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Focus workspace up in grid."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-switch-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "up"))))
|
|
|
|
|
|
|
|
(define (switch-workspace-right)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Focus workspace right in grid."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-switch-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "right"))))
|
|
|
|
|
|
|
|
(define (switch-workspace-down)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Focus workspace down in grid."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-switch-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "down"))))
|
|
|
|
|
|
|
|
(define (switch-workspace-left)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Focus workspace left in grid."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-switch-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "left"))))
|
|
|
|
|
|
|
|
(define (move-container-to-workspace-up)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Move current container to workspace up in grid and focus it."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-move-container-to-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "up")))
|
|
|
|
(switch-workspace-up))
|
|
|
|
|
|
|
|
(define (move-container-to-workspace-right)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Move current container to workspace right in grid and focus it."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-move-container-to-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "right")))
|
|
|
|
(switch-workspace-right))
|
|
|
|
|
|
|
|
(define (move-container-to-workspace-down)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Move current container to workspace down in grid and focus it."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-move-container-to-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "down")))
|
|
|
|
(switch-workspace-down))
|
|
|
|
|
|
|
|
(define (move-container-to-workspace-left)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Move current container to workspace left in grid and focus it."
|
2024-06-15 09:57:11 +02:00
|
|
|
(sway-move-container-to-workspace
|
|
|
|
(get-workspace-name
|
|
|
|
(get-workspace-direction "left")))
|
|
|
|
(switch-workspace-left))
|
|
|
|
|
|
|
|
(define (valid-grid? rows columns workspaces)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Validate the grid structure by ensuring the number of workspaces
|
|
|
|
matches the number of rowsxcolumns."
|
2024-06-15 09:57:11 +02:00
|
|
|
(and (> (length workspaces) 0)
|
|
|
|
(equal? (* rows columns) (length (car workspaces)))))
|
|
|
|
|
|
|
|
(define (workspace-grid-init)
|
2024-06-18 18:05:39 +02:00
|
|
|
"Initialize the workspace grid."
|
|
|
|
(format #t "starting workspace-grid\n~a\n" WORKSPACES)
|
2024-06-15 09:57:11 +02:00
|
|
|
(if (valid-grid? ROWS COLUMNS WORKSPACES)
|
2024-06-18 18:05:39 +02:00
|
|
|
(format #t "successfully started workspace ~ax~a\n" ROWS COLUMNS)
|
|
|
|
(format #t "workspace grid failed to start the grid configs ~ax~a\n" ROWS COLUMNS)))
|