mirror of
https://github.com/org-roam/org-roam
synced 2025-08-01 12:17:21 -05:00
140 lines
5.1 KiB
EmacsLisp
140 lines
5.1 KiB
EmacsLisp
;;; org-roam-utils.el --- Utilities for Org-roam -*- coding: utf-8; lexical-binding: t; -*-
|
|
|
|
;; Copyright © 2020 Jethro Kuan <jethrokuan95@gmail.com>
|
|
|
|
;; Author: Jethro Kuan <jethrokuan95@gmail.com>
|
|
;; URL: https://github.com/org-roam/org-roam
|
|
;; Keywords: org-mode, roam, convenience
|
|
;; Version: 2.0.0
|
|
;; Package-Requires: ((emacs "26.1") (dash "2.13") (f "0.17.2") (s "1.12.0") (org "9.4") (emacsql "3.0.0") (emacsql-sqlite3 "1.0.2") (magit-section "2.90.1"))
|
|
|
|
;; This file is NOT part of GNU Emacs.
|
|
|
|
;; This program is free software; you can redistribute it and/or modify
|
|
;; it under the terms of the GNU General Public License as published by
|
|
;; the Free Software Foundation; either version 3, or (at your option)
|
|
;; any later version.
|
|
;;
|
|
;; This program is distributed in the hope that it will be useful,
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;; GNU General Public License for more details.
|
|
;;
|
|
;; You should have received a copy of the GNU General Public License
|
|
;; along with GNU Emacs; see the file COPYING. If not, write to the
|
|
;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
;; Boston, MA 02110-1301, USA.
|
|
|
|
;;; Commentary:
|
|
;;
|
|
;; This library implements utility functions used throughout
|
|
;; Org-roam.
|
|
;;
|
|
;;
|
|
;;; Code:
|
|
;;;; Library Requires
|
|
(require 'dash)
|
|
(require 's)
|
|
|
|
(defvar org-roam-verbose)
|
|
|
|
;; This is necessary to ensure all dependents on this module see
|
|
;; `org-mode-hook' and `org-inhibit-startup' as dynamic variables,
|
|
;; regardless of whether Org is loaded before their compilation.
|
|
(require 'org)
|
|
|
|
;;;; Utility Functions
|
|
(defun org-roam--plist-to-alist (plist)
|
|
"Return an alist of the property-value pairs in PLIST."
|
|
(let (res)
|
|
(while plist
|
|
(let ((prop (intern (substring (symbol-name (pop plist)) 1 nil)))
|
|
(val (pop plist)))
|
|
(push (cons prop val) res)))
|
|
res))
|
|
|
|
(defun org-roam--list-interleave (lst separator)
|
|
"Interleaves elements in LST with SEPARATOR."
|
|
(when lst
|
|
(let ((new-lst (list (pop lst))))
|
|
(dolist (it lst)
|
|
(nconc new-lst (list separator it)))
|
|
new-lst)))
|
|
|
|
(defun org-roam-message (format-string &rest args)
|
|
"Pass FORMAT-STRING and ARGS to `message' when `org-roam-verbose' is t."
|
|
(when org-roam-verbose
|
|
(apply #'message `(,(concat "(org-roam) " format-string) ,@args))))
|
|
|
|
(defun org-roam-string-quote (str)
|
|
"Quote STR."
|
|
(->> str
|
|
(s-replace "\\" "\\\\")
|
|
(s-replace "\"" "\\\"")))
|
|
|
|
(defun org-roam-set-header-line-format (string)
|
|
"Set the header-line using STRING.
|
|
If the `face' property of any part of STRING is already set, then
|
|
that takes precedence. Also pad the left side of STRING so that
|
|
it aligns with the text area."
|
|
(setq-local header-line-format
|
|
(concat (propertize " " 'display '(space :align-to 0))
|
|
string)))
|
|
|
|
;;; Shielding regions
|
|
(defun org-roam-shield-region (beg end)
|
|
"Shield region against modifications.
|
|
BEG and END are markers for the beginning and end regions.
|
|
REGION must be a cons-cell containing the marker to the region
|
|
beginning and maximum values."
|
|
(add-text-properties beg end
|
|
'(font-lock-face org-roam-shielded
|
|
read-only t)
|
|
(marker-buffer beg)))
|
|
|
|
(defun org-roam-unshield-region (beg end)
|
|
"Unshield the shielded REGION.
|
|
BEG and END are markers for the beginning and end regions."
|
|
(let ((inhibit-read-only t))
|
|
(remove-text-properties beg end
|
|
'(font-lock-face org-roam-shielded
|
|
read-only t)
|
|
(marker-buffer beg))))
|
|
|
|
;;; Diagnostics
|
|
;;;###autoload
|
|
(defun org-roam-version (&optional message)
|
|
"Return `org-roam' version.
|
|
Interactively, or when MESSAGE is non-nil, show in the echo area."
|
|
(interactive)
|
|
(let* ((version
|
|
(with-temp-buffer
|
|
(insert-file-contents-literally (locate-library "org-roam.el"))
|
|
(goto-char (point-min))
|
|
(save-match-data
|
|
(if (re-search-forward "\\(?:;; Version: \\([^z-a]*?$\\)\\)" nil nil)
|
|
(substring-no-properties (match-string 1))
|
|
"N/A")))))
|
|
(if (or message (called-interactively-p 'interactive))
|
|
(message "%s" version)
|
|
version)))
|
|
|
|
;;;###autoload
|
|
(defun org-roam-diagnostics ()
|
|
"Collect and print info for `org-roam' issues."
|
|
(interactive)
|
|
(with-current-buffer (switch-to-buffer-other-window (get-buffer-create "*org-roam diagnostics*"))
|
|
(erase-buffer)
|
|
(insert (propertize "Copy info below this line into issue:\n" 'face '(:weight bold)))
|
|
(insert (format "- Emacs: %s\n" (emacs-version)))
|
|
(insert (format "- Framework: %s\n"
|
|
(condition-case _
|
|
(completing-read "I'm using the following Emacs framework:"
|
|
'("Doom" "Spacemacs" "N/A" "I don't know"))
|
|
(quit "N/A"))))
|
|
(insert (format "- Org: %s\n" (org-version nil 'full)))
|
|
(insert (format "- Org-roam: %s" (org-roam-version)))))
|
|
|
|
(provide 'org-roam-utils)
|
|
;;; org-roam-utils.el ends here
|