Module: IsoDoc::Function::References
- Included in:
- Common
- Defined in:
- lib/isodoc/function/references.rb
Constant Summary collapse
- ISO_PUBLISHER_XPATH =
"./contributor[xmlns:role/@type = 'publisher']/"\ "organization[abbreviation = 'ISO' or xmlns:abbreviation = 'IEC' or "\ "xmlns:name = 'International Organization for Standardization' or "\ "xmlns:name = 'International Electrotechnical Commission']".freeze
- BIBLIOGRAPHY_XPATH =
"//bibliography/clause[title = 'Bibliography'] | "\ "//bibliography/references[title = 'Bibliography']".freeze
Instance Method Summary collapse
- #bibitem_ref_code(b) ⇒ Object
- #biblio_list(f, div, bibliography) ⇒ Object
- #bibliography(isoxml, out) ⇒ Object
- #bibliography_parse(node, out) ⇒ Object
- #date_note_process(b, ref) ⇒ Object
-
#docid_l10n(x) ⇒ Object
This is highly specific to ISO, but it’s not a bad precedent for references anyway; keeping here instead of in IsoDoc::Iso for now.
- #docid_prefix(prefix, docid) ⇒ Object
- #format_ref(ref, prefix, isopub, date, allparts) ⇒ Object
-
#implicit_reference(b) ⇒ Object
reference not to be rendered because it is deemed implicit in the standards environment.
- #is_standard(b) ⇒ Object
- #iso_bibitem_entry_attrs(b, biblio) ⇒ Object
- #iso_title(b) ⇒ Object
-
#nonstd_bibitem(list, b, ordinal, bibliography) ⇒ Object
TODO generate formatted ref if not present.
- #norm_ref(isoxml, out, num) ⇒ Object
- #norm_ref_preface(f, div) ⇒ Object
- #omit_docid_prefix(prefix) ⇒ Object
- #prefix_bracketed_ref(ref, text) ⇒ Object
-
#ref_entry_code(r, ordinal, t) ⇒ Object
if t is just a number, only use that ([1] Non-Standard) else, use both ordinal, as prefix, and t.
- #reference_format(b, r) ⇒ Object
- #reference_names(ref) ⇒ Object
- #std_bibitem_entry(list, b, ordinal, biblio) ⇒ Object
Instance Method Details
#bibitem_ref_code(b) ⇒ Object
45 46 47 48 49 50 |
# File 'lib/isodoc/function/references.rb', line 45 def bibitem_ref_code(b) id = b.at(ns("./docidentifier[not(@type = 'DOI' or @type = 'metanorma')]")) id ||= b.at(ns("./docidentifier[not(@type = 'DOI')]")) id ||= b.at(ns("./docidentifier")) or return "(NO ID)" docid_prefix(id["type"], id.text.sub(/^\[/, "").sub(/\]$/, "")) end |
#biblio_list(f, div, bibliography) ⇒ Object
119 120 121 122 123 124 125 126 127 128 |
# File 'lib/isodoc/function/references.rb', line 119 def biblio_list(f, div, bibliography) f.xpath(ns("./bibitem")).each_with_index do |b, i| next if implicit_reference(b) if(is_standard(b)) std_bibitem_entry(div, b, i + 1, bibliography) else nonstd_bibitem(div, b, i + 1, bibliography) end end end |
#bibliography(isoxml, out) ⇒ Object
155 156 157 158 159 160 161 162 163 164 165 |
# File 'lib/isodoc/function/references.rb', line 155 def bibliography(isoxml, out) f = isoxml.at(ns(BIBLIOGRAPHY_XPATH)) || return page_break(out) out.div do |div| div.h1 @bibliography_lbl, **{ class: "Section3" } f.elements.reject do |e| ["reference", "title", "bibitem"].include? e.name end.each { |e| parse(e, div) } biblio_list(f, div, true) end end |
#bibliography_parse(node, out) ⇒ Object
167 168 169 170 171 172 173 174 175 176 |
# File 'lib/isodoc/function/references.rb', line 167 def bibliography_parse(node, out) title = node&.at(ns("./title"))&.text || "" out.div do |div| div.h2 title, **{ class: "Section3" } node.elements.reject do |e| ["reference", "title", "bibitem"].include? e.name end.each { |e| parse(e, div) } biblio_list(node, div, true) end end |
#date_note_process(b, ref) ⇒ Object
62 63 64 65 66 67 68 |
# File 'lib/isodoc/function/references.rb', line 62 def date_note_process(b, ref) date_note = b.at(ns("./note[text()][contains(.,'ISO DATE:')]")) return if date_note.nil? date_note.content = date_note.content.gsub(/ISO DATE: /, "") date_note.children.first.replace("<p>#{date_note.content}</p>") footnote_parse(date_note, ref) end |
#docid_l10n(x) ⇒ Object
This is highly specific to ISO, but it’s not a bad precedent for references anyway; keeping here instead of in IsoDoc::Iso for now
6 7 8 9 |
# File 'lib/isodoc/function/references.rb', line 6 def docid_l10n(x) return x if x.nil? x.gsub(/All Parts/i, @all_parts_lbl.downcase) end |
#docid_prefix(prefix, docid) ⇒ Object
52 53 54 55 |
# File 'lib/isodoc/function/references.rb', line 52 def docid_prefix(prefix, docid) docid = "#{prefix} #{docid}" if prefix && !omit_docid_prefix(prefix) docid_l10n(docid) end |
#format_ref(ref, prefix, isopub, date, allparts) ⇒ Object
178 179 180 181 182 183 184 185 186 187 188 189 190 |
# File 'lib/isodoc/function/references.rb', line 178 def format_ref(ref, prefix, isopub, date, allparts) if isopub #if date #on = date.at(ns("./on")) #ref += on&.text == "--" ? ":--" : "" # ":#{date_range(date)}" #ref += " (all parts)" if allparts # ref = docid_prefix(prefix, ref) #end end ref = docid_prefix(prefix, ref) return "[#{ref}]" if /^\d+$/.match(ref) && !prefix && !/^\[.*\]$/.match(ref) ref end |
#implicit_reference(b) ⇒ Object
reference not to be rendered because it is deemed implicit in the standards environment
84 85 86 |
# File 'lib/isodoc/function/references.rb', line 84 def implicit_reference(b) false end |
#is_standard(b) ⇒ Object
110 111 112 113 114 115 116 117 |
# File 'lib/isodoc/function/references.rb', line 110 def is_standard(b) ret = false b.xpath(ns("./docidentifier")).each do |id| next if id["type"].nil? || %w(metanorma DOI).include?(id["type"]) ret = true end ret end |
#iso_bibitem_entry_attrs(b, biblio) ⇒ Object
70 71 72 |
# File 'lib/isodoc/function/references.rb', line 70 def iso_bibitem_entry_attrs(b, biblio) { id: b["id"], class: biblio ? "Biblio" : "NormRef" } end |
#iso_title(b) ⇒ Object
74 75 76 77 78 79 80 |
# File 'lib/isodoc/function/references.rb', line 74 def iso_title(b) title = b.at(ns("./title[@language = '#{@lang}' and @type = 'main']")) || b.at(ns("./title[@language = '#{@lang}']")) || b.at(ns("./title[@type = 'main']")) || b.at(ns("./title")) title end |
#nonstd_bibitem(list, b, ordinal, bibliography) ⇒ Object
TODO generate formatted ref if not present
12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/isodoc/function/references.rb', line 12 def nonstd_bibitem(list, b, ordinal, bibliography) list.p **attr_code(iso_bibitem_entry_attrs(b, bibliography)) do |r| id = bibitem_ref_code(b) if bibliography ref_entry_code(r, ordinal, id) else r << "#{id}, " end reference_format(b, r) end end |
#norm_ref(isoxml, out, num) ⇒ Object
138 139 140 141 142 143 144 145 146 147 148 149 |
# File 'lib/isodoc/function/references.rb', line 138 def norm_ref(isoxml, out, num) q = "//bibliography/references[title = 'Normative References' or "\ "title = 'Normative references']" f = isoxml.at(ns(q)) or return num out.div do |div| num = num + 1 clause_name(num, @normref_lbl, div, nil) norm_ref_preface(f, div) biblio_list(f, div, false) end num end |
#norm_ref_preface(f, div) ⇒ Object
130 131 132 133 134 135 136 |
# File 'lib/isodoc/function/references.rb', line 130 def norm_ref_preface(f, div) refs = f.elements.select do |e| ["reference", "bibitem"].include? e.name end pref = refs.empty? ? @norm_empty_pref : @norm_with_refs_pref div.p pref end |
#omit_docid_prefix(prefix) ⇒ Object
57 58 59 60 |
# File 'lib/isodoc/function/references.rb', line 57 def omit_docid_prefix(prefix) return true if prefix.nil? || prefix.empty? return ["ISO", "IEC", "metanorma"].include? prefix end |
#prefix_bracketed_ref(ref, text) ⇒ Object
88 89 90 91 |
# File 'lib/isodoc/function/references.rb', line 88 def prefix_bracketed_ref(ref, text) ref << "[#{text}]" insert_tab(ref, 1) end |
#ref_entry_code(r, ordinal, t) ⇒ Object
if t is just a number, only use that ([1] Non-Standard) else, use both ordinal, as prefix, and t
36 37 38 39 40 41 42 43 |
# File 'lib/isodoc/function/references.rb', line 36 def ref_entry_code(r, ordinal, t) if /^\d+$/.match(t) prefix_bracketed_ref(r, t) else prefix_bracketed_ref(r, ordinal) r << "#{t}, " end end |
#reference_format(b, r) ⇒ Object
93 94 95 96 97 98 99 100 101 102 |
# File 'lib/isodoc/function/references.rb', line 93 def reference_format(b, r) if ftitle = b.at(ns("./formattedref")) ftitle&.children&.each { |n| parse(n, r) } else title = iso_title(b) r.i do |i| title&.children&.each { |n| parse(n, i) } end end end |
#reference_names(ref) ⇒ Object
192 193 194 195 196 197 198 199 200 201 |
# File 'lib/isodoc/function/references.rb', line 192 def reference_names(ref) isopub = ref.at(ns(ISO_PUBLISHER_XPATH)) docid = ref.at(ns("./docidentifier")) prefix = ref.at(ns("./docidentifier/@type")) # return ref_names(ref) unless docid date = ref.at(ns("./date[@type = 'published']")) allparts = ref.at(ns("./extent[@type='part'][referenceFrom='all']")) reference = format_ref(docid_l10n(docid.text), prefix&.text, isopub, date, allparts) @anchors[ref["id"]] = { xref: reference } end |
#std_bibitem_entry(list, b, ordinal, biblio) ⇒ Object
24 25 26 27 28 29 30 31 32 |
# File 'lib/isodoc/function/references.rb', line 24 def std_bibitem_entry(list, b, ordinal, biblio) list.p **attr_code(iso_bibitem_entry_attrs(b, biblio)) do |ref| prefix_bracketed_ref(ref, ordinal) if biblio ref << bibitem_ref_code(b) date_note_process(b, ref) ref << ", " reference_format(b, ref) end end |