/usr/share/refdb/dsssl/citations.dsl is in refdb-clients 1.0.2-3ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 | <!DOCTYPE style-sheet PUBLIC "-//James Clark//DTD DSSSL Style Sheet//EN">
<style-sheet>
<style-specification>
<style-specification-body>
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; This file is part of refdb
;; Markus Hoenicka 001124
;; markus@mhoenicka.de
;; $Id: citations.dsl,v 1.8 2004/03/19 23:23:11 mhoenicka Exp $
;;
;;
;;; The purpose of this stylesheet is to extract a list of the contents of
;;; all citation elements in the text. The latter are "citation" in DocBook
;;; and 'seg type="REFDBCITATION"' in TEI. The result will be an XML file
;;; containing the CITATION elements and their XREF children
;;; NB it is possible to add code for further document types to this file
;;; as long as no top-level element names overlap
;
;;; Processing: jade -t xml -d citations.dsl [sgml-declaration] infile > outfile
(declare-flow-object-class element
"UNREGISTERED::James Clark//Flow Object Class::element")
(declare-flow-object-class processing-instruction
"UNREGISTERED::James Clark//Flow Object Class::processing-instruction")
(declare-flow-object-class document-type
"UNREGISTERED::James Clark//Flow Object Class::document-type")
;; start user-customizable section
;; the path to the citationlistx dtd
;;(define SYSTEMCITID "/usr/local/lib/sgml/dtd/citationlistx.dtd")
(define SYSTEMCITID "http://refdb.sourceforge.net/dtd/citationlistx.dtd")
;; end user-customizable section
(define PUBLICCITID "-//Markus Hoenicka//DTD CitationList//EN")
;*****************************************************************
; DocBook
;*****************************************************************
(element book
(make sequence
(make processing-instruction
data: "xml version=\"1.0\" standalone=\"no\"")
; this doctype line will not be well-formed in both jade and openjade and
; thus needs post-processing
(make document-type
name: "CITATIONLIST"
public-id: PUBLICCITID
system-id: SYSTEMCITID)
(make element
gi: "CITATIONLIST"
(process-node-list (select-elements (descendants (current-node)) (normalize "citation"))))))
(element article
(make sequence
(make processing-instruction
data: "xml version=\"1.0\" standalone=\"no\"")
(make document-type
name: "CITATIONLIST"
public-id: PUBLICCITID
system-id: SYSTEMCITID)
(make element
gi: "CITATIONLIST"
(process-node-list (select-elements (descendants (current-node)) (normalize "citation"))))))
(element citation
(if (equal? (normalize (attribute-string (normalize "role"))) "REFDB")
(make sequence
(make element
gi: "CITATION"
(process-node-list (select-elements (children (current-node)) (normalize "xref")))))
(empty-sosofo)))
(element xref
(make sequence
(if (attribute-string (normalize "ENDTERM"))
(make element
gi: "XREF"
attributes: (list (list "ENDTERM" (attribute-string (normalize "endterm"))))
(literal (strip-refdb-suffix (attribute-string (normalize "linkend")))))
(make element
gi: "XREF"
(literal (strip-refdb-suffix (attribute-string (normalize "linkend"))))))))
;*****************************************************************
; TEI
;*****************************************************************
(element TEI.2
(make sequence
(make processing-instruction
data: "xml version=\"1.0\" standalone=\"no\"")
(make document-type
name: "CITATIONLIST"
public-id: PUBLICCITID
system-id: SYSTEMCITID)
(make element
gi: "CITATIONLIST"
(process-node-list (select-elements (descendants (current-node)) (normalize "seg"))))))
(element seg
(if (equal? (attribute-string (normalize "type")) "REFDBCITATION")
(make sequence
(make element
gi: "CITATION"
(process-node-list (select-elements (children (current-node)) (normalize "ptr")))))
(empty-sosofo)))
(element ptr
(make sequence
(if (equal? (normalize (attribute-string (normalize "type"))) "MULTIXREF")
(make element
gi: "XREF"
attributes: (list (list "ENDTERM" (attribute-string (normalize "target"))))
(literal (strip-refdb-suffix (attribute-string (normalize "target") (node-list-first (follow (current-node)))))))
(make element
gi: "XREF"
(literal (strip-refdb-suffix (attribute-string (normalize "target"))))))))
;*****************************************************************
; library stuff
;*****************************************************************
(define (normalize str)
;; REFENTRY normalize
;; PURP Normalize the str according to the SGML declaration in effect
;; DESC
;; Performs SGML general name normalization on the string;
;; used to compare attribute names and generic identifiers correctly
;; according to the SGML declaration in effect; this is necessary
;; since XML is case-sensitive but the reference concrete syntax and
;; many SGML DTDs are not.
;; /DESC
;; AUTHOR Chris Maden
;; /REFENTRY
(if (string? str)
(general-name-normalize str
(current-node))
str))
(define (strip-refdb-suffix str)
;; REFENTRY strip-refdb-suffix
;; PURP strips off trailing link type specifier and separator in ID
;; DESC
;; RefDB citations use ID values in the formats "IDnumerical_id:X"
;; or "IDalphanumeric_citekey:X where ID is the invariant part,
;; followed by a number or a citekey of unlimited length, which is
;; followed by a separator and an one-char specifier for the text
;; which is to be rendered with the link. Stripping off
;; this specifier simplifies downstream processing
;; /DESC
;; AUTHOR Markus Hoenicka
;; /REFENTRY
(let ((strlen (string-length str)))
(if (equal? (substring str (- strlen 2) (- strlen 1)) "-")
(substring str 0 (- strlen 2))
str)))
</style-specification-body>
</style-specification>
</style-sheet>
|