class Asciidoctor::AbstractNode
all content segments in an AsciiDoc document.
node of AsciiDoc content. The state and methods on this class are comment to
Public: An abstract base class that provides state and methods for managing a
def attr(name, default = nil, inherit = true)
return the value of the attribute or the default value if the attribute
AsciiDoctor::Document if not found on this node (default: false)
inherit - a Boolean indicating whether to check for the attribute on the
default - the Object value to return if the attribute is not found (default: nil)
name - the String or Symbol name of the attribute to lookup
return the default value, which defaults to nil.
Document node and return the value of the attribute if found. Otherwise,
this node is a child of the Document node, look in the attributes of the
this node and return the value of the attribute if found. Otherwise, if
Get the value for the specified attribute. First look in the attributes on
Public: Get the value of the specified attribute
def attr(name, default = nil, inherit = true) name = name.to_s if name.is_a?(Symbol) inherit = false if self == @document if !inherit default.nil? ? @attributes[name] : @attributes.fetch(name, default) else default.nil? ? @attributes.fetch(name, @document.attr(name)) : @attributes.fetch(name, @document.attr(name, default)) end end
def attr?(name, expect = nil, inherit = true)
comparison value is specified, whether the value of the attribute matches
return a Boolean indicating whether the attribute exists and, if a
AsciiDoctor::Document if not found on this node (default: false)
inherit - a Boolean indicating whether to check for the attribute on the
expect - the expected Object value of the attribute (default: nil)
name - the String or Symbol name of the attribute to lookup
Otherwise, return whether the attribute was found.
comparison value is specified (not nil), return whether the two values match.
the attributes of the Document node. If the attribute is found and a
node. If not found, and this node is a child of the Document node, look in
Check if the attribute is defined. First look in the attributes on this
comparison of its value if expected is not nil
Public: Check if the attribute is defined, optionally performing a
def attr?(name, expect = nil, inherit = true) name = name.to_s if name.is_a?(Symbol) inherit = false if self == @document if expect.nil? if @attributes.has_key? name true elsif inherit @document.attributes.has_key? name else false end else if @attributes.has_key? name @attributes[name] == expect elsif inherit && @document.attributes.has_key?(name) @document.attributes[name] == expect else false end end end
def generate_data_uri(target_image, asset_dir_key = nil)
the image is located (default: nil)
asset_dir_key - The String attribute key used to lookup the directory where
target_image - A String path to the target image
Base64. Finally, a data URI is built which can be used in an image tag.
to ancestor paths in the filesystem. The image data is then read and converted to
is set to at least SafeMode::SAFE (a condition which is true by default) to prevent access
First, and foremost, the target image path is cleaned if the document safe mode level
Public: Generate a data URI that can be used to embed an image in the output document
def generate_data_uri(target_image, asset_dir_key = nil) Helpers.require_library 'base64' ext = File.extname(target_image)[1..-1] mimetype = 'image/' + ext mimetype = "#{mimetype}+xml" if ext == 'svg' if asset_dir_key #asset_dir_path = normalize_system_path(@document.attr(asset_dir_key), nil, nil, :target_name => asset_dir_key) #image_path = normalize_system_path(target_image, asset_dir_path, nil, :target_name => 'image') image_path = normalize_system_path(target_image, @document.attr(asset_dir_key), nil, :target_name => 'image') else image_path = normalize_system_path(target_image) end if !File.readable? image_path puts "asciidoctor: WARNING: image to embed not found or not readable: #{image_path}" return "data:#{mimetype}:base64," #return '' end bindata = nil if IO.respond_to? :binread bindata = IO.binread(image_path) else bindata = File.open(image_path, 'rb') {|file| file.read } end "data:#{mimetype};base64,#{Base64.encode64(bindata).delete("\n")}" end
def get_binding template
the backend template and binds the method arguments as local variables in
returns the execution context for this object so it can be be transferred to
Bound to the local variable of the same name, template.
template - The BaseTemplate instance in which this binding will be active.
method are also available in the execution environment.
reference in an evaluation context. Any arguments passed to this
Each object in Ruby has a binding context that can be used to set the 'self'
template.
that map to this method's arguments during the evaluation of a backend
This method is used to set the 'self' reference as well as local variables
Public: Get the execution context of this object (via Kernel#binding).
def get_binding template binding end
def icon_uri(name)
name - The String name of the icon
The return value of this method can be safely used in an image tag.
safely converted to a data URI.
the 'data-uri' attribute is set on the document, the image will be
The target image path is then passed through the #image_uri() method. If
(defaulting to 'png').
attribute, the icon name and the value of the 'icontype' attribute
construct a target image path by concatenating the value of the 'iconsdir'
value of this attribute is used as the target image path. Otherwise,
If the 'icon' attribute is set on this block, the name is ignored and the
specified icon name.
Public: Construct a reference or data URI to an icon image for the
def icon_uri(name) if attr? 'icon' image_uri(attr('icon'), nil) else image_uri("#{name}.#{@document.attr('icontype', 'png')}", 'iconsdir') end end
def image_uri(target_image, asset_dir_key = 'imagesdir')
the image is located (default: 'imagesdir')
asset_dir_key - The String attribute key used to lookup the directory where
target_image - A String path to the target image
The return value of this method can be safely used in an image tag.
are satisfied, a relative path (i.e., URL) will be returned.
by reading it from the same directory. If neither of these conditions
is less than SafeMode::SECURE, the image will be safely converted to a data URI
If the 'data-uri' attribute is set on the document, and the safe mode level
specified attribute key, if provided.
The target image is resolved relative to the directory retrieved from the
If the target image is a URI reference, then leave it untouched.
Public: Construct a URI reference or data URI to the target image.
def image_uri(target_image, asset_dir_key = 'imagesdir') if target_image.include?(':') && target_image.match(Asciidoctor::REGEXP[:uri_sniff]) target_image elsif @document.safe < Asciidoctor::SafeMode::SECURE && @document.attr?('data-uri') generate_data_uri(target_image, asset_dir_key) elsif asset_dir_key && attr?(asset_dir_key) normalize_web_path(target_image, @document.attr(asset_dir_key)) else normalize_web_path(target_image) end end
def initialize(parent, context)
def initialize(parent, context) @parent = (context != :document ? parent : nil) if !parent.nil? @document = parent.is_a?(Document) ? parent : parent.document else @document = nil end @context = context @attributes = {} @passthroughs = [] end
def media_uri(target, asset_dir_key = 'imagesdir')
the media is located (default: 'imagesdir')
asset_dir_key - The String attribute key used to lookup the directory where
target - A String reference to the target media
The return value can be safely used in a media tag (img, audio, video).
specified attribute key, if provided.
The target media is resolved relative to the directory retrieved from the
If the target media is a URI reference, then leave it untouched.
Public: Construct a URI reference to the target media.
def media_uri(target, asset_dir_key = 'imagesdir') if target.include?(':') && target.match(Asciidoctor::REGEXP[:uri_sniff]) target elsif asset_dir_key && attr?(asset_dir_key) normalize_web_path(target, @document.attr(asset_dir_key)) else normalize_web_path(target) end end
def normalize_asset_path(asset_ref, asset_name = 'path', autocorrect = true)
Delegates to normalize_system_path, with the start path set to the value of
Public: Normalize the asset file or directory to a concrete and rinsed path
def normalize_asset_path(asset_ref, asset_name = 'path', autocorrect = true) normalize_system_path(asset_ref, @document.base_dir, nil, :target_name => asset_name, :recover => autocorrect) end
def normalize_system_path(target, start = nil, jail = nil, opts = {})
parent references resolved and self references removed. If a jail is provided,
returns a String path resolved from the start and target paths, with any
outside the jail.
raises a SecurityError if a jail is specified and the resolved path is
* :target_name is used in messages to refer to the path being resolved
when an illegal path is encountered
* :recover is used to control whether the processor should auto-recover
opts - an optional Hash of options to control processing (default: {}):
jail - the String jail path to confine the resolved path
start - the String start (i.e., parent) path
target - the String target path
by default).
safe level is set to SafeMode::SAFE or greater (a condition which is true
file, stored in the base_dir instance variable on Document) if the document
path outside of the jail (which defaults to the directory of the source
The most important functionality in this method is to prevent resolving a
See PathResolver::system_path(target, start, jail, opts) for details.
using the PathResolver.
Public: Resolve and normalize a secure path from the target and start paths
def normalize_system_path(target, start = nil, jail = nil, opts = {}) if start.nil? start = @document.base_dir end if jail.nil? && @document.safe >= SafeMode::SAFE jail = @document.base_dir end PathResolver.new.system_path(target, start, jail, opts) end
def normalize_web_path(target, start = nil)
start - the String start (i.e, parent) path (optional, default: nil)
target - the String target path
See PathResolver::web_path(target, start) for details.
Public: Normalize the web page using the PathResolver.
def normalize_web_path(target, start = nil) PathResolver.new.web_path(target, start) end
def read_asset(path, warn_on_failure = false)
returns the contents of the file at the specified path, or nil
the file cannot be read
warn_on_failure - a Boolean that controls whether a warning is issued if
path - the String path from which to read the contents
that the file is readable before attempting to read it.
This method assumes that the path is safe to read. It checks
Public: Read the contents of the file at the specified path.
def read_asset(path, warn_on_failure = false) if File.readable? path File.read(path).chomp else puts "asciidoctor: WARNING: file does not exist or cannot be read: #{path}" if warn_on_failure nil end end
def renderer
Public: Get the Asciidoctor::Renderer instance being used for the
def renderer @document.renderer end
def set_attr(key, val, overwrite = nil)
val - The value to assign to the key
key - The attribute key (or name)
block's attributes hash.
Public: Assign the value to the specified key in this
def set_attr(key, val, overwrite = nil) if overwrite.nil? @attributes[key] = val true else if overwrite || @attributes.has_key?(key) @attributes[key] = val true else false end end end
def update_attributes(attributes)
attributes - A Hash of attributes to assign to this node.
be overridden.
If an attribute already exists with the same key, it's value will
the attributes argument.
Public: Update the attributes of this node with the new values in
def update_attributes(attributes) @attributes.update(attributes) nil end