From 97ea5d017a2c9a889604fb5216ded59a1952e723 Mon Sep 17 00:00:00 2001 From: hammerfunctor Date: Mon, 18 Dec 2023 00:01:39 -0500 Subject: [PATCH 1/3] New file --- lisp/ol-arxiv.el | 76 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 lisp/ol-arxiv.el diff --git a/lisp/ol-arxiv.el b/lisp/ol-arxiv.el new file mode 100644 index 000000000..280b909f2 --- /dev/null +++ b/lisp/ol-arxiv.el @@ -0,0 +1,76 @@ +;;; ol-arxiv.el --- ARXIV links support in Org -*- lexical-binding: t; -*- + +;; Copyright (C) 2023-2023 Free Software Foundation, Inc. + +;; Author: Zhengfei Hu + +;; This file is part of GNU Emacs. + +;; GNU Emacs 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 of the License, or +;; (at your option) any later version. + +;; GNU Emacs 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. If not, see . + +;;; Commentary: + +;; This library introduces the "arxiv" link type in Org, and provides +;; code for opening and exporting such links. + +;;; Code: + +(require 'org-macs) +(org-assert-version) + +(require 'ol) + +(defcustom org-link-arxiv-server-url "https://arxiv.org/abs/" + "The URL of the ARXIV server." + :group 'org-link-follow + :version "24.3" + :type 'string + :safe #'stringp) + +(defun org-link-arxiv-open (path arg) + "Open a \"arxiv\" type link. +PATH is a the path to search for, as a string. +ARG is passed to `browse-url'." + (browse-url (url-encode-url (concat org-link-arxiv-server-url path)) arg)) + +(defun org-link-arxiv-export (path desc backend info) + "Export a \"arxiv\" type link. +PATH is the ARXIV name. DESC is the description of the link, or +nil. BACKEND is a symbol representing the backend used for +export. INFO is a plist containing the export parameters." + (let ((uri (concat org-link-arxiv-server-url path))) + (pcase backend + (`html + (format "%s" uri (or desc uri))) + (`latex + (if desc (format "\\href{%s}{%s}" uri desc) + (format "\\url{%s}" uri))) + (`ascii + (if (not desc) (format "<%s>" uri) + (concat (format "[%s]" desc) + (and (not (plist-get info :ascii-links-to-notes)) + (format " (<%s>)" uri))))) + (`texinfo + (if (not desc) (format "@uref{%s}" uri) + (format "@uref{%s, %s}" uri desc))) + (_ uri)))) + +(org-link-set-parameters "arxiv" + :follow #'org-link-arxiv-open + :export #'org-link-arxiv-export) + + +(provide 'org-link-arxiv) +(provide 'ol-arxiv) +;;; ol-arxiv.el ends here -- 2.43.0