Commit 85ea2f61 authored by Jun Hiroe's avatar Jun Hiroe

Refactor range_eql() func in rangec.c

parent 6852680d
...@@ -377,34 +377,23 @@ range_eql(mrb_state *mrb, mrb_value range) ...@@ -377,34 +377,23 @@ range_eql(mrb_state *mrb, mrb_value range)
{ {
mrb_value obj; mrb_value obj;
struct RRange *r, *o; struct RRange *r, *o;
mrb_bool eql_p;
mrb_get_args(mrb, "o", &obj); mrb_get_args(mrb, "o", &obj);
if (mrb_obj_equal(mrb, range, obj)) {
eql_p = 1; if (mrb_obj_equal(mrb, range, obj)) return mrb_true_value();
} if (!mrb_obj_is_kind_of(mrb, obj, RANGE_CLASS)) {
else if (!mrb_obj_is_kind_of(mrb, obj, RANGE_CLASS)) { return mrb_false_value();
eql_p = 0;
} }
else { if (mrb_type(obj) != MRB_TT_RANGE) return mrb_false_value();
r = mrb_range_ptr(range); r = mrb_range_ptr(range);
if (mrb_type(obj) != MRB_TT_RANGE) {
eql_p = 0;
}
else {
o = mrb_range_ptr(obj); o = mrb_range_ptr(obj);
if (!mrb_eql(mrb, r->edges->beg, o->edges->beg) || if (!mrb_eql(mrb, r->edges->beg, o->edges->beg) ||
!mrb_eql(mrb, r->edges->end, o->edges->end) || !mrb_eql(mrb, r->edges->end, o->edges->end) ||
(r->excl != o->excl)) { (r->excl != o->excl)) {
eql_p = 0; return mrb_false_value();
}
else {
eql_p = 1;
}
}
} }
return mrb_true_value();
return mrb_bool_value(eql_p);
} }
/* 15.2.14.4.15(x) */ /* 15.2.14.4.15(x) */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment