module IsoDoc
module Iso
class Counter < IsoDoc::XrefGen::Counter
end
class Xref < IsoDoc::Xref
def initial_anchor_names(doc)
if @klass.amd(doc)
initial_anchor_names_amd(doc)
else
initial_anchor_names1(doc)
end
if @parse_settings.empty? || @parse_settings[:clauses]
introduction_names(doc.at(ns("//introduction")))
end
end
def initial_anchor_names_amd(doc)
if @parse_settings.empty? || @parse_settings[:clauses]
doc.xpath(ns("//preface/*")).each do |c|
c.element? and preface_names(c)
end
doc.xpath(ns("//sections/clause")).each do |c|
c.element? and preface_names(c)
end
end
if @parse_settings.empty?
sequential_asset_names(doc.xpath(ns("//preface/*")))
middle_section_asset_names(doc)
termnote_anchor_names(doc)
termexample_anchor_names(doc)
end
end
def initial_anchor_names1(doc)
if @parse_settings.empty? || @parse_settings[:clauses]
doc.xpath(ns("//preface/*")).each do |c|
c.element? and preface_names(c)
end
# potentially overridden in middle_section_asset_names()
sequential_asset_names(doc.xpath(ns("//preface/*")))
n = Counter.new
n = section_names(doc.at(ns("//clause[@type = 'scope']")), n, 1)
n = section_names(doc.at(ns(@klass.norm_ref_xpath)), n, 1)
doc.xpath(ns("//sections/clause[not(@type = 'scope')] | "\
"//sections/terms | //sections/definitions")).each do |c|
n = section_names(c, n, 1)
end
end
if @parse_settings.empty?
middle_section_asset_names(doc)
termnote_anchor_names(doc)
termexample_anchor_names(doc)
end
end
# we can reference 0-number clauses in introduction
def introduction_names(clause)
return if clause.nil?
clause.at(ns("./clause")) and
@anchors[clause["id"]] = { label: "0", level: 1, type: "clause",
xref: clause.at(ns("./title"))&.text }
i = Counter.new
clause.xpath(ns("./clause")).each do |c|
i.increment(c)
section_names1(c, "0.#{i.print}", 2)
end
end
def annex_names(clause, num)
appendix_names(clause, num)
super
end
def appendix_names(clause, _num)
i = Counter.new
clause.xpath(ns("./appendix")).each do |c|
i.increment(c)
@anchors[c["id"]] =
anchor_struct(i.print, nil, @labels["appendix"],
"clause").merge(level: 2, subtype: "annex",
container: clause["id"])
j = Counter.new
c.xpath(ns("./clause | ./references")).each do |c1|
j.increment(c1)
lbl = "#{@labels['appendix']} #{i.print}.#{j.print}"
appendix_names1(c1, l10n(lbl), 3, clause["id"])
end
end
end
# subclauses are not prefixed with "Clause"
# retaining subtype for the semantics
def section_names1(clause, num, level)
@anchors[clause["id"]] =
{ label: num, level: level, xref: num, subtype: "clause" }
i = Counter.new
clause.xpath(ns("./clause | ./terms | ./term | ./definitions | "\
"./references"))
.each do |c|
i.increment(c)
section_names1(c, "#{num}.#{i.print}", level + 1)
end
end
def annex_names1(clause, num, level)
@anchors[clause["id"]] = { label: num, xref: num, level: level,
subtype: "annex" }
i = Counter.new
clause.xpath(ns("./clause | ./references")).each do |c|
i.increment(c)
annex_names1(c, "#{num}.#{i.print}", level + 1)
end
end
def appendix_names1(clause, num, level, container)
@anchors[clause["id"]] = { label: num, xref: num, level: level,
container: container }
i = Counter.new
clause.xpath(ns("./clause | ./references")).each do |c|
i.increment(c)
appendix_names1(c, "#{num}.#{i.print}", level + 1, container)
end
end
def hierarchical_formula_names(clause, num)
c = IsoDoc::XrefGen::Counter.new
clause.xpath(ns(".//formula")).each do |t|
next if blank?(t["id"])
@anchors[t["id"]] = anchor_struct(
"#{num}#{hiersep}#{c.increment(t).print}", t,
t["inequality"] ? @labels["inequality"] : @labels["formula"],
"formula", t["unnumbered"]
)
end
end
def figure_anchor(elem, sublabel, label)
@anchors[elem["id"]] = anchor_struct(
(sublabel ? "#{label} #{sublabel}" : label),
nil, @labels["figure"], "figure", elem["unnumbered"]
)
sublabel && elem["unnumbered"] != "true" and
@anchors[elem["id"]][:label] = sublabel
end
def sequential_figure_names(clause)
j = 0
clause.xpath(ns(".//figure | .//sourcecode[not(ancestor::example)]"))
.each_with_object(IsoDoc::XrefGen::Counter.new) do |t, c|
j = subfigure_increment(j, c, t)
sublabel = j.zero? ? nil : "#{(j + 96).chr})"
next if blank?(t["id"])
figure_anchor(t, sublabel, c.print)
end
end
def hierarchical_figure_names(clause, num)
c = IsoDoc::XrefGen::Counter.new
j = 0
clause.xpath(ns(".//figure | .//sourcecode[not(ancestor::example)]"))
.each do |t|
j = subfigure_increment(j, c, t)
label = "#{num}#{hiersep}#{c.print}"
sublabel = j.zero? ? nil : "#{(j + 96).chr})"
next if blank?(t["id"])
figure_anchor(t, sublabel, label)
end
end
def reference_names(ref)
super
@anchors[ref["id"]] = { xref: @anchors[ref["id"]][:xref]
.sub(/ \(All Parts\)/i, "") }
end
def back_anchor_names(docxml)
super
if @parse_settings.empty? || @parse_settings[:clauses]
docxml.xpath(ns("//indexsect")).each { |b| preface_names(b) }
end
end
def annex_name_lbl(clause, num)
super.sub(%r{
(.*)$}, "
\\1")
end
def list_anchor_names(sections)
sections.each do |s|
notes = s.xpath(ns(".//ol")) - s.xpath(ns(".//clause//ol")) -
s.xpath(ns(".//appendix//ol")) - s.xpath(ns(".//ol//ol"))
c = Counter.new
notes.reject { |n| blank?(n["id"]) }.each do |n|
@anchors[n["id"]] = anchor_struct(increment_label(notes, n, c), n,
@labels["list"], "list", false)
list_item_anchor_names(n, @anchors[n["id"]], 1, "",
!single_ol_for_xrefs?(notes))
end
list_anchor_names(s.xpath(ns(CHILD_SECTIONS)))
end
end
# all li in the ol in lists are consecutively numbered through @start
def single_ol_for_xrefs?(lists)
return true if lists.size == 1
start = 0
lists.each_with_index do |l, i|
next if i.zero?
start += lists[i - 1].xpath(ns("./li")).size
return false unless l["start"]&.to_i == start + 1
end
true
end
end
end
end