summaryrefslogtreecommitdiff
path: root/ext/bigdecimal/bigdecimal.c
diff options
context:
space:
mode:
authormrkn <mrkn@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-06-13 09:51:52 +0000
committermrkn <mrkn@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-06-13 09:51:52 +0000
commit5112c6d1d9021a920a04e914449a81e9ede9a75e (patch)
tree95e0ab182c4ee0ca60ff24200c18733ef82fa069 /ext/bigdecimal/bigdecimal.c
parent3bd8b390de64b002329729aecc370218035ee655 (diff)
* ext/bigdecimal/bigdecimal.c (is_kind_of_BigDecimal): new function to
examine the whether the object is kind of BigDecimal. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32053 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/bigdecimal/bigdecimal.c')
-rw-r--r--ext/bigdecimal/bigdecimal.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/ext/bigdecimal/bigdecimal.c b/ext/bigdecimal/bigdecimal.c
index c21dd8c5ce..3badb034ed 100644
--- a/ext/bigdecimal/bigdecimal.c
+++ b/ext/bigdecimal/bigdecimal.c
@@ -119,6 +119,12 @@ static const rb_data_type_t BigDecimal_data_type = {
{0, BigDecimal_delete, BigDecimal_memsize,},
};
+static inline int
+is_kind_of_BigDecimal(VALUE const v)
+{
+ return rb_typeddata_is_kind_of(v, &BigDecimal_data_type);
+}
+
static VALUE
ToValue(Real *p)
{
@@ -168,7 +174,7 @@ again:
goto SomeOneMayDoIt;
case T_DATA:
- if (rb_typeddata_is_kind_of(v, &BigDecimal_data_type)) {
+ if (is_kind_of_BigDecimal(v)) {
pv = DATA_PTR(v);
return pv;
}
@@ -798,7 +804,7 @@ BigDecimalCmp(VALUE self, VALUE r,char op)
GUARD_OBJ(a,GetVpValue(self,1));
switch (TYPE(r)) {
case T_DATA:
- if (!rb_typeddata_is_kind_of(r, &BigDecimal_data_type)) break;
+ if (!is_kind_of_BigDecimal(r)) break;
/* fall through */
case T_FIXNUM:
/* fall through */