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

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