module IsoDoc::Function
module XrefSectGen
def back_anchor_names(docxml)
docxml.xpath(ns("//annex")).each_with_index do |c, i|
annex_names(c, (65 + i).chr.to_s)
end
docxml.xpath(ns("//bibitem[not(ancestor::bibitem)]")).each do |ref|
reference_names(ref)
end
end
def initial_anchor_names(d)
introduction_names(d.at(ns("//introduction")))
n = 0
n = section_names(d.at(ns("//clause[title = 'Scope']")), n, 1)
n = section_names(d.at(ns(
"//references[title = 'Normative References' or title = 'Normative references']")), n, 1)
n = section_names(d.at(ns("//sections/terms | "\
"//sections/clause[descendant::terms]")), n, 1)
n = section_names(d.at(ns("//sections/symbols-abbrevs")), n, 1)
middle_section_asset_names(d)
clause_names(d, n)
termnote_anchor_names(d)
termexample_anchor_names(d)
end
def middle_section_asset_names(d)
middle_sections = "//clause[title = 'Scope'] | "\
"//foreword | //introduction | "\
"//references[title = 'Normative References' or title = 'Normative references'] | "\
"//sections/terms | "\
"//sections/symbols-abbrevs | //clause[parent::sections]"
sequential_asset_names(d.xpath(ns(middle_sections)))
end
def clause_names(docxml, sect_num)
q = "//clause[parent::sections][not(xmlns:title = 'Scope')]"\
"[not(descendant::terms)]"
docxml.xpath(ns(q)).each_with_index do |c, i|
section_names(c, (i + sect_num), 1)
end
end
def introduction_names(clause)
return if clause.nil?
clause.xpath(ns("./clause")).each_with_index do |c, i|
section_names1(c, "0.#{i + 1}", 2)
end
end
def section_names(clause, num, lvl)
return num if clause.nil?
num = num + 1
@anchors[clause["id"]] =
{ label: num.to_s, xref: l10n("#{@clause_lbl} #{num}"), level: lvl }
clause.xpath(ns("./clause | ./term | ./terms | ./symbols-abbrevs")).
each_with_index do |c, i|
section_names1(c, "#{num}.#{i + 1}", lvl + 1)
end
num
end
def section_names1(clause, num, level)
@anchors[clause["id"]] =
{ label: num, level: level, xref: num }
# subclauses are not prefixed with "Clause"
clause.xpath(ns("./clause | ./terms | ./term | ./symbols-abbrevs")).
each_with_index do |c, i|
section_names1(c, "#{num}.#{i + 1}", level + 1)
end
end
def annex_name_lbl(clause, num)
obl = l10n("(#{@inform_annex_lbl})")
obl = l10n("(#{@norm_annex_lbl})") if clause["obligation"] == "normative"
l10n("#{@annex_lbl} #{num}
#{obl}")
end
def annex_names(clause, num)
@anchors[clause["id"]] = { label: annex_name_lbl(clause, num),
xref: "#{@annex_lbl} #{num}", level: 1 }
clause.xpath(ns("./clause")).each_with_index do |c, i|
annex_names1(c, "#{num}.#{i + 1}", 2)
end
appendix_names(clause, num)
hierarchical_asset_names(clause, num)
end
def annex_names1(clause, num, level)
@anchors[clause["id"]] = { label: num, xref: num, level: level }
clause.xpath(ns(".//clause")).each_with_index do |c, i|
annex_names1(c, "#{num}.#{i + 1}", level + 1)
end
end
def appendix_names(clause, num)
clause.xpath(ns("./appendix")).each_with_index do |c, i|
@anchors[c["id"]] = anchor_struct(i + 1, nil, @appendix_lbl)
@anchors[c["id"]][:level] = 2
@anchors[c["id"]][:container] = clause["id"]
end
end
end
end