module IsoDoc::XrefGen module Sections 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(@klass.bibliography_xpath)).each do |b| preface_names(b) end docxml.xpath(ns("//bibitem[not(ancestor::bibitem)]")).each do |ref| reference_names(ref) end end def initial_anchor_names(d) d.xpath(ns("//preface/*")).each { |c| c.element? and preface_names(c) } # potentially overridden in middle_section_asset_names() sequential_asset_names(d.xpath(ns("//preface/*"))) n = section_names(d.at(ns("//clause[@type = 'scope']")), 0, 1) n = section_names(d.at(ns(@klass.norm_ref_xpath)), n, 1) n = section_names(d.at(ns("//sections/terms | "\ "//sections/clause[descendant::terms]")), n, 1) n = section_names(d.at(ns("//sections/definitions")), n, 1) clause_names(d, n) middle_section_asset_names(d) termnote_anchor_names(d) termexample_anchor_names(d) end def preface_clause_name(c) ret = c.at(ns("./title"))&.text || c.name.capitalize ret end SUBCLAUSES = "./clause | ./references | ./term | ./terms | ./definitions".freeze # in StanDoc, prefaces have no numbering; they are referenced only by title def preface_names(clause) return if clause.nil? @anchors[clause["id"]] = { label: nil, level: 1, xref: preface_clause_name(clause), type: "clause" } clause.xpath(ns(SUBCLAUSES)).each_with_index do |c, i| preface_names1(c, c.at(ns("./title"))&.text, "#{preface_clause_name(clause)}, #{i+1}", 2) end end def preface_names1(clause, title, parent_title, level) label = title || parent_title @anchors[clause["id"]] = { label: nil, level: level, xref: label, type: "clause" } clause.xpath(ns(SUBCLAUSES)). each_with_index do |c, i| preface_names1(c, c.at(ns("./title"))&.text, "#{label} #{i+1}", level + 1) end end def middle_section_asset_names(d) middle_sections = "//clause[@type = 'scope'] | "\ "#{@klass.norm_ref_xpath} | "\ "//sections/terms | //preface/* | "\ "//sections/definitions | //clause[parent::sections]" sequential_asset_names(d.xpath(ns(middle_sections))) end def clause_names(docxml, sect_num) docxml.xpath(ns(@klass.middle_clause)).each_with_index do |c, i| section_names(c, (i + sect_num), 1) 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("#{@labels["clause"]} #{num}"), level: lvl, type: "clause" } clause.xpath(ns(SUBCLAUSES)). 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: l10n("#{@labels["clause"]} #{num}"), type: "clause" } clause.xpath(ns(SUBCLAUSES)). each_with_index do |c, i| section_names1(c, "#{num}.#{i + 1}", level + 1) end end def annex_name_lbl(clause, num) obl = l10n("(#{@labels["inform_annex"]})") obl = l10n("(#{@labels["norm_annex"]})") if clause["obligation"] == "normative" l10n("#{@labels["annex"]} #{num}
#{obl}") end def single_annex_special_section(clause) a = clause.xpath(ns("./references | ./terms | ./definitions")) a.size == 1 or return nil clause.xpath(ns("./clause | ./p | ./table | ./ol | ./ul | ./dl | "\ "./note | ./admonition | ./figure")).size == 0 or return nil a[0] end def annex_names(clause, num) @anchors[clause["id"]] = { label: annex_name_lbl(clause, num), type: "clause", xref: "#{@labels["annex"]} #{num}", level: 1 } if a = single_annex_special_section(clause) annex_names1(a, "#{num}", 1) else clause.xpath(ns(SUBCLAUSES)).each_with_index do |c, i| annex_names1(c, "#{num}.#{i + 1}", 2) end end hierarchical_asset_names(clause, num) end def annex_names1(clause, num, level) @anchors[clause["id"]] = { label: num, xref: "#{@labels["annex"]} #{num}", level: level, type: "clause" } clause.xpath(ns(SUBCLAUSES)).each_with_index do |c, i| annex_names1(c, "#{num}.#{i + 1}", level + 1) end end 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 def reference_names(ref) isopub = ref.at(ns(ISO_PUBLISHER_XPATH)) ids = @klass.bibitem_ref_code(ref) identifiers = @klass.render_identifier(ids) date = ref.at(ns("./date[@type = 'published']")) reference = @klass.docid_l10n(identifiers[0] || identifiers[1]) @anchors[ref["id"]] = { xref: reference } end end end