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 incase
statements. -
#^(obj2) ⇒ Object
Exclusive Or—If obj is
nil
orfalse
, returnsfalse
; otherwise, returnstrue
. -
#to_s ⇒ Object
(also: #inspect)
The string representation of
false
is “false”. -
#|(obj2) ⇒ Object
Or—Returns
false
if obj isnil
orfalse
;true
otherwise.
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;
}
|