Class: Coradoc::CoreModel::AttributeReferenceResolver

Inherits:
Object
  • Object
show all
Defined in:
lib/coradoc/core_model/attribute_reference_resolver.rb

Overview

Walks a CoreModel tree and resolves InlineElement nodes whose format_type is ‘attribute_reference’ against a Metadata store.

AsciiDoc ‘foo` references round-trip as InlineElement with format_type: ’attribute_reference’ and target: ‘foo’. After the document is parsed and its attributes are known, this visitor rewrites those nodes in place to TextContent carrying the value. Unresolved references are left untouched so they survive serialisation back to the source format.

The visitor never mutates its input tree; it returns a new tree sharing unchanged subtrees. InlineElement#with_content already produces non-mutating copies for inline content; the same pattern is used here at the block level via ‘replace_children`.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(attributes) ⇒ AttributeReferenceResolver

Returns a new instance of AttributeReferenceResolver.



26
27
28
# File 'lib/coradoc/core_model/attribute_reference_resolver.rb', line 26

def initialize(attributes)
  @attributes = attributes || Metadata.new
end

Instance Attribute Details

#attributesObject (readonly)

Returns the value of attribute attributes.



20
21
22
# File 'lib/coradoc/core_model/attribute_reference_resolver.rb', line 20

def attributes
  @attributes
end

Class Method Details

.call(root, attributes) ⇒ Object



22
23
24
# File 'lib/coradoc/core_model/attribute_reference_resolver.rb', line 22

def self.call(root, attributes)
  new(attributes).visit(root)
end

Instance Method Details

#visit(node) ⇒ Object



30
31
32
33
34
35
36
# File 'lib/coradoc/core_model/attribute_reference_resolver.rb', line 30

def visit(node)
  return node.map { |child| visit(child) } if node.is_a?(Array)

  return node unless node.is_a?(Base)

  visit_typed(node)
end