summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.config/emacs/init.el340
-rw-r--r--.config/guix/channels.scm29
-rw-r--r--.config/sway/config5
-rw-r--r--.gitconfig5
-rw-r--r--guix/channels.scm26
-rw-r--r--guix/home.scm21
-rw-r--r--guix/system-create.scm27
-rw-r--r--guix/uranus.scm10
8 files changed, 217 insertions, 246 deletions
diff --git a/.config/emacs/init.el b/.config/emacs/init.el
index ddb2281..35d15c9 100644
--- a/.config/emacs/init.el
+++ b/.config/emacs/init.el
@@ -28,9 +28,7 @@
;; ╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╱╰╯
;;; Code:
-;; Disable package.el
-(setq package-enable-at-startup nil
- package-archives nil)
+(package-initialize)
(setf user-full-name "Thanos Apollo"
user-mail-address "[email protected]")
@@ -73,32 +71,7 @@
;; Enable use-package support for imenu
(setf use-package-enable-imenu-support t)
-;; Install straight.el
-(defvar bootstrap-version)
-
-(let ((bootstrap-file
- (expand-file-name
- "straight/repos/straight.el/bootstrap.el"
- (or (bound-and-true-p straight-base-dir)
- user-emacs-directory)))
- (bootstrap-version 7))
- (unless (file-exists-p bootstrap-file)
- (with-current-buffer
- (url-retrieve-synchronously
- "https://raw.githubusercontent.com/radian-software/straight.el/develop/install.el"
- 'silent 'inhibit-cookies)
- (goto-char (point-max))
- (eval-print-last-sexp)))
- (load bootstrap-file nil 'nomessage))
-
-(require 'straight)
-
-(setf straight-use-package-by-default t)
-
-(setf straight-recipe-overrides
- '((transmission :type git :host nil :repo "[email protected]:/var/git/transmission.git")))
-
-(setf browse-url-browser-function 'browse-url-generic
+(setf browse-url-browser-function 'eww ;; 'browse-url-generic
browse-url-generic-program "icecat"
backup-directory-alist '((".*" . "~/.Trash"))
sentence-end-double-space t
@@ -174,7 +147,8 @@
("\\paragraph{%s}" . "\\paragraph*{%s}")))
:hook ((org-mode . (lambda () (display-line-numbers-mode -1) (flyspell-mode))))
:bind (:map org-mode-map (("C-c l" . org-store-link)
- ("C-c M-t" . org-todo))))
+ ("C-c M-t" . org-todo)
+ ("C-c RET" . org-table-hline-and-move))))
;; Export
@@ -219,7 +193,6 @@
(scheme-mode . thanos/add-custom-keywords)))
(use-package dired
- :straight nil
:ensure nil
:config
(defun dired-watch-video ()
@@ -341,7 +314,8 @@
(make-directory "~/Notes"))
(use-package org-roam
- :straight (org-roam :local-repo "~/Dev/emacs-lisp/org-roam")
+ :vc t
+ :load-path "~/Dev/emacs-lisp/org-roam"
:defer t
:init
(define-prefix-command 'thanos/notes-map)
@@ -352,7 +326,7 @@
(org-roam-db-autosync-enable)
(setf org-roam-node-display-template
- (concat "${title:50} "(propertize "${tags:30}" 'face 'org-tag)))
+ (concat "${title:50} "(propertize "${tags:50}" 'face 'org-tag)))
(setf org-roam-db-node-include-function
(lambda ()
@@ -378,7 +352,7 @@
"* %?"
:target (file+head "%<%Y-%m-%d>.org"
"#+title: %<%Y-%m-%d>\n#+filetags: :journal:dailies:\n
-* Daily Notes\n\n* Goals\n+ []\n\n* Extras"))))
+* Daily Notes\n\n* Goals\n+ [] Πρωινὴ Προσευχή\n+ [] Ἑσπερινή Προσευχή\n\n* Extras"))))
(defun org-roam-ref-add-book ()
"Insert org-link from Library."
@@ -418,11 +392,30 @@
("C-c i" . org-id-get-create)))
(use-package org-roam-ui
- :defer t)
+ :vc (:url "https://github.com/org-roam/org-roam-ui")
+ :after org-roam
+ :config
+ (setq org-roam-ui-sync-theme t
+ org-roam-ui-follow t
+ org-roam-ui-update-on-save t
+ org-roam-ui-open-on-start t))
+
+(use-package org-present
+ :vc (:url "https://github.com/rlister/org-present")
+ :hook ((org-present-mode . (lambda ()
+ (org-present-big)
+ (org-display-inline-images)
+ (org-present-hide-cursor)
+ (org-present-read-only)))
+ (org-present-mode-quit . (lambda ()
+ (org-present-small)
+ (org-remove-inline-images)
+ (org-present-show-cursor)
+ (org-present-read-write)))))
(unless (or is-phone is-uranus)
(use-package modus-themes
- :straight t
+ :vc (:url "https://github.com/protesilaos/modus-themes")
:config
(setf modus-themes-italic-constructs nil
modus-themes-bold-constructs nil
@@ -491,12 +484,13 @@
:init (define-prefix-command 'thanos/search)
:bind (("C-x r d" . 'bookmark-delete)
("C-x r C-r" . 'bookmark-rename)
- ("C-x r j" . 'consult-register)
+ ("C-x r C-j" . 'consult-register)
("C-x r SPC" . 'consult-register-store)
("C-x r b" . 'consult-bookmark)
("C-c m" . 'consult-imenu)
("C-x b" . 'consult-buffer)
("C-x C-b" . 'switch-to-prev-buffer)
+ ("C-x M-b" . 'ibuffer)
("M-y" . 'consult-yank-from-kill-ring)
("C-M-s" . 'consult-line)
("C-c s" . 'thanos/search)
@@ -517,6 +511,7 @@
(use-package elfeed
:defer t
+ :vc (:url "https://github.com/skeeto/elfeed")
:config
(setf elfeed-search-filter "@1-week-ago +unread -hackernoon"
browse-url-browser-function #'browse-url-default-browser
@@ -540,7 +535,6 @@
("http://localhost/?action=display&bridge=CssSelectorBridge&home_page=https%3A%2F%2Fwww.estianews.gr%2Feidiseis-arthra%2F&url_selector=h3.entry-title&url_pattern=&content_selector=div.col-lg-8&content_cleanup=&title_cleanup=&limit=&format=Atom" estia greek news)
("http://localhost/?action=display&bridge=CssSelectorBridge&home_page=https%3A%2F%2Fwww.estianews.gr%2Fkentriko-thema%2F&url_selector=h3.entry-title&url_pattern=&content_selector=div.col-md-8&content_cleanup=&title_cleanup=&limit=&format=Atom" estia greek kyrio)
("http://localhost/?action=display&bridge=CssSelectorBridge&home_page=https%3A%2F%2Fwww.estianews.gr%2Fapopseis%2F&url_selector=h3.entry-title&url_pattern=&content_selector=div.col-lg-8&content_cleanup=&title_cleanup=&limit=&format=Atom" estia greek opinions)
- ("http://localhost/?action=display&bridge=CssSelectorBridge&home_page=https%3A%2F%2Fwww.reuters.com%2Fworld%2F&url_selector=a.media-story-card__headline__tFMEu&url_pattern=&content_selector=article.article__container__2MUeZ&content_cleanup=div.info-content__toolbar__3AkHm%2C+div.article-body__row__dFOPA%2C+div.article__read-next__Kjxdw&title_cleanup=&limit=&format=Atom" reuters world news)
("http://localhost/?action=display&bridge=CssSelectorBridge&home_page=https%3A%2F%2Fwww.reuters.com%2Fbusiness%2Fhealthcare-pharmaceuticals%2F&url_selector=a.basic-card__title__37xHl&url_pattern=&content_selector=div.article-body__wrapper__3IxHM&content_cleanup=svg.link__new-tab-symbol__3T19s%2C+div.toolbar__container__3kIkw%2C+div.article-body__row__dFOPA+article-body__element__2p5pI&title_cleanup=&limit=&format=Atom" reuters med news)
("http://localhost/?action=display&bridge=CssSelectorBridge&home_page=https%3A%2F%2Fwww.reuters.com%2Ftechnology%2Fcybersecurity%2F&url_selector=a.media-story-card__headline__tFMEu%2C+a.media-story-card__heading__eqhp9&url_pattern=&content_selector=article.article__container__2MUeZ&content_cleanup=div.info-content__toolbar__3AkHm%2C+svg.link__new-tab-symbol__3T19s%2C+div.article-body__row__dFOPA%2C+div.read-next-tablet-up__container__3MpHN%2C+div.author-bio__multiple-authors__5YGrG%2C+div.article__read-next__Kjxdw&title_cleanup=&limit=&format=Atom" reuters cybersec news)
("https://annas-blog.org/
@@ -554,6 +548,7 @@ rss.xml" anna piracy)
("http://planet.lisp.org/rss20.xml" lisp planetlisp)
("https://guix.gnu.org/feeds/blog.atom" guix)
("https://protesilaos.com/master.xml" prot)
+ ("https://static.fsf.org/fsforg/rss/news.xml" gnu fsf)
;; YouTube
("https://www.youtube.com/feeds/videos.xml?channel_id=UCVls1GmFKf6WlTraIb_IaJg"
distrotube yt linux)
@@ -588,22 +583,12 @@ rss.xml" anna piracy)
:hook ((elfeed-searchacw-mode . (lambda () (display-line-numbers-mode 0)))))
;; Python
-(use-package python-mode
- :defer t
- :config
- (add-to-list 'auto-mode-alist '("\\.py\\'" . python-mode)))
-
-(use-package pyenv
- :defer t)
+(add-to-list 'auto-mode-alist '("\\.py\\'" . python-ts-mode))
-;; Clojure
-(use-package cider
- :defer t)
-
-(use-package clojure-mode
- :defer t)
+;; Lisp
(use-package rainbow-delimiters
+ :vc (:url "https://github.com/Fanael/rainbow-delimiters")
:defer t
:hook ((emacs-lisp-mode . rainbow-delimiters-mode)
(lisp-mode . rainbow-delimiters-mode)
@@ -612,48 +597,58 @@ rss.xml" anna piracy)
(use-package sly
:init (setf inferior-lisp-program "sbcl")
- :defer t)
+ :ensure t)
-(use-package helpful
- :defer t
- :bind (("C-h f" . 'helpful-callable)
- ("C-h v" . 'helpful-variable)
- ("C-h k" . 'helpful-key)
- ("C-h x" . 'helpful-command)
- ("C-h ." . 'helpful-at-point)
- ("C-h F" . 'helpful-function)
- ("C-h C-k" . 'helpful-kill-buffers)
- ("C-h a" . 'apropos)
- ("C-h C-m" . 'info-apropos)))
-
-(use-package ox-hugo
+(use-package vc
:ensure t
:config
- (setf org-hugo-section "post"))
-
-(use-package json-mode
- :defer t
- :config
- (add-to-list 'auto-mode-alist '("\\.json'" . json-mode)))
-
-(defun project-magit ()
- "Run magit-status in the current project's root."
- (interactive)
- (magit-status-setup-buffer (project-root (project-current t))))
-
-(use-package magit
- :defer t
- :config
- (setf magit-display-buffer-function #'magit-display-buffer-same-window-except-diff-v1)
- :bind (:map project-prefix-map ("g" . 'project-magit)))
-
-(use-package magit-todos
- :after magit
- :config
- (magit-todos-mode 0)
- (setf magit-todos-keywords
- '(("TODO" . "#cc9393")
- ("FIXME" . "#FF0000"))))
+ (defun vc-git--commit-hash-at-point ()
+ "Return commit hash at point."
+ (let ((hash (thing-at-point 'word t)))
+ (and (stringp hash)
+ (string-match-p "^[0-9a-f]\\{7,40\\}$" hash)
+ hash)))
+
+ (defun vc-git-reset-to-commit-at-point (&optional hash)
+ "Reset the current branch to the commit at point in the vc log buffer."
+ (let ((commit-hash (or (thing-at-point 'word t) hash)))
+ (vc-git--reset commit-hash)))
+
+ (defun vc-git--reset (commit-hash)
+ "Reset to commit HASH."
+ (if (and commit-hash (string-match-p "^[0-9a-f]\\{7,40\\}$" commit-hash))
+ (if (yes-or-no-p (format "Reset current branch to commit %s?" commit-hash))
+ (progn
+ (let ((default-directory (vc-root-dir)))
+ (vc-git-command nil 0 nil "reset" "--hard" commit-hash)
+ (message "Reset to commit %s completed." commit-hash)))
+ (message "Reset cancelled."))
+ "Invalid commit hash"))
+
+ (defun vc-git--select-commit ()
+ (let* ((history-add-new-input nil)
+ (commit-strings (split-string (shell-command-to-string "git log --oneline") "\n" t))
+ (selected (completing-read "Select commit: " commit-strings nil t))
+ (selected-hash (car (split-string selected))))
+ selected-hash))
+
+ (defun vc-git-reset (&optional hash)
+ (interactive)
+ (vc-git--reset (or hash
+ (vc-git--commit-hash-at-point)
+ (vc-git--select-commit))))
+
+ (defun vc-git-format-patches (num)
+ "Format patches for NUM of last commits"
+ (interactive (list (read-number "Number of commits: ")))
+ (vc-git-command nil 0 nil "format-patch" (format "-%d" num))
+ (message "Done."))
+
+ (defun vc-git-reword-commit ()
+ "Edit current commit message"
+ (interactive)
+ (vc-checkin nil 'git nil nil nil "")
+ (vc-git-log-edit-toggle-amend)))
(use-package corfu
:ensure t
@@ -675,6 +670,16 @@ rss.xml" anna piracy)
(when (or is-phone is-uranus)
(use-package corfu-terminal))
+(use-package cape
+ ;; Press C-c p ? to for help.
+ :bind ("M-p" . cape-prefix-map) ;; Alternative keys: M-p, M-+, ...
+ :config
+ ;; (add-hook 'completion-at-point-functions #'cape-dabbrev)
+ (add-hook 'completion-at-point-functions #'cape-file)
+ ;; (add-hook 'completion-at-point-functions #'cape-elisp-block)
+ ;; (add-hook 'completion-at-point-functions #'cape-dict)
+ )
+
(defun insert-brackets (&optional arg)
"Insert ARG brackets."
(interactive "P")
@@ -692,7 +697,6 @@ rss.xml" anna piracy)
completion-cycle-threshold 2))
(use-package pdf-tools
- :straight nil
:ensure nil
:config
(add-to-list 'auto-mode-alist '("\\.pdf\\'" . pdf-view-mode))
@@ -703,22 +707,13 @@ rss.xml" anna piracy)
;; minor modes automatically
(pdf-tools-enable-minor-modes)))))
-(use-package markdown-mode
- :straight nil
- :defer t
- :config
- (setq markdown-header-scaling t
- markdown-command "multimarkdown")
- (add-to-list 'auto-mode-alist '("\\.md\\'" . gfm-mode))
- :hook ((markdown-mode . flyspell-mode)))
-
(use-package nov
- :straight nil
- :defer t
+ :ensure nil
:config
(add-to-list 'auto-mode-alist '("\\.epub\\'" . nov-mode)))
(use-package eshell-syntax-highlighting
+ :vc (:url "https://github.com/akreisher/eshell-syntax-highlighting")
:ensure t
:after eshell
:config
@@ -730,8 +725,8 @@ rss.xml" anna piracy)
:commands emojify-mode)
(use-package flycheck-package
- :straight t
- :ensure t
+ :vc (:url "https://github.com/purcell/flycheck-package")
+ :ensure nil
:after flycheck)
(use-package flycheck
@@ -742,14 +737,6 @@ rss.xml" anna piracy)
:hook ((emacs-lisp-mode . (lambda () (flycheck-mode) (flycheck-package-setup)))))
(use-package eat
- :straight '(eat :type git
- :host codeberg
- :repo "akib/emacs-eat"
- :files ("*.el" ("term" "term/*.el") "*.texi"
- "*.ti" ("terminfo/e" "terminfo/e/*")
- ("terminfo/65" "terminfo/65/*")
- ("integration" "integration/*")
- (:exclude ".dir-locals.el" "*-tests.el")))
:config
(setf eshell-visual-commands nil
eat-term-name "xterm-256color")
@@ -765,10 +752,7 @@ rss.xml" anna piracy)
:hook ((shell-mode . (lambda () (display-line-numbers-mode -1)))))
(defvar thanos/aliases
- '((g . magit)
- (gl . magit-log)
- (gc . magit-clone)
- (d . dired)
+ '((d . dired)
(o . find-file)
(oo . find-file-other-window)
(ll . (lambda () (eshell/ls '-lha)))
@@ -796,7 +780,8 @@ rss.xml" anna piracy)
(display-line-numbers-mode -1)))))
(use-package eshell-git-prompt
- :straight nil
+ :vc (:url "https://github.com/xuchunyang/eshell-git-prompt")
+ :ensure t
:config
(defun eshell-git-prompt-multiline ()
"Eshell Git prompt inspired by spaceship-prompt."
@@ -829,43 +814,21 @@ rss.xml" anna piracy)
(eshell-git-prompt-use-theme 'multiline))
-;; Chat
-(use-package jabber
+;; Password-store
+(use-package password-store
+ :init (define-prefix-command 'thanos/pass)
:defer t
:config
- (defun jabber-buffers-formats (&optional buffer-formats)
- "Return jabber BUFFER-FORMATS without the format specifiers.
-
-By default, returns all jabber related buffers format."
- (let ((buffer-formats (or buffer-formats '(jabber-chat-buffer-format
- jabber-browse-buffer-format
- jabber-roster-buffer
- jabber-groupchat-buffer-format
- jabber-muc-private-buffer-format))))
- (cl-loop for var in buffer-formats
- for str = (symbol-value var)
- for formatted-str = (when (stringp str)
- ;; Remove format specifier and
- ;; the following 2 char, or 1 if
- ;; there is not second.
- (replace-regexp-in-string "%.?" "" str))
- collect formatted-str)))
-
- (defun jabber-switch-to-buffer ()
- "Prompt the user to select a buffer whose name matches a list of strings."
- (interactive)
- (let* ((string-list (jabber-buffers-formats))
- (buffers-matching-strings
- (cl-loop for buf in (buffer-list)
- when (cl-loop for str in string-list
- thereis (string-match-p str (buffer-name buf)))
- collect (buffer-name buf))))
- (if buffers-matching-strings
- (switch-to-buffer
- (completing-read "Select jabber buffer: " buffers-matching-strings)))
- (error "No jabber buffer found")))
- :bind (:map jabber-global-keymap
- ("C-b" . 'jabber-switch-to-buffer)))
+ (setf password-store-password-length (+ 20 (random 20)))
+ :bind (("C-c p" . 'thanos/pass)
+ :map thanos/pass
+ ("i" . 'password-store-insert)
+ ("e" . 'password-store-edit)
+ ("g" . 'password-store-generate)
+ ("c" . 'password-store-copy)
+ ("s" . 'smtp-get-pass)))
+
+;; Chat
(use-package erc
:ensure t
@@ -873,27 +836,29 @@ By default, returns all jabber related buffers format."
(unless (expand-file-name "erc" user-emacs-directory)
(make-directory (expand-file-name "erc" user-emacs-directory)))
(setf erc-modules
- '(sasl netsplit fill button match track completion readonly
- networks ring autojoin noncommands irccontrols move-to-prompt stamp
- menu list log notifications)
+ '(netsplit fill button match track completion readonly
+ networks ring autojoin noncommands irccontrols move-to-prompt stamp
+ menu list log notifications)
erc-log-channels-directory (expand-file-name "erc" user-emacs-directory))
(defun thanos/erc-login ()
"Login to libera.chat"
(interactive)
- (erc-tls :server "irc.libera.chat" :port 6697
- :nick "thanosapollo"
- :user "thanosapollo"
- :password (password-store-get "liberachat/thanos_apollo")))
+ (erc :server "uranus" :port 5555
+ :nick "thanosapollo"
+ :user "thanosapollo"
+ :password (password-store-get "znc/admin")))
:bind (("C-c E" . 'erc-libera)
:map erc-mode-map
("C-c RET" . 'erc-cmd-QUERY)))
(use-package transmission
+ :vc (:url "https://github.com/holomorph/transmission")
:defer t)
(use-package sudo-edit
- :defer t
+ :vc (:url "https://github.com/nflath/sudo-edit")
+ :ensure t
:config
(setf sudo-edit-local-method "sudo"))
@@ -912,7 +877,8 @@ By default, returns all jabber related buffers format."
(when (or is-zeus is-hermes)
(use-package yeetube
:init (define-prefix-command 'thanos/yeetube-map)
- :straight (yeeutube :local-repo "~/Dev/emacs-lisp/yeetube")
+ :vc t
+ :load-path "~/Dev/emacs-lisp/yeetube"
:ensure t
:config
(setf yeetube-results-limit 20
@@ -931,7 +897,8 @@ By default, returns all jabber related buffers format."
(while (not (string= url "q"))
(setf url (read-string "Enter URL (q to quit): "))
(unless (string= url "q")
- (setf name (read-string (format "Custom name (download counter: %d) " download-counter)))
+ (setf name
+ (read-string (format "Custom name (download counter: %d) " download-counter)))
(push (cons url name) stored-contents)
(setf download-counter (1+ download-counter))))
;; Process the collected links and names
@@ -952,7 +919,8 @@ By default, returns all jabber related buffers format."
(while (not (string= url "q"))
(setf url (read-string "Enter URL (q to quit): "))
(unless (string= url "q")
- (setf name (read-string (format "Custom name (download counter: %d) " download-counter)))
+ (setf name
+ (read-string (format "Custom name (download counter: %d) " download-counter)))
(setf download-counter (1+ download-counter))
(call-process-shell-command
(format
@@ -973,7 +941,8 @@ By default, returns all jabber related buffers format."
("k" . 'yeetube-remove-saved-video)))
(use-package gnosis
- :straight (gnosis :local-repo "~/Dev/emacs-lisp/gnosis")
+ :vc t
+ :load-path "~/Dev/emacs-lisp/gnosis"
:ensure t
:init (define-prefix-command 'thanos/gnosis-map)
:config
@@ -992,7 +961,8 @@ By default, returns all jabber related buffers format."
(gnosis-vc-pull)
(use-package pcmpl-tailscale
- :straight (pcmpl-tailscale :local-repo "~/Dev/emacs-lisp/pcmpl-tailscale")
+ :vc t
+ :load-path "~/Dev/emacs-lisp/pcmpl-tailscale"
:ensure nil))
;; Emacs dev
@@ -1002,7 +972,7 @@ By default, returns all jabber related buffers format."
;; AI tools
(use-package gptel
- :defer t
+ :ensure t
:config
(setf gptel-api-key (password-store-get-field "openai/[email protected]" "api")
gptel-default-mode 'org-mode
@@ -1023,22 +993,6 @@ By default, returns all jabber related buffers format."
:map gptel-mode-map
("C-c h" . 'gptel-menu)))
-
-;; Password-store
-(use-package password-store
- :init (define-prefix-command 'thanos/pass)
- :defer t
- :config
- (setf password-store-password-length (+ 20 (random 20)))
-
- :bind (("C-c p" . 'thanos/pass)
- :map thanos/pass
- ("i" . 'password-store-insert)
- ("e" . 'password-store-edit)
- ("g" . 'password-store-generate)
- ("c" . 'password-store-copy)
- ("s" . 'smtp-get-pass)))
-
(use-package package-lint
:defer t)
@@ -1073,8 +1027,7 @@ By default, returns all jabber related buffers format."
(kill-buffer (process-buffer process))))))))
(use-package notmuch
- :straight nil
- :ensure t
+ :defer t
:bind (("C-x m" . notmuch-hello)
:map notmuch-hello-mode-map
("u" . notmuch-hello-update)
@@ -1086,7 +1039,9 @@ By default, returns all jabber related buffers format."
(setf notmuch-archive-tags '("-inbox" "-unread" "+archived")
notmuch-show-all-tags-list t
- notmuch-hello-sections '(notmuch-hello-insert-header notmuch-hello-insert-saved-searches notmuch-hello-insert-alltags))
+ notmuch-hello-sections
+ '(notmuch-hello-insert-header notmuch-hello-insert-saved-searches
+ notmuch-hello-insert-alltags))
(setq notmuch-search-oldest-first nil)
@@ -1120,13 +1075,12 @@ By default, returns all jabber related buffers format."
;; autosign messages
(add-hook 'message-send-hook 'mml-secure-message-sign-pgpmime)
-(use-package yasnippet
- :ensure nil
- :config
- (when is-zeus (add-to-list 'yas-snippet-dirs "~/Dev/guile/guix/etc/snippets/yas")))
+;; (use-package yasnippet
+;; :ensure nil
+;; :config
+;; (when is-zeus (add-to-list 'yas-snippet-dirs "~/Dev/guile/guix/etc/snippets/yas")))
(use-package emms
- :straight nil
:defer t
:init (define-prefix-command 'thanos/emms)
:config
@@ -1200,7 +1154,6 @@ By default, returns all jabber related buffers format."
memory cores image (if iso (concat "-cdrom " iso) "")))))
(use-package 0x0
- :straight nil
:ensure nil)
;; Misc Functions ;;
@@ -1390,10 +1343,11 @@ Create a temporary frame to execute BODY, which will then be deleted."
(interactive "nStart: \nnEnd: ")
(dotimes (i (1+ (- end str)))
(insert (format "%s" (+ i str)))
- (org-return)))
+ (org-table-hline-and-move)))
(use-package greek-polytonic
- :straight (greek-polytonic :local-repo "~/Dev/emacs-lisp/greek-polytonic"))
+ :vc t
+ :load-path "~/Dev/emacs-lisp/greek-polytonic")
(require 'server)
(unless (server-running-p)
diff --git a/.config/guix/channels.scm b/.config/guix/channels.scm
new file mode 100644
index 0000000..4c01a9f
--- /dev/null
+++ b/.config/guix/channels.scm
@@ -0,0 +1,29 @@
+(cons*
+ (channel
+ (name 'nonguix)
+ (url "https://gitlab.com/nonguix/nonguix")
+ (introduction
+ (make-channel-introduction
+ "897c1a470da759236cc11798f4e0a5f7d4d59fbc"
+ (openpgp-fingerprint
+ "2A39 3FFF 68F4 EF7A 3D29 12AF 6F51 20A0 22FB B2D5"))))
+ (channel
+ (name 'rosenthal)
+ (url "https://codeberg.org/hako/rosenthal.git")
+ (branch "trunk")
+ (introduction
+ (make-channel-introduction
+ "7677db76330121a901604dfbad19077893865f35"
+ (openpgp-fingerprint
+ "13E7 6CD6 E649 C28C 3385 4DF5 5E5A A665 6149 17F7"))))
+ (channel
+ (name 'hecate)
+ ;; (url "https://git.thanosapollo.org/hecate")
+ (url (string-append "file://" (getenv "HOME")
+ "/Dev/guile/hecate"))
+ (introduction
+ (make-channel-introduction
+ "6d40e319e46eddc6a3e1a97b1dd1dafedb785889"
+ (openpgp-fingerprint
+ "62B7 58D0 F671 9938 BC09 CECA 339F 736C 3A72 0928"))))
+ %default-channels)
diff --git a/.config/sway/config b/.config/sway/config
index 4d42897..aed1e7f 100644
--- a/.config/sway/config
+++ b/.config/sway/config
@@ -190,10 +190,7 @@ client.placeholder #000000 #000000 #F8F8F2 #000000 #000000
bindsym $mod+f fullscreen
# Toggle the current focus between tiling and floating mode
- bindsym $mod+Shift+space floating toggle
-
- # Swap focus between the tiling area and the floating area
- bindsym $mod+space focus mode_toggle
+ bindsym $mod+Shift+f floating toggle
# Move focus to the Parent container
# bindsym $mod+p focus parent
diff --git a/.gitconfig b/.gitconfig
index 6caad0f..09e4f93 100644
--- a/.gitconfig
+++ b/.gitconfig
@@ -8,12 +8,11 @@
subjectPrefix = PATCH
[sendemail]
from = Thanos Apollo <[email protected]>
- smtpserver = smtp.forwardemail.net
- smtpuser = [email protected]
+ smtpserver = smtp.mailbox.org
+ smtpuser = [email protected]
smtpencryption = ssl
smtpserverport = 465
annotate = yes
- smtpass = $(pass forwardemail/[email protected])
[core]
commitGraph = true
[gc]
diff --git a/guix/channels.scm b/guix/channels.scm
deleted file mode 100644
index f068a56..0000000
--- a/guix/channels.scm
+++ /dev/null
@@ -1,26 +0,0 @@
-(cons* (channel
- (name 'nonguix)
- (url "https://gitlab.com/nonguix/nonguix")
- (introduction
- (make-channel-introduction
- "897c1a470da759236cc11798f4e0a5f7d4d59fbc"
- (openpgp-fingerprint
- "2A39 3FFF 68F4 EF7A 3D29 12AF 6F51 20A0 22FB B2D5"))))
- (channel
- (name 'rosenthal)
- (url "https://codeberg.org/hako/rosenthal.git")
- (branch "trunk")
- (introduction
- (make-channel-introduction
- "7677db76330121a901604dfbad19077893865f35"
- (openpgp-fingerprint
- "13E7 6CD6 E649 C28C 3385 4DF5 5E5A A665 6149 17F7"))))
- (channel
- (name 'hecate)
- (url "https://git.thanosapollo.org/hecate")
- (introduction
- (make-channel-introduction
- "6d40e319e46eddc6a3e1a97b1dd1dafedb785889"
- (openpgp-fingerprint
- "62B7 58D0 F671 9938 BC09 CECA 339F 736C 3A72 0928"))))
- %default-channels)
diff --git a/guix/home.scm b/guix/home.scm
index c3071b3..2a54561 100644
--- a/guix/home.scm
+++ b/guix/home.scm
@@ -11,6 +11,7 @@
#:use-module (gnu home services shells)
#:use-module (gnu home services desktop)
#:use-module (gnu home services gnupg)
+ #:use-module (gnu home services messaging)
#:use-module (hecate packages emacs)
#:use-module (hecate packages hunspell)
#:export (home))
@@ -24,23 +25,21 @@
(define thanos/emacs-packages
- '("emacs-pgtk" "emacs-nov-el" "emacs-pdf-tools" "emacs-emms"
- "emacs-geiser" "emacs-geiser-guile" "emacs-jabber" "emacs-yeetube"
- "emacs-debbugs" "emacs-eshell-git-prompt" "emacs-0x0" "emacs-org-roam"
- "emacs-markdown-mode" "emacs-gnosis" "emacs-notmuch"))
+ '("emacs-next-pgtk" "emacs-nov-el" "emacs-pdf-tools" "emacs-emms"
+ "emacs-geiser" "emacs-geiser-guile" "emacs-notmuch" "emacs-password-store"
+ "emacs-debbugs" "emacs-0x0" "emacs-emojify"))
(define thanos/python-packages
'("python-next" "python-pip" "python-lsp-server" "python-numpy"))
(home-environment
(packages (specifications->packages
- (append '("perl" "yt-dlp" "icecat" "gcc-toolchain" "wl-clipboard" "sqlite"
- "hyfetch" "transmission" "isync" "mpv" "steam" "signal-desktop"
- "git" "fuzzel" "wl-clipboard" "alacritty" "password-store" "curl" "dino"
- "bind" "nmap" "hunspell" "wtype" "hunspell-dict-en-med" "hunspell-dict-el"
- "mlocate" "rsync" "grimshot" "nyxt" "swayidle" "wl-clipboard" "htop"
- "net-tools" "gnupg" "texlive" "texlive-collection-latexrecommended"
- "notmuch" "hunspell-dict-en-us" "sbcl" "xkeyboard-config")
+ (append '("perl" "yt-dlp" "torbrowser" "icecat" "sbcl" "notmuch" "hunspell-dict-en"
+ "gcc-toolchain" "sqlite" "hyfetch" "transmission" "isync" "mpv"
+ "steam" "signal-desktop" "git" "fuzzel" "alacritty" "password-store"
+ "curl" "dino" "bind" "nmap" "hunspell" "wtype" "hunspell-dict-en-med"
+ "hunspell-dict-el" "mlocate" "rsync" "grimshot" "swayidle" "htop"
+ "net-tools" "gnupg" "texlive" "texlive-collection-latexrecommended")
thanos/emacs-packages thanos/python-packages thanos/fonts-packages)))
(services
(list (service home-bash-service-type
diff --git a/guix/system-create.scm b/guix/system-create.scm
index 70f7570..dac64a0 100644
--- a/guix/system-create.scm
+++ b/guix/system-create.scm
@@ -26,7 +26,7 @@
'("sway" "swaylock" "swaylock-effects" "swaybg"
"waybar" "gnupg" "pinentry" "font-jetbrains-mono"
"docker" "docker-cli" "dbus" "xf86-input-libinput"
- "xf86-video-fbdev"))
+ "xf86-video-fbdev" "tailscale-bin"))
(define* (system-create #:key
(system-packages thanos/system-packages)
@@ -48,7 +48,7 @@
(initrd microcode-initrd)
(firmware (list linux-firmware))
- ;; The list of user accounts ('root' is implicit).
+
(users (cons* (user-account
(name "thanos")
(comment "Thanos Apollo")
@@ -57,13 +57,10 @@
(supplementary-groups '("wheel" "netdev" "audio" "video" "docker" "kvm")))
%base-user-accounts))
- ;; Packages installed system-wide.
(packages
(append (map specification->package system-packages)
%base-packages))
- ;; Below is the list of system services. To search for available
- ;; services, run 'guix system search KEYWORD' in a terminal.
(services
(append (list
(service docker-service-type)
@@ -79,8 +76,24 @@
(service tailscale-service-type)
(service wpa-supplicant-service-type) ;; Needed by NetworkManager
(service network-manager-service-type)
+ (service block-facebook-hosts-service-type)
+ (simple-service 'add-extra-hosts
+ hosts-service-type
+ (list (host "192.168.0.100" "zeus"
+ '())
+ (host "192.168.0.101" "uranus"
+ '())))
+ (service tailscale-service-type)
- (service transmission-daemon-service-type)
+ (service transmission-daemon-service-type
+ (transmission-daemon-configuration
+ ;; Accept requests from this and other hosts on the
+ ;; local network
+ (rpc-whitelist-enabled? #t)
+ (rpc-whitelist '("::1" "127.0.0.1" "192.168.*"))
+ (rpc-username "z3us")
+ ;; hashed password
+ (rpc-password "{eab35f5df5b1e2691acf11f49be1b1dcffa55a59FyE5eNd8")))
;; tty login
(service elogind-service-type)
@@ -149,7 +162,7 @@
(targets (list "/boot/efi"))
(keyboard-layout keyboard-layout)))
- ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
+ ;; Filesystem
(swap-devices (list (swap-space
(target (uuid swap-uuid)))))
diff --git a/guix/uranus.scm b/guix/uranus.scm
index 2a02fd5..7cc4f99 100644
--- a/guix/uranus.scm
+++ b/guix/uranus.scm
@@ -5,7 +5,8 @@
#:use-module (gnu services dbus)
#:use-module (gnu services docker)
#:use-module (gnu services version-control)
- #:use-module (gnu services cgit))
+ #:use-module (gnu services cgit)
+ #:use-module (rosenthal services networking))
(use-service-modules cups desktop networking ssh docker xorg)
@@ -28,6 +29,10 @@
(service openssh-service-type
(openssh-configuration
(permit-root-login 'prohibit-password)))
+
+ (service tailscale-service-type)
+
+
(service nginx-service-type
(nginx-configuration
(server-blocks
@@ -43,9 +48,10 @@
(listen '("*:8001"))
(ssl-certificate #f)
(ssl-certificate-key #f))))))
+
(service cgit-service-type
(cgit-configuration
- (root-desc "Freely you have received; freely give. | Mathew 10:8")
+ (root-desc "Δωρεὰν ἐλάβετε, δωρεὰν δότε. | Freely you have received; freely give. (Mathew 10:8)")
(project-list '("dotfiles" "gnosis" "yeetube"
"hecate" "pcmpl-emerge" "pcmpl-rc"
"pcmpl-tailscale" "greek-polytonic.el"))