summaryrefslogtreecommitdiff
path: root/.stumpwm.d/commands.lisp
blob: da88a18f39cda41ac4365e9fa5f850843db10ea3 (about) (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
;; Functions

(defun feh-set-wallpaper (wallpaper-name)
  "Set wallpaper using feh"
  (let ((wallpaper-dir "~/wallpapers/"))
    (format t "Setting wallpaper: ~a~%" wallpaper-name)
    (run-shell-command (format nil "feh --bg-scale ~a~a" wallpaper-dir wallpaper-name))))


(defun thanos/set-wallpapers ()
  "Set wallpapers depending on hostname."
  (cond ((equal (asdf:hostname) "zeus") (feh-set-wallpaper "anime-night-mountains.jpg"))
	((equal (asdf:hostname) "hermes") (feh-set-wallpaper "library-old-house.jpg"))))

;; Web jump (works for DuckDuckGo)
(defmacro make-web-jump (name prefix)
  `(defcommand ,(intern name) (search) ((:rest ,(concatenate 'string "Search with " name ": ")))
     (nsubstitute #\+ #\Space search)
     (run-shell-command (concatenate 'string ,prefix search))))

;; (defcommand nyxt () (search) ((:rest ,(concatenate 'string "Search with " name ": ")))
;;      (nsubstitute #\+ #\Space search)
;;      (run-shell-command (concatenate 'string "nyxt -r -e" "" search)))

(make-web-jump "searxng" "nyxt https://search.thanosapollo.com/?q=")
(make-web-jump "Invidious" "firefox https://yewtu.be/search?q=")

(ql:quickload :slynk)

(defcommand sly-start-server () ()
  "Start a slynk server for sly."
  (sb-thread:make-thread (lambda () (slynk:create-server :dont-close t))))

(defcommand sly-stop-server () ()
  "Stop current slynk server for sly."
  (sb-thread:make-thread (lambda () (slynk:stop-server 4005))))

(defcommand nyxt-buffer-search (search)
    ((:string "Search for: "))
  (let ((url "https://search.thanosapollo.com/?q="))
    (run-shell-command
     (concatenate 'string "nyxt -r -e '(buffer-load" "\"" url search "\"" ")'" ))))

(stumpwm:defcommand nyxt-buffer-url (search)
    ((:string "Set URL: "))
  (let ((url "https://search.thanosapollo.com/?q="))
    (stumpwm:run-shell-command
     (concatenate 'string "nyxt -r -e '(buffer-load" "\"" search "\"" ")'" ))))

(defcommand nyxt-new-buffer-search (search)
    ((:string "New Buffer Search for: "))
  (let ((url "https://search.thanosapollo.com/?q="))
    (run-shell-command
     (concatenate 'string "nyxt -r -e '(set-url-new-buffer :url" "\"" url  search "\"" ")'" ))))


(defcommand firefox () ()
  "Run or raise Firefox."
  (sb-thread:make-thread (lambda () (run-or-raise "firefox" '(:class "firefox") t nil))))

(defcommand delete-window-and-frame () ()
  "Delete the current frame with its window."
  (delete-window)
  (remove-split))

(defcommand hsplit-and-focus () ()
  "Create a new frame on the right and focus it."
  (hsplit)
  (move-focus :right))

(defcommand vsplit-and-focus () ()
  "Create a new frame below and move focus to it."
  (vsplit)
  (move-focus :down))

(defcommand term (&optional program) ()
  "Invoke a terminal, possibly with a @arg{program}."
  (sb-thread:make-thread
   (lambda ()
     (run-shell-command (if program
			    (format nil "kitty ~A" program)
			    "kitty")))))

(when *initializing*
  (mapc #'run-shell-command
   '("picom"
     "transmission-daemon"
     "xsetroot -cursor_name left_ptr"))
  (thanos/set-wallpapers))