Class: FalseClass
Overview
The global value false is the only instance of class FalseClass and represents a logically false value in boolean expressions. The class provides operators allowing false to participate correctly in logical expressions.
Instance Method Summary collapse
-
#&(obj2) ⇒ Object
And—Returns
false. -
#===(other) ⇒ Boolean
Case Equality – For class Object, effectively the same as calling
#==, but typically overridden by descendants to provide meaningful semantics incasestatements. -
#^(obj2) ⇒ Object
Exclusive Or—If obj is
nilorfalse, returnsfalse; otherwise, returnstrue. -
#to_s ⇒ Object
(also: #inspect)
The string representation of
falseis “false”. -
#|(obj2) ⇒ Object
Or—Returns
falseif obj isnilorfalse;trueotherwise.
Instance Method Details
#&(obj) ⇒ false #&(obj) ⇒ false
And—Returns false. obj is always evaluated as it is the argument to a method call—there is no short-circuit evaluation in this case.
1542 1543 1544 1545 1546 |
# File 'object.c', line 1542 static VALUE false_and(VALUE obj, VALUE obj2) { return Qfalse; } |
#===(other) ⇒ Boolean
Case Equality – For class Object, effectively the same as calling #==, but typically overridden by descendants to provide meaningful semantics in case statements.
131 132 133 134 135 136 137 138 139 140 141 142 143 |
# File 'object.c', line 131 VALUE rb_equal(VALUE obj1, VALUE obj2) { VALUE result; if (obj1 == obj2) return Qtrue; result = rb_equal_opt(obj1, obj2); if (result == Qundef) { result = rb_funcall(obj1, id_eq, 1, obj2); } if (RTEST(result)) return Qtrue; return Qfalse; } |
#^(obj) ⇒ Boolean #^(obj) ⇒ Boolean
Exclusive Or—If obj is nil or false, returns false; otherwise, returns true.
1577 1578 1579 1580 1581 |
# File 'object.c', line 1577 static VALUE false_xor(VALUE obj, VALUE obj2) { return RTEST(obj2)?Qtrue:Qfalse; } |
#to_s ⇒ Object Also known as: inspect
The string representation of false is “false”.
1526 1527 1528 1529 1530 |
# File 'object.c', line 1526 static VALUE false_to_s(VALUE obj) { return rb_cFalseClass_to_s; } |
#|(obj) ⇒ Boolean #|(obj) ⇒ Boolean
Or—Returns false if obj is nil or false; true otherwise.
1558 1559 1560 1561 1562 |
# File 'object.c', line 1558 static VALUE false_or(VALUE obj, VALUE obj2) { return RTEST(obj2)?Qtrue:Qfalse; } |