Files
doom-emacs-work-conf/flycheck_config.el

764 lines
29 KiB
EmacsLisp
Raw Normal View History

2026-02-05 15:07:42 +01:00
;;; $DOOMDIR/config.el -*- lexical-binding: t; -*-
;; Place your private configuration here! Remember, you do not need to run 'doom
;; sync' after modifying this file!
;; Some functionality uses this to identify you, e.g. GPG configuration, email
;; clients, file templates and snippets. It is optional.
;; (setq user-full-name "John Doe"
;; user-mail-address "john@doe.com")
;; Doom exposes five (optional) variables for controlling fonts in Doom:
;;
;; - `doom-font' -- the primary font to use
;; - `doom-variable-pitch-font' -- a non-monospace font (where applicable)
;; - `doom-big-font' -- used for `doom-big-font-mode'; use this for
;; presentations or streaming.
;; - `doom-symbol-font' -- for symbols
;; - `doom-serif-font' -- for the `fixed-pitch-serif' face
;;
;; See 'C-h v doom-font' for documentation and more examples of what they
;; accept. For example:
;;
;;(setq doom-font (font-spec :family "Fira Code" :size 12 :weight 'semi-light)
;; doom-variable-pitch-font (font-spec :family "Fira Sans" :size 13))
;;
;; If you or Emacs can't find your font, use 'M-x describe-font' to look them
;; up, `M-x eval-region' to execute elisp code, and 'M-x doom/reload-font' to
;; refresh your font settings. If Emacs still can't find your font, it likely
;; wasn't installed correctly. Font issues are rarely Doom issues!
;; There are two ways to load a theme. Both assume the theme is installed and
;; available. You can either set `doom-theme' or manually load a theme with the
;; `load-theme' function. This is the default:
;; (setq doom-theme 'doom-one)
;; This determines the style of line numbers in effect. If set to `nil', line
;; numbers are disabled. For relative line numbers, set this to `relative'.
(setq display-line-numbers-type t)
;; If you use `org' and don't want your org files in the default location below,
;; change `org-directory'. It must be set before org loads!
(setq org-directory "/mnt/c/Users/q669019/Bachelor/org/")
;; Whenever you reconfigure a package, make sure to wrap your config in an
;; `after!' block, otherwise Doom's defaults may override your settings. E.g.
;;
;; (after! PACKAGE
;; (setq x y))
;;
;; The exceptions to this rule:
;;
;; - Setting file/directory variables (like `org-directory')
;; - Setting variables which explicitly tell you to set them before their
;; package is loaded (see 'C-h v VARIABLE' to look up their documentation).
;; - Setting doom variables (which start with 'doom-' or '+').
;;
;; Here are some additional functions/macros that will help you configure Doom.
;;
;; - `load!' for loading external *.el files relative to this one
;; - `use-package!' for configuring packages
;; - `after!' for running code after a package has loaded
;; - `add-load-path!' for adding directories to the `load-path', relative to
;; this file. Emacs searches the `load-path' when you load packages with
;; `require' or `use-package'.
;; - `map!' for binding new keys
;;
;; To get information about any of these functions/macros, move the cursor over
;; the highlighted symbol at press 'K' (non-evil users must press 'C-c c k').
;; This will open documentation for it, including demos of how they are used.
;; Alternatively, use `C-h o' to look up a symbol (functions, variables, faces,
;; etc).
;;
;; You can also try 'gd' (or 'C-c c d') to jump to their definition and see how
;; they are implemented.
;; (setq doom-theme 'catppuccin)
;; (setq doom-theme 'doom-palenight)
;;(setq org-startup-with-inline-images t)
;; for inline images in org mode
(setq org-display-inline-images t)
(setq org-redisplay-inline-images t)
(setq org-startup-with-inline-images "inlineimages")
;; (defun my/org-insert-latest-screenshot ()
;; "Copy the latest screenshot into the current directory and insert it as [[filename]]."
;; (interactive)
;; (let* ((src (car (sort (directory-files "~/Bilder/Bildschirmfotos/" t ".*\\.png$")
;; (lambda (a b)
;; (time-less-p (file-attribute-modification-time (file-attributes b))
;; (file-attribute-modification-time (file-attributes a))))))
;; (filename (format "Pasted image %s.png"
;; (format-time-string "%Y%m%dT%H%M%S")))
;; (dst (expand-file-name filename default-directory)))
;; (copy-file src dst)
;; (insert (format "[[%s]]" filename))))
;;
;; (map! :after org
;; :map org-mode-map
;; :leader
;; "i l" #'my/org-insert-latest-screenshot)
;; (with-eval-after-load "ispell"
;; ;; Configure `LANG`, otherwise ispell.el cannot find a 'default
;; ;; dictionary' even though multiple dictionaries will be configured
;; ;; in next line.
;; (setenv "LANG" "en_US.UTF-8")
;; (setq ispell-program-name "hunspell")
;; ;; Configure German, Swiss German, and two variants of English.
;; (setq ispell-dictionary "de_DE,en_US")
;; ;; ispell-set-spellchecker-params has to be called
;; ;; before ispell-hunspell-add-multi-dic will work
;; (ispell-set-spellchecker-params)
;; (ispell-hunspell-add-multi-dic "de_DE,en_US")
;; ;; For saving words to the personal dictionary, don't infer it from
;; ;; the locale, otherwise it would save to ~/.hunspell_de_DE.
;; (setq ispell-personal-dictionary "~/.hunspell_personal"))
;;
;; ;; The personal dictionary file has to exist, otherwise hunspell will
;; ;; silently not use it.
;; (unless (file-exists-p ispell-personal-dictionary)
;; (write-region "" nil ispell-personal-dictionary nil 0))
;;
;; (use-package flycheck
;; :ensure t
;; :config
;; (add-hook 'after-init-hook #'global-flycheck-mode))
;; (after! lsp-mode
;; (setq lsp-diagnostics-provider :flycheck))
;;
;;
;; (add-hook 'spell-fu-mode-hook
;; (lambda ()
;; (spell-fu-dictionary-add (spell-fu-get-ispell-dictionary "de_DE"))
;; (spell-fu-dictionary-add (spell-fu-get-ispell-dictionary "en_US"))
;; ))
;;
;;
;; (setq ispell-program-name "aspell"
;; aspell-dictionary "de_DE"
;; aspell-dictionary "en_US"
;; aspell-program-name "aspell"
;; ispell-dictionary "de_DE"
;; ispell-dictionary "en_US"
;; ispell-program-name "aspell")
(after! ispell
(setq ispell-really-hunspell t
ispell-program-name "hunspell"
ispell-dictionary "en_US,de_DE")
(ispell-set-spellchecker-params)
(ispell-hunspell-add-multi-dic "en_US,de_DE"))
(use-package! flycheck)
(use-package flycheck-languagetool
:ensure t
:hook (text-mode . flycheck-languagetool-setup)
:init
(setq flycheck-languagetool-server-jar "~/.languagetool-server.jar"))
(require 'ansi-color)
(defun display-ansi-colors ()
(interactive)
(ansi-color-apply-on-region (point-min) (point-max)))
(remove-hook 'org-mode-hook #'ws-butler-mode)
(add-hook 'org-mode-hook (lambda () (ws-butler-mode -1)))
;;(use-package! org-fragtog
;; :after org
;; :hook (org-mode . org-fragtog) ; this auto-enables it when you enter an org-buffer, remove if you do not want this
;; :config
;; ;; whatever you want
;; )
(defun toggle-org-latex-preview-on-save ()
"adds or removes after save hook to org-latex-preview"
(interactive)
(if (memq 'org-latex-preview after-save-hook)
(progn
(remove-hook 'after-save-hook 'org-latex-preview)
;; (remove-hook 'after-save-hook 'org-latex-preview t)
(message "Disabled org latex preview on save for current buffer..."))
(add-hook 'after-save-hook 'org-latex-preview)
;; (add-hook 'after-save-hook 'org-latex-preview nil t)
(message "Enabled org latex preview on save for current buffer...")))
;; (add-to-list 'org-latex-packages-alist '("" "tikz" t))
;;
;; (eval-after-load "preview"
;; '(add-to-list 'preview-default-preamble
;; "\\PreviewEnvironment{tikzpicture}" t))
(org-babel-do-load-languages
'org-babel-load-languages
'((latex . t)))
(after! org
(setq org-startup-with-latex-preview t)
(setq font-lock-maximum-decoration t))
(add-hook 'org-mode-hook #'turn-on-font-lock)
(menu-bar--display-line-numbers-mode-relative)
;; (setq org-preview-latex-default-process :imagemagick)
;;
;; (setq org-babel-latex-htlatex "htlatex")
;; (defmacro by-backend (&rest body)
;; `(case org-export-current-backend ,@body))
;; #+REVEAL_ROOT: https://cdn.jsdelivr.net/npm/reveal.js
;; Reveal.js + Org mode
(use-package ox-reveal
:after org)
(use-package! ox-reveal
:after ox)
(require 'ox-reveal)
(setq Org-Reveal-title-slide nil)
;; Wrong number of arguments?!?!
;;(setq org-export-backends md ascii html icalendar latex odt typst reveal)
;; (defun org-insert-src-block (src-code-type)
;; "Insert a `SRC-CODE-TYPE' type source code block in org-mode."
;; (interactive
;; (let ((src-code-types
;; '("emacs-lisp" "python" "C" "sh" "java" "js" "clojure" "C++" "css"
;; "calc" "asymptote" "dot" "gnuplot" "ledger" "lilypond" "mscgen"
;; "octave" "oz" "plantuml" "R" "sass" "screen" "sql" "awk" "ditaa"
;; "haskell" "latex" "lisp" "matlab" "ocaml" "org" "perl" "ruby"
;; "scheme" "sqlite")))
;; (list (ido-completing-read "Source code type: " src-code-types))))
;; (progn
;; (newline-and-indent)
;; (insert (format "#+BEGIN_SRC %s\n" src-code-type))
;; (newline-and-indent)
;; (insert "#+END_SRC\n")
;; (previous-line 2)
;; (org-edit-src-code)
;; )
;; )
(defun org-insert-c-src()
"Insert a C src block with a helper function to run it."
(interactive)
(progn
(newline-and-indent)
(insert "#+NAME: cprog\n#+BEGIN_SRC C :tangle (concat (org-get-heading t t t t) \".c\") :results output")
(newline-and-indent)
(insert "#+END_SRC\n")
(newline-and-indent)
;;(insert "#+BEGIN_SRC sh :dir . :results output :exports both :var filename=(concat (org-get-heading t t t t) \".c\") output=(concat (org-get-heading t t t t) \".o\")\n# output=${filename%.*}.o\ngcc $filename -o $output\n./$output\n# ./$output <<EOF\n# input here\n# EOF\n#+END_SRC")
(org-insert-c-helper)
(previous-line 15)
(back-to-indentation)
;; (insert "#+END_SRC\n")
;; (previous-line 2)
;; (evil-insert-state)
)
)
(defun org-insert-c-helper ()
(interactive)
(progn
(insert "#+BEGIN_SRC sh :dir . :results output :exports both :var filename=(concat (org-get-heading t t t t) \".c\") output=(concat (org-get-heading t t t t) \".o\")\ncat <<EOF >$filename\n<<cprog>>\nEOF\n\n# output=${filename%.*}.o\ngcc $filename -o $output\n./$output\n# ./$output <<EOF\n# input here\n# EOF\n#+END_SRC")
)
)
(defun org-insert-c-exercise ()
(interactive)
(progn
(newline-and-indent)
(org-meta-return)
(insert (format "Exercise_%s" (read-string "Exercise_")))
(org-insert-c-src)
)
)
(setq gptel-model 'gpt-5
gptel-backend (gptel-make-gh-copilot "Copilot"
))
(defun my/gptel-url-retrieve(orig-fun url &rest args)
"Advice to replace github.com with bmw.ghe.com in URLs for `gptel--url-retrieve`."
(let ((modified-url (replace-regexp-in-string
"[^\.]+\.com"
"bmw\.ghe\.com"
url)))
(apply orig-fun modified-url args)))
;; Add the advice around gptel--url-retrieve
(advice-add 'gptel--url-retrieve :around #'my/gptel-url-retrieve)
;; (advice-add 'gptel-send :around #'my/gptel-url-retrieve)
;; Determine the specific system type.
;; Emacs variable system-type doesn't yet have a "wsl/linux" value,
;; so I'm front-ending system-type with my variable: sysTypeSpecific.
;; I'm no elisp hacker, so I'm diverging from the elisp naming convention
;; to ensure that I'm not stepping on any pre-existing variable.
(setq-default sysTypeSpecific system-type) ;; get the system-type value
;; (cond
;; ;; If type is "gnu/linux", override to "wsl/linux" if it's WSL.
;; ((eq sysTypeSpecific 'gnu/linux)
;; (when (string-match "Linux.*Microsoft.*Linux"
;; (shell-command-to-string "uname -a"))
;;
;; (setq-default sysTypeSpecific "wsl/linux") ;; for later use.
;; (setq
;; cmdExeBin"/mnt/c/Windows/System32/cmd.exe"
;; cmdExeArgs '("/c" "start" "") )
;; (setq
;; browse-url-generic-program cmdExeBin
;; browse-url-generic-args cmdExeArgs
;; browse-url-browser-function 'browse-url-generic)
;; )))
(setq calendar-week-start-day 1)
(setq calendar-intermonth-text
'(propertize
(format "%2d"
(car
(calendar-iso-from-absolute
(calendar-absolute-from-gregorian (list month day year)))))
'font-lock-face 'font-lock-warning-face))
(setq calendar-intermonth-header
(propertize "W" ; or e.g. "KW" in Germany
'font-lock-face 'font-lock-keyword-face))
(use-package! org-roam-bibtex
:after org-roam
:config
(require 'org-ref)) ; optional: if using Org-ref v2 or v3 citation links
(use-package! websocket
:after org-roam)
(use-package! org-roam-ui
:after org-roam ;; or :after org
;; normally we'd recommend hooking orui after org-roam, but since org-roam does not have
;; a hookable mode anymore, you're advised to pick something yourself
;; if you don't care about startup time, use
;; :hook (after-init . org-roam-ui-mode)
: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! citar
:custom
;;(org-cite-global-bibliography '("C:/Users/q669019/Bachelor/Bibliothek/Bibliothek.bib"))
(org-cite-global-bibliography '("/mnt/c/Users/q669019/Bachelor/Literatur/Bibliothek/Bibliothek.bib"))
;;(citar-bibliography '("C:/Users/q669019/Bachelor/Bibliothek/")))
(citar-bibliography '("/mnt/c/Users/q669019/Bachelor/Literatur/Bibliothek/Bibliothek.bib")))
;;(setq default-directory "C:/Users/q669019/Bachelor/")
(setq default-directory "/mnt/c/Users/q669019/Bachelor/")
;; from https://pragmaticemacs.wordpress.com/2017/11/08/more-pdf-tools-tweaks/
;; automatically annotate highlights
(setq pdf-annot-activate-created-annotations t)
;; more fine-grained zooming
(setq pdf-view-resize-factor 1.1)
;; keyboard shortcuts
;;
;;(define-key pdf-view-mode-map (kbd "h") 'pdf-annot-add-highlight-markup-annotation)
;;;;(define-key pdf-view-mode-map (kbd "t") 'pdf-annot-add-text-annotation)
;;;;(define-key pdf-view-mode-map (kbd "D") 'pdf-annot-delete)
;; (map! :map evil-normal-state-map "SPC i t" #'insert-current-date-time)
;; (map! :after pdf-view
;; :map pdf-view-mode-map
;; :prefix "a"
;; "h" #'pdf-annot-add-highlight-markup-annotation
;; "t" #'pdf-annot-add-text-annotation
;; "m" #'pdf-annot-add-markup-annotation
;; "l" #'pdf-annot-list-annotations
;; "D" #'pdf-annot-delete
;; "a" #'pdf-annot-attachment-dired
;; )
(map! :map pdf-view-mode-map :n "a h" #'pdf-annot-add-highlight-markup-annotation)
(map! :map pdf-view-mode-map :n "a t" #'pdf-annot-add-text-annotation)
(map! :map pdf-view-mode-map :n "a D" #'pdf-annot-delete)
(map! :map pdf-view-mode-map :n "a l" #'pdf-annot-list-annotations)
(map! :map pdf-view-mode-map :n "a a" #'pdf-annot-attachment-dired)
(map! :map pdf-view-mode-map :n "a m" #'pdf-annot-add-markup-annotation)
;; ====================
;; insert date and time
(defvar current-date-time-format "%Y-%m-%dT%H:%M:%S"
"Format of date to insert with `insert-current-date-time' func
See help of `format-time-string' for possible replacements")
(defvar current-time-format "%H:%M:%S"
"Format of date to insert with `insert-current-time' func.
Note the weekly scope of the command's precision.")
(defun insert-current-date-time ()
"insert the current date and time into current buffer.
Uses `current-date-time-format' for the formatting the date/time."
(interactive)
(insert (format-time-string current-date-time-format (current-time)))
)
(defun insert-current-time ()
"insert the current time (1-week scope) into the current buffer."
(interactive)
(insert (format-time-string current-time-format (current-time)))
(insert "\n")
)
;;(map! "SPC i t" #'insert-current-date-time)
;; (global-set-key "SPC i t" 'insert-current-date-time)
;; (global-set-key "\C-c\C-t" 'insert-current-time)
(map! :map evil-normal-state-map "SPC i t" #'insert-current-date-time)
;; (setenv "MSYSTEM" "UCRT64") ;; Tell MSYS2 which subsystem
;; (setenv "CHERE_INVOKING" "1") ;; Avoid directory change
(setq +latex-viewers '(pdf-tools))
(setq lsp-tex-server 'texlab)
;; (add-hook LaTeX-mode-hook #'xenops-mode)
(when (eq window-system 'w32)
(setq tramp-use-ssh-controlmaster-options nil)
(add-to-list 'tramp-connection-properties
(list (regexp-quote "/ssh:")
"login-args"
'(("-tt") ("-l" "%u") ("-p" "%p") ("%c")
("-e" "none") ("%h"))))
)
;;(load "./typing-speed.el")
(after! tramp
(setq tramp-default-method "ssh"
tramp-use-ssh-controlmaster-options nil ; sometimes fixes Windows hangs
tramp-verbose 6
tramp-inline-compress-start-size 1000
tramp-use-sh-file-name nil)) ; avoid weird /bin/sh resolution on Windows
;; If your remote prompt is fancy, tighten prompt regexp:
;;(setq tramp-shell-prompt-pattern "^[^#$%>\n]*[#$%>] *"))
;; (let ((msys "C:/Users/q669019/Programs/msys2"))
;; ;; Ensure MSYS2 userland tools (bash, ssh, etc.) are found
;; (add-to-list 'exec-path (concat msys "/usr/bin"))
;; (setenv "PATH" (concat msys "/usr/bin;" (getenv "PATH")))
;; ;; Use bash, NOT ucrt64.exe
;; (setq explicit-shell-file-name (concat msys "/usr/bin/bash.exe")
;; shell-file-name explicit-shell-file-name)
;; (setenv "SHELL" shell-file-name)
;; ;; Make TRAMP use ssh (default, but force just in case)
;; (setq tramp-default-method "ssh")
;; ;; Hide flashing helper consoles
;; (setq w32-start-process-show-window nil)
;; )
(use-package! cypher-mode)
(use-package! n4js)
(setq n4js-cli-arguments '("-port" "7474"))
(use-package! n4js)
;;(use-package evangelion-theme
;; :custom
;; ;; `nil' to disable background for comments
;; (evangelion-comment-background-enabled . t)
;; :config (load-theme 'evangelion t))
;;(setq doom-theme 'evangelion)
(use-package ob-cypher
:ensure t
:config
(add-to-list 'org-babel-load-languages '(cypher . t))
(org-babel-do-load-languages 'org-babel-load-languages org-babel-load-languages)
(add-to-list 'org-babel-tangle-lang-exts '("cypher" . "cypher")))
(defun org-insert-cypher-block()
"Insert a cypher/ neo4j src block."
(interactive)
(progn
(newline-and-indent)
(insert "#+BEGIN_SRC cypher :port 7687 :file ./.png\n")
(insert "#+END_SRC\n")
(newline-and-indent)
;;(insert "#+BEGIN_SRC sh :dir . :results output :exports both :var filename=(concat (org-get-heading t t t t) \".c\") output=(concat (org-get-heading t t t t) \".o\")\n# output=${filename%.*}.o\ngcc $filename -o $output\n./$output\n# ./$output <<EOF\n# input here\n# EOF\n#+END_SRC")
;; (insert "#+END_SRC\n")
;; (previous-line 3)
(back-to-indentation)
(search-backward ".png") ; point now at the '.' before png
(evil-insert-state)
)
)
(with-eval-after-load 'ob-cypher
(defvar ob-cypher-database "neo4j")
(advice-add
'ob-cypher/query :around
(lambda (_orig statement host port authstring)
(let* ((statement (s-replace "\"" "\\\"" statement))
(body (format
"{\"statements\":[{\"statement\":\"%s\",\"resultDataContents\":[\"graph\",\"row\"]}]}"
(s-join " " (s-lines statement))))
(url (format "http://%s:%d/db/%s/tx/commit" host port ob-cypher-database))
(tmp (org-babel-temp-file "cypher-curl-"))
(auth-header (unless (string-empty-p authstring)
(format "-H 'Authorization: Basic %s'" authstring)))
(cmd (format
"curl -s -H 'Accept: application/json; charset=UTF-8' -H 'Content-Type: application/json' %s -d@'%s' '%s'"
(or auth-header "") tmp url)))
(with-temp-file tmp (insert body))
(shell-command-to-string cmd)))))
(use-package! csv-mode)
(defun evangelion-splash ()
(let* ((banner '(" _ ____ "
" : \\ | \\ . "
" | \\ . | : |\\ /\\ "
" . | :|\\__ | | | \\ / \\ "
" |\\ | |! \\ \\ | | | |\\ / / "
" \\\"-.______ | \\: ||\\ \\ \\ | | | | \\ / / "
" \\_ \"-_| |\\ || \\ \\/ | |___| ! |\\____/ _/-. /\\ "
" \"-_ ____: |_\\ || \\/ ___\\ __ _// | | ___ \\---\" / "
" \\ \\ | _____, /___\\___\\/ / / \\_! | // _/ / / "
" ___\\_ \\__| | | __. _/____ / / / > // / \\/ "
" //_________| / |/ |/ \\__// / / /_/ \\/ "
" | / | : | / /__/ "
" |/ |/ "
" E M A C S "))
(longest-line (apply #'max (mapcar #'length banner))))
(put-text-property (point) (dolist (line banner (point))
(insert (+doom-dashboard--center
+doom-dashboard--width
(concat line (make-string (max 0 (- longest-line (length line))) 50)))
"\n")) 'face 'doom-dashboard-banner)))
(setq +doom-dashboard-ascii-banner-fn #'evangelion-splash)
;; (use-package! company-org-block)
(use-package company-org-block
;; :ensure t
;; :custom
;; (company-org-block-edit-style 'auto) ;; 'auto, 'prompt, or 'inline
:hook ((org-mode . (lambda ()
(setq-local company-backends '(company-org-block))
(company-mode +1)))))
(setq company-org-block-edit-style 'auto) ;; 'auto, 'prompt, or 'inline
(add-hook 'org-mode-hook
(lambda ()
(add-to-list (make-local-variable 'company-backends)
'company-org-block)))
;; (use-package evangelion-theme
;; :config (load-theme 'evangelion t))
;; (evangelion-comment-background-enabled . t)
;; (setq doom-theme 'evangelion)
(setq doom-theme 'doom-palenight)
(defun org-insert-cite-eol ()
(interactive)
(progn
(evil-org-end-of-line)
(insert " ")
(call-interactively 'org-cite-insert)
))
;; (map! :map evil-normal-state-map "SPC m $" #'org-cite-insert-eol)
;; (add-hook 'csv-mode-hook
;; (lambda ()
;; (visual-line-mode -1)
;; (toggle-truncate-lines 1)))
;; disable line wrap
(defun disable-linewrap ()
"csv line wrap setup"
(visual-line-mode -1)
(toggle-truncate-lines 1))
(add-hook 'csv-mode-hook #'disable-linewrap)
;; später entfernen:
;; (remove-hook 'csv-mode-hook #'disable-linewrap)
;; auto detect separator
(add-hook 'csv-mode-hook #'csv-guess-set-separator)
;; turn on field alignment
(add-hook 'csv-mode-hook #'csv-align-mode)
;; add csv header line
(add-hook 'csv-mode-hook #'csv-header-line)
(defun toggle-csv-mode-hooks ()
"Toggle my CSV mode hooks (add/remove)."
(interactive)
(if (memq #'disable-linewrap csv-mode-hook)
(progn
(remove-hook 'csv-mode-hook #'disable-linewrap)
(visual-line-mode t)
(toggle-truncate-lines)
(remove-hook 'csv-mode-hook #'csv-guess-set-separator)
(csv-guess-set-separator)
(remove-hook 'csv-mode-hook #'csv-align-mode)
(csv-align-mode)
(remove-hook 'csv-mode-hook #'csv-header-line)
(csv-header-line)
(normal-mode)
(message "CSV hooks removed"))
(progn
(add-hook 'csv-mode-hook #'disable-linewrap)
(add-hook 'csv-mode-hook #'csv-guess-set-separator)
(add-hook 'csv-mode-hook #'csv-align-mode)
(add-hook 'csv-mode-hook #'csv-header-line)
(normal-mode)
(message "CSV hooks added"))))
;; (map! :map csv-mode-map "SPC t ;" #'toggle-csv-mode-hooks)
(map! :after csv-mode
:map csv-mode-map
:desc "Toggle CSV hooks"
:n "SPC t ;" #'toggle-csv-mode-hooks)
;; :leader
;; "t;" #'toggle-csv-mode-hooks)
;; make invisible characters more visible
(setq! glyphless-char-display-control '((format-control . empty-box) (variation-selectors . thin-space) (no-font . hex-code)))
(with-eval-after-load 'ob-cypher
;; Eigene Variante von org-babel-execute:cypher
(defun my/org-babel-execute:cypher (body params)
"Erweiterte Version von `org-babel-execute:cypher`.
Verhalten:
- Mit :file und :result-type graph -> wie bisher: Graphviz/DOT.
- Mit :file und :result-type json -> rohes JSON in Datei.
(with-eval-after-load 'ob-cypher
;; Erweiterte/ersetzte Variante von org-babel-execute:cypher
(defun my/org-babel-execute:cypher (body params)
Erweiterte Version von `org-babel-execute:cypher`.
Verhalten:
- :result-type graph -> wie bisher: Graphviz/DOT, Datei wird von `dot` erzeugt.
- :result-type json -> rohes JSON als String (Org schreibt es bei :file selber weg).
- sonst (Standard) -> Tabelle per REST; mit :file als CSV-Text zurückgeben,
den Org bei :results ... file in die Datei schreibt."
(let* ((host (or (cdr (assoc :host params)) "127.0.0.1"))
(port (or (cdr (assoc :port params)) 1337))
(username (or (cdr (assoc :username params)) "neo4j"))
(password (or (cdr (assoc :password params)) "neo4j"))
(authstring (base64-encode-string (concat username ":" password)))
(http-port (or (cdr (assoc :http-port params)) 7474))
;; optionaler Header :result-type (eigene Erweiterung)
(rt-raw (cdr (assoc :result-type params)))
(result-type
(cond
((symbolp rt-raw) rt-raw)
((stringp rt-raw) (intern (downcase rt-raw)))
(t nil)))
(file (cdr (assoc :file params)))
(body (if (s-ends-with? ";" body) body (s-append ";" body))))
(cond
;; 1. Graphviz wie im Original (für Bilder/DOT-Ausgabe)
((eq result-type 'graph)
(unless file
(user-error "Für :result-type graph musst du auch :file angeben"))
;; erzeugt die Datei als Seiteneffekt, gibt nil zurück
(ob-cypher/dot body host http-port file authstring))
;; 2. Rohes JSON (z.B. für Debug oder eigene Weiterverarbeitung)
;; Bei :results ... file und :file <pfad> schreibt Org den String in die Datei.
((eq result-type 'json)
(ob-cypher/query body host http-port authstring))
;; 3. Standard: REST -> Tabelle; mit :file als CSV-Text
(t
(let ((tbl (ob-cypher/rest body host http-port authstring)))
(if file
(progn
(require 'org-table)
;; Wir liefern nur den CSV-String zurück.
;; Org schreibt ihn bei :results ... file in `file`.
(orgtbl-to-csv tbl nil))
;; Kein :file -> Tabelle als normales Babel-Ergebnis
tbl))))))
;; Originalfunktion vollständig übersteuern
(advice-add 'org-babel-execute:cypher
:override #'my/org-babel-execute:cypher))
(use-package org-mind-map
:init
(require 'ox-org)
:ensure t
;; Uncomment the below if 'ensure-system-packages` is installed
;;:ensure-system-package (gvgen . graphviz)
:config
(setq org-mind-map-engine "dot") ; Default. Directed Graph
;; (setq org-mind-map-engine "neato") ; Undirected Spring Graph
;; (setq org-mind-map-engine "twopi") ; Radial Layout
;; (setq org-mind-map-engine "fdp") ; Undirected Spring Force-Directed
;; (setq org-mind-map-engine "sfdp") ; Multiscale version of fdp for the layout of large graphs
;; (setq org-mind-map-engine "twopi") ; Radial layouts
;; (setq org-mind-map-engine "circo") ; Circular Layout
)
(defalias 'first #'cl-first)
(add-hook 'pdf-view-mode-hook (lambda () (pdf-view-themed-minor-mode t)))
(setq doom-snippets-dir (expand-file-name "doom-snippets/" doom-user-dir))
(setq +snippets-dir (expand-file-name "private-snippets/" doom-user-dir))
(use-package org-noter)
;; just like in pdf-view
(map! :map evil-normal-state-map "SPC j m" #'jump-to-register)
(map! :map evil-normal-state-map "SPC j M" #'point-to-register)
(map! :map evil-normal-state-map "SPC j '" #'point-to-register)
;; pdf view
;;(define-key map (kbd "'") 'pdf-view-jump-to-register)
;; (map! :after pdf-view :map pdf-view-mode-map "SPC j m" #'pdf-view-jump-to-register)
;; (map! :after pdf-view :map pdf-view-mode-map "SPC j M" #'pdf-view-point-to-register)
(map! :map pdf-view-mode-map :n "m" #'pdf-view-jump-to-register)
(map! :map pdf-view-mode-map :n "M" #'pdf-view-position-to-register)
(map! :map evil-normal-state-map "SPC j n" #'evil-jump-forward)
(map! :map evil-normal-state-map "SPC j N" #'evil-jump-backward)
(map! :after latex-mode :map latex-mode-map :n "SPC i c" #'citar-insert-citation)