mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
fa4bfa6af5
Fixes ticket:68. NOTE that this involves an API change! Entity declarations in the doctype now generate events that carry two, not one, arguments. Implements ticket:15, using gwrite's suggestion. This allows Element to be subclassed. Two unrelated changes, because subversion is retarded and doesn't do block-level commits: 1) Fixed a typo bug in previous change for ticket:15 2) Fixed namespaces handling in XPath and element. ***** Note that this is an API change!!! ***** Element.namespaces() now returns a hash of namespace mappings which are relevant for that node. Fixes a bug in multiple decodings The changeset 1230:1231 was bad. The default behavior is *not* to use the native REXML encodings by default, but rather to use ICONV by default. I know that this will piss some people off, but defaulting to the pure Ruby version isn't the correct solution, and it breaks other encodings, so I've reverted it. * Fixes ticket:61 (xpath_parser) * Fixes ticket:63 (UTF-16; UNILE decoding was bad) * Cleans up some tests, removing opportunities for test corruption * Improves parsing error messages a little * Adds the ability to override the encoding detection in Source construction * Fixes an edge case in Functions::string, where document nodes weren't correctly converted * Fixes Functions::string() for Element and Document nodes * Fixes some problems in entity handling Addresses ticket:66 Fixes ticket:71 Addresses ticket:78 NOTE: that this also fixes what is technically another bug in REXML. REXML's XPath parser used to allow exponential notation in numbers. The XPath spec is specific about what a number is, and scientific notation is not included. Therefore, this has been fixed. Cross-ported a fix for ticket:88 from CVS. Fixes ticket:80 Documentation cleanup. Ticket:84 Applied Kou's fix for an un-trac'ed bug. ------------------------------------------------------------------------ git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11548 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
64 lines
1.4 KiB
Ruby
64 lines
1.4 KiB
Ruby
require "rexml/parseexception"
|
|
|
|
module REXML
|
|
# Represents a node in the tree. Nodes are never encountered except as
|
|
# superclasses of other objects. Nodes have siblings.
|
|
module Node
|
|
# @return the next sibling (nil if unset)
|
|
def next_sibling_node
|
|
return nil if @parent.nil?
|
|
@parent[ @parent.index(self) + 1 ]
|
|
end
|
|
|
|
# @return the previous sibling (nil if unset)
|
|
def previous_sibling_node
|
|
return nil if @parent.nil?
|
|
ind = @parent.index(self)
|
|
return nil if ind == 0
|
|
@parent[ ind - 1 ]
|
|
end
|
|
|
|
def to_s indent=-1
|
|
rv = ""
|
|
write rv,indent
|
|
rv
|
|
end
|
|
|
|
def indent to, ind
|
|
if @parent and @parent.context and not @parent.context[:indentstyle].nil? then
|
|
indentstyle = @parent.context[:indentstyle]
|
|
else
|
|
indentstyle = ' '
|
|
end
|
|
to << indentstyle*ind unless ind<1
|
|
end
|
|
|
|
def parent?
|
|
false;
|
|
end
|
|
|
|
|
|
# Visit all subnodes of +self+ recursively
|
|
def each_recursive(&block) # :yields: node
|
|
self.elements.each {|node|
|
|
block.call(node)
|
|
node.each_recursive(&block)
|
|
}
|
|
end
|
|
|
|
# Find (and return) first subnode (recursively) for which the block
|
|
# evaluates to true. Returns +nil+ if none was found.
|
|
def find_first_recursive(&block) # :yields: node
|
|
each_recursive {|node|
|
|
return node if block.call(node)
|
|
}
|
|
return nil
|
|
end
|
|
|
|
# Returns the position that +self+ holds in its parent's array, indexed
|
|
# from 1.
|
|
def index_in_parent
|
|
parent.index(self)+1
|
|
end
|
|
end
|
|
end
|