|
@@ -54,7 +54,10 @@
|
|
|
|
|
|
;; The library supports the following citation styles:
|
|
|
;;
|
|
|
+;; - author (a), including caps (c), full (f), and caps-full (cf) variants,
|
|
|
;; - noauthor (na), including bare (b), caps (c) and bare-caps (bc) variants,
|
|
|
+;; - year (y), including a bare (b) variant,
|
|
|
+;; - text (t). including caps (c), full (f), and caps-full (cf) variants,
|
|
|
;; - default style, including bare (b), caps (c) and bare-caps (bc) variants.
|
|
|
|
|
|
;; CSL styles recognize "locator" in citation references' suffix. For example,
|
|
@@ -277,26 +280,54 @@ INFO is the export state, as a property list."
|
|
|
(citeproc-proc-style
|
|
|
(org-cite-csl--processor info))))
|
|
|
|
|
|
-(defun org-cite-csl--no-affixes-p (citation info)
|
|
|
- "Non-nil when CITATION should be exported without affix.
|
|
|
-INFO is the export data, as a property list."
|
|
|
- (pcase (org-cite-citation-style citation info)
|
|
|
- (`(,(or "noauthor" "na" `nil) . ,(or "bare" "b" "bare-caps" "bc")) t)
|
|
|
- (_ nil)))
|
|
|
-
|
|
|
-(defun org-cite-csl--capitalize-p (citation info)
|
|
|
- "Non-nil when CITATION should be capitalized.
|
|
|
-INFO is the export-data, as a property list."
|
|
|
- (pcase (org-cite-citation-style citation info)
|
|
|
- (`(,(or "noauthor" "na" `nil) . ,(or "caps" "c" "bare-caps" "bc")) t)
|
|
|
- (_ nil)))
|
|
|
-
|
|
|
-(defun org-cite-csl--no-author-p (reference info)
|
|
|
- "Non-nil when citation REFERENCE should be exported without author.
|
|
|
-INFO is the export data, as a property list."
|
|
|
- (pcase (org-cite-citation-style (org-element-property :parent reference) info)
|
|
|
- (`(,(or "noauthor" "na") . ,_) t)
|
|
|
- (_ nil)))
|
|
|
+(defun org-cite-csl--create-structure-params (citation info)
|
|
|
+ "Return citeproc structure creation params for CITATION object.
|
|
|
+STYLE is the citation style, as a string or nil. INFO is the export state, as
|
|
|
+a property list."
|
|
|
+ (let* ((style (org-cite-citation-style citation info)))
|
|
|
+ (pcase style
|
|
|
+ ;; "author" style.
|
|
|
+ (`(,(or "author" "a") . ,(or "caps" "c"))
|
|
|
+ '(:mode author-only :capitalize-first t :suppress-affixes t))
|
|
|
+ (`(,(or "author" "a") . ,(or "full" "f"))
|
|
|
+ '(:mode author-only :ignore-et-al t :suppress-affixes t))
|
|
|
+ (`(,(or "author" "a") . ,(or "caps-full" "cf"))
|
|
|
+ '(:mode author-only :capitalize-first t :ignore-et-al t :suppress-affixes t))
|
|
|
+ (`(,(or "author" "a") . ,_)
|
|
|
+ '(:mode author-only :suppress-affixes t))
|
|
|
+ ;; "noauthor" style.
|
|
|
+ (`(,(or "noauthor" "na") . ,(or "bare" "b"))
|
|
|
+ '(:mode suppress-author :suppress-affixes t))
|
|
|
+ (`(,(or "noauthor" "na") . ,(or "caps" "c"))
|
|
|
+ '(:mode suppress-author :capitalize-first t))
|
|
|
+ (`(,(or "noauthor" "na") . ,(or "bare-caps" "bc"))
|
|
|
+ '(:mode suppress-author :suppress-affixes t :capitalize-first t))
|
|
|
+ (`(,(or "noauthor" "na") . ,_)
|
|
|
+ '(:mode suppress-author))
|
|
|
+ ;; "year" style.
|
|
|
+ (`(,(or "year" "y") . ,(or "bare" "b"))
|
|
|
+ '(:mode year-only :suppress-affixes t))
|
|
|
+ (`(,(or "year" "y") . ,_)
|
|
|
+ '(:mode year-only))
|
|
|
+ ;; "text" style.
|
|
|
+ (`(,(or "text" "t") . ,(or "caps" "c"))
|
|
|
+ '(:mode textual :capitalize-first t))
|
|
|
+ (`(,(or "text" "t") . ,(or "full" "f"))
|
|
|
+ '(:mode textual :ignore-et-al t))
|
|
|
+ (`(,(or "text" "t") . ,(or "caps-full" "cf"))
|
|
|
+ '(:mode textual :ignore-et-al t :capitalize-first t))
|
|
|
+ (`(,(or "text" "t") . ,_)
|
|
|
+ '(:mode textual))
|
|
|
+ ;; Default "nil" style.
|
|
|
+ (`(,_ . ,(or "bare" "b"))
|
|
|
+ '(:suppress-affixes t))
|
|
|
+ (`(,_ . ,(or "caps" "c"))
|
|
|
+ '(:capitalize-first t))
|
|
|
+ (`(,_ . ,(or "bare-caps" "bc"))
|
|
|
+ '(:suppress-affixes t :capitalize-first t))
|
|
|
+ (`(,_ . ,_) nil)
|
|
|
+ ;; This should not happen.
|
|
|
+ (_ (error "Invalid style: %S" style)))))
|
|
|
|
|
|
(defun org-cite-csl--no-citelinks-p (info)
|
|
|
"Non-nil when export BACKEND should not create cite-reference links."
|
|
@@ -375,8 +406,8 @@ property in INFO."
|
|
|
|
|
|
INFO is the export state, as a property list.
|
|
|
|
|
|
-The result is a association list. Keys are: `id', `suppress-author', `prefix',
|
|
|
-`suffix', `location', `locator' and `label'."
|
|
|
+The result is a association list. Keys are: `id', `prefix',`suffix',
|
|
|
+`location', `locator' and `label'."
|
|
|
(let (label location-start locator-start location locator prefix suffix)
|
|
|
;; Parse suffix. Insert it in a temporary buffer to find
|
|
|
;; different parts: pre-label, label, locator, location (label +
|
|
@@ -434,8 +465,7 @@ The result is a association list. Keys are: `id', `suppress-author', `prefix',
|
|
|
(suffix . ,(funcall export suffix))
|
|
|
(locator . ,locator)
|
|
|
(label . ,label)
|
|
|
- (location . ,location)
|
|
|
- (suppress-author . ,(org-cite-csl--no-author-p reference info))))))
|
|
|
+ (location . ,location)))))
|
|
|
|
|
|
(defun org-cite-csl--create-structure (citation info)
|
|
|
"Create Citeproc structure for CITATION object.
|
|
@@ -465,11 +495,11 @@ INFO is the export state, as a property list."
|
|
|
(org-cite-adjust-note citation info)
|
|
|
(org-cite-wrap-citation citation info))
|
|
|
;; Return structure.
|
|
|
- (citeproc-citation-create
|
|
|
- :note-index (and footnote (org-export-get-footnote-number footnote info))
|
|
|
- :cites cites
|
|
|
- :capitalize-first (or footnote (org-cite-csl--capitalize-p citation info))
|
|
|
- :suppress-affixes (org-cite-csl--no-affixes-p citation info))))
|
|
|
+ (apply #'citeproc-citation-create
|
|
|
+ `(:note-index
|
|
|
+ ,(and footnote (org-export-get-footnote-number footnote info))
|
|
|
+ :cites ,cites
|
|
|
+ ,@(org-cite-csl--create-structure-params citation info)))))
|
|
|
|
|
|
(defun org-cite-csl--rendered-citations (info)
|
|
|
"Return the rendered citations as an association list.
|
|
@@ -578,8 +608,11 @@ property list."
|
|
|
:export-bibliography #'org-cite-csl-render-bibliography
|
|
|
:export-finalizer #'org-cite-csl-finalizer
|
|
|
:cite-styles
|
|
|
- '((("noauthor" "na") ("bare" "b") ("bare-caps" "bc") ("caps" "c"))
|
|
|
- (("nil") ("bare" "b") ("bare-caps" "bc") ("caps" "c"))))
|
|
|
+ '((("author" "a") ("full" "f") ("caps" "c") ("caps-full" "cf"))
|
|
|
+ (("noauthor" "na") ("bare" "b") ("caps" "c") ("bare-caps" "bc"))
|
|
|
+ (("year" "y") ("bare" "b"))
|
|
|
+ (("text" "t") ("caps" "c") ("full" "f") ("caps-full" "cf"))
|
|
|
+ (("nil") ("bare" "b") ("caps" "c") ("bare-caps" "bc"))))
|
|
|
|
|
|
(provide 'oc-csl)
|
|
|
;;; oc-csl.el ends here
|