Support for the XPath "or" operator.
This commit is contained in:
parent
4f189d9218
commit
4fa40b58cf
|
@ -609,6 +609,23 @@ module Oga
|
||||||
return on_call_boolean(context, left) && on_call_boolean(context, right)
|
return on_call_boolean(context, left) && on_call_boolean(context, right)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Processes the `or` operator.
|
||||||
|
#
|
||||||
|
# This operator returns `true` if one of the expressions evaluates to
|
||||||
|
# true, otherwise false is returned. If the first expression evaluates to
|
||||||
|
# `true` the second expression is ignored.
|
||||||
|
#
|
||||||
|
# @param [Oga::XPath::Node] ast_node
|
||||||
|
# @param [Oga::XML::NodeSet] context
|
||||||
|
# @return [TrueClass|FalseClass]
|
||||||
|
#
|
||||||
|
def on_or(ast_node, context)
|
||||||
|
left, right = *ast_node
|
||||||
|
|
||||||
|
return on_call_boolean(context, left) || on_call_boolean(context, right)
|
||||||
|
end
|
||||||
|
|
||||||
##
|
##
|
||||||
# Delegates function calls to specific handlers.
|
# Delegates function calls to specific handlers.
|
||||||
#
|
#
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe Oga::XPath::Evaluator do
|
||||||
|
context 'or operator' do
|
||||||
|
before do
|
||||||
|
@document = parse('<root><a>1</a><b>1</b></root>')
|
||||||
|
@evaluator = described_class.new(@document)
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'return true if both boolean literals are true' do
|
||||||
|
@evaluator.evaluate('true() or true()').should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'return true if one of the boolean literals is false' do
|
||||||
|
@evaluator.evaluate('true() or false()').should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'return true if the left node set is not empty' do
|
||||||
|
@evaluator.evaluate('root/a or root/x').should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'return true if the right node set is not empty' do
|
||||||
|
@evaluator.evaluate('root/x or root/b').should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'return true if both node sets are not empty' do
|
||||||
|
@evaluator.evaluate('root/a or root/b').should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'return false if both node sets are empty' do
|
||||||
|
@evaluator.evaluate('root/x or root/y').should == false
|
||||||
|
end
|
||||||
|
|
||||||
|
example 'skip the right expression if the left one evaluates to false' do
|
||||||
|
@evaluator.should_not receive(:on_call_false)
|
||||||
|
|
||||||
|
@evaluator.evaluate('true() or false()').should == true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue