Module: Comparable
- Included in:
- File::Stat, Numeric, String, Time
- Defined in:
- compar.c
Instance Method Summary collapse
-
#<(other) ⇒ Boolean
Compares two objects based on the receiver's
<=>
method, returning true if it returns -1. -
#<=(other) ⇒ Boolean
Compares two objects based on the receiver's
<=>
method, returning true if it returns -1 or 0. -
#==(other) ⇒ Boolean
Compares two objects based on the receiver's
<=>
method, returning true if it returns 0. -
#>(other) ⇒ Boolean
Compares two objects based on the receiver's
<=>
method, returning true if it returns 1. -
#>=(other) ⇒ Boolean
Compares two objects based on the receiver's
<=>
method, returning true if it returns 0 or 1. -
#between?(min, max) ⇒ Boolean
Returns
false
if obj<=>
min is less than zero or if anObject<=>
max is greater than zero,true
otherwise.
Instance Method Details
#<(other) ⇒ Boolean
Compares two objects based on the receiver's <=>
method, returning true if it returns -1.
|
# File 'compar.c'
/*
* call-seq:
* obj < other => true or false
*
* Compares two objects based on the receiver's <code><=></code>
* method, returning true if it returns -1.
*/
static VALUE
cmp_lt(x, y)
VALUE x, y;
{
VALUE c = rb_funcall(x, cmp, 1, y);
if (NIL_P(c)) return cmperr();
if (rb_cmpint(c, x, y) < 0) return Qtrue;
return Qfalse;
}
|
#<=(other) ⇒ Boolean
Compares two objects based on the receiver's <=>
method, returning true if it returns -1 or 0.
|
# File 'compar.c'
/*
* call-seq:
* obj <= other => true or false
*
* Compares two objects based on the receiver's <code><=></code>
* method, returning true if it returns -1 or 0.
*/
static VALUE
cmp_le(x, y)
VALUE x, y;
{
VALUE c = rb_funcall(x, cmp, 1, y);
if (NIL_P(c)) return cmperr();
if (rb_cmpint(c, x, y) <= 0) return Qtrue;
return Qfalse;
}
|
#==(other) ⇒ Boolean
Compares two objects based on the receiver's <=>
method, returning true if it returns 0. Also returns true if obj and other are the same object.
|
# File 'compar.c'
/*
* call-seq:
* obj == other => true or false
*
* Compares two objects based on the receiver's <code><=></code>
* method, returning true if it returns 0. Also returns true if
* _obj_ and _other_ are the same object.
*/
static VALUE
cmp_equal(x, y)
VALUE x, y;
{
VALUE a[2];
if (x == y) return Qtrue;
a[0] = x; a[1] = y;
return rb_rescue(cmp_eq, (VALUE)a, cmp_failed, 0);
}
|
#>(other) ⇒ Boolean
Compares two objects based on the receiver's <=>
method, returning true if it returns 1.
|
# File 'compar.c'
/*
* call-seq:
* obj > other => true or false
*
* Compares two objects based on the receiver's <code><=></code>
* method, returning true if it returns 1.
*/
static VALUE
cmp_gt(x, y)
VALUE x, y;
{
VALUE c = rb_funcall(x, cmp, 1, y);
if (NIL_P(c)) return cmperr();
if (rb_cmpint(c, x, y) > 0) return Qtrue;
return Qfalse;
}
|
#>=(other) ⇒ Boolean
Compares two objects based on the receiver's <=>
method, returning true if it returns 0 or 1.
|
# File 'compar.c'
/*
* call-seq:
* obj >= other => true or false
*
* Compares two objects based on the receiver's <code><=></code>
* method, returning true if it returns 0 or 1.
*/
static VALUE
cmp_ge(x, y)
VALUE x, y;
{
VALUE c = rb_funcall(x, cmp, 1, y);
if (NIL_P(c)) return cmperr();
if (rb_cmpint(c, x, y) >= 0) return Qtrue;
return Qfalse;
}
|
#between?(min, max) ⇒ Boolean
Returns false
if obj <=>
min is less than zero or if anObject <=>
max is greater than zero, true
otherwise.
3.between?(1, 5) #=> true
6.between?(1, 5) #=> false
'cat'.between?('ant', 'dog') #=> true
'gnu'.between?('ant', 'dog') #=> false
|
# File 'compar.c'
/*
* call-seq:
* obj.between?(min, max) => true or false
*
* Returns <code>false</code> if <i>obj</i> <code><=></code>
* <i>min</i> is less than zero or if <i>anObject</i> <code><=></code>
* <i>max</i> is greater than zero, <code>true</code> otherwise.
*
* 3.between?(1, 5) #=> true
* 6.between?(1, 5) #=> false
* 'cat'.between?('ant', 'dog') #=> true
* 'gnu'.between?('ant', 'dog') #=> false
*
*/
static VALUE
cmp_between(x, min, max)
VALUE x, min, max;
{
if (RTEST(cmp_lt(x, min))) return Qfalse;
if (RTEST(cmp_gt(x, max))) return Qfalse;
return Qtrue;
}
|