Ruby  2.1.10p492(2016-04-01revision54464)
Macros | Functions | Variables
rational.c File Reference
#include "ruby.h"
#include "internal.h"
#include <math.h>
#include <float.h>
#include <assert.h>
#include <ctype.h>

Go to the source code of this file.

Macros

#define NDEBUG
 
#define ZERO   INT2FIX(0)
 
#define ONE   INT2FIX(1)
 
#define TWO   INT2FIX(2)
 
#define GMP_GCD_DIGITS   1
 
#define f_boolcast(x)   ((x) ? Qtrue : Qfalse)
 
#define f_inspect   rb_inspect
 
#define f_to_s   rb_obj_as_string
 
#define binop(n, op)
 
#define fun1(n)
 
#define fun2(n)
 
#define f_expt10(x)   f_expt(INT2FIX(10), x)
 
#define f_positive_p(x)   (!f_negative_p(x))
 
#define f_nonzero_p(x)   (!f_zero_p(x))
 
#define k_exact_p(x)   (!k_float_p(x))
 
#define k_inexact_p(x)   k_float_p(x)
 
#define k_exact_zero_p(x)   (k_exact_p(x) && f_zero_p(x))
 
#define k_exact_one_p(x)   (k_exact_p(x) && f_one_p(x))
 
#define get_dat1(x)
 
#define get_dat2(x, y)
 
#define rb_raise_zerodiv()   rb_raise(rb_eZeroDivError, "divided by 0")
 
#define id_ceil   rb_intern("ceil")
 
#define f_ceil(x)   rb_funcall((x), id_ceil, 0)
 
#define id_quo   rb_intern("quo")
 
#define f_quo(x, y)   rb_funcall((x), id_quo, 1, (y))
 
#define f_reciprocal(x)   f_quo(ONE, (x))
 
#define id_numerator   rb_intern("numerator")
 
#define f_numerator(x)   rb_funcall((x), id_numerator, 0)
 
#define id_denominator   rb_intern("denominator")
 
#define f_denominator(x)   rb_funcall((x), id_denominator, 0)
 
#define id_to_r   rb_intern("to_r")
 
#define f_to_r(x)   rb_funcall((x), id_to_r, 0)
 
#define id_lshift   rb_intern("<<")
 
#define f_lshift(x, n)   rb_funcall((x), id_lshift, 1, (n))
 
#define rb_intern(str)   rb_intern_const(str)
 

Functions

static VALUE f_add (VALUE x, VALUE y)
 
static VALUE f_cmp (VALUE x, VALUE y)
 
static VALUE f_div (VALUE x, VALUE y)
 
static VALUE f_lt_p (VALUE x, VALUE y)
 
 binop (mod, '%')
 
static VALUE f_sub (VALUE x, VALUE y)
 
 fun1 (abs)
 
static VALUE f_to_f (VALUE x)
 
static VALUE f_eqeq_p (VALUE x, VALUE y)
 
 fun2 (expt)
 
static VALUE f_zero_p (VALUE x)
 
static VALUE f_one_p (VALUE x)
 
static VALUE f_minus_one_p (VALUE x)
 
static VALUE f_kind_of_p (VALUE x, VALUE c)
 
static VALUE k_numeric_p (VALUE x)
 
static VALUE k_integer_p (VALUE x)
 
static VALUE k_float_p (VALUE x)
 
static VALUE k_rational_p (VALUE x)
 
static long i_gcd (long x, long y)
 
static VALUE f_gcd_normal (VALUE x, VALUE y)
 
VALUE rb_gcd_normal (VALUE x, VALUE y)
 
static VALUE f_gcd (VALUE x, VALUE y)
 
static VALUE f_lcm (VALUE x, VALUE y)
 
static VALUE nurat_s_new_internal (VALUE klass, VALUE num, VALUE den)
 
static VALUE nurat_s_alloc (VALUE klass)
 
static VALUE f_rational_new_bang1 (VALUE klass, VALUE x)
 
static void nurat_int_check (VALUE num)
 
static VALUE nurat_int_value (VALUE num)
 
static VALUE nurat_s_canonicalize_internal (VALUE klass, VALUE num, VALUE den)
 
static VALUE nurat_s_canonicalize_internal_no_reduce (VALUE klass, VALUE num, VALUE den)
 
static VALUE nurat_s_new (int argc, VALUE *argv, VALUE klass)
 
static VALUE f_rational_new2 (VALUE klass, VALUE x, VALUE y)
 
static VALUE f_rational_new_no_reduce2 (VALUE klass, VALUE x, VALUE y)
 
static VALUE nurat_f_rational (int argc, VALUE *argv, VALUE klass)
 
static VALUE nurat_numerator (VALUE self)
 
static VALUE nurat_denominator (VALUE self)
 
static VALUE f_imul (long a, long b)
 
static VALUE f_addsub (VALUE self, VALUE anum, VALUE aden, VALUE bnum, VALUE bden, int k)
 
static VALUE nurat_add (VALUE self, VALUE other)
 
static VALUE nurat_sub (VALUE self, VALUE other)
 
static VALUE f_muldiv (VALUE self, VALUE anum, VALUE aden, VALUE bnum, VALUE bden, int k)
 
static VALUE nurat_mul (VALUE self, VALUE other)
 
static VALUE nurat_div (VALUE self, VALUE other)
 
static VALUE nurat_fdiv (VALUE self, VALUE other)
 
static VALUE f_odd_p (VALUE integer)
 
static VALUE nurat_expt (VALUE self, VALUE other)
 
static VALUE nurat_cmp (VALUE self, VALUE other)
 
static VALUE nurat_eqeq_p (VALUE self, VALUE other)
 
static VALUE nurat_coerce (VALUE self, VALUE other)
 
static VALUE nurat_floor (VALUE self)
 
static VALUE nurat_ceil (VALUE self)
 
static VALUE nurat_truncate (VALUE self)
 
static VALUE nurat_round (VALUE self)
 
static VALUE f_round_common (int argc, VALUE *argv, VALUE self, VALUE(*func)(VALUE))
 
static VALUE nurat_floor_n (int argc, VALUE *argv, VALUE self)
 
static VALUE nurat_ceil_n (int argc, VALUE *argv, VALUE self)
 
static VALUE nurat_truncate_n (int argc, VALUE *argv, VALUE self)
 
static VALUE nurat_round_n (int argc, VALUE *argv, VALUE self)
 
static VALUE nurat_to_f (VALUE self)
 
static VALUE nurat_to_r (VALUE self)
 
static void nurat_rationalize_internal (VALUE a, VALUE b, VALUE *p, VALUE *q)
 
static VALUE nurat_rationalize (int argc, VALUE *argv, VALUE self)
 
static VALUE nurat_hash (VALUE self)
 
static VALUE f_format (VALUE self, VALUE(*func)(VALUE))
 
static VALUE nurat_to_s (VALUE self)
 
static VALUE nurat_inspect (VALUE self)
 
static VALUE nurat_dumper (VALUE self)
 
static VALUE nurat_loader (VALUE self, VALUE a)
 
static VALUE nurat_marshal_dump (VALUE self)
 
static VALUE nurat_marshal_load (VALUE self, VALUE a)
 
VALUE rb_rational_reciprocal (VALUE x)
 
VALUE rb_gcd (VALUE self, VALUE other)
 
VALUE rb_lcm (VALUE self, VALUE other)
 
VALUE rb_gcdlcm (VALUE self, VALUE other)
 
VALUE rb_rational_raw (VALUE x, VALUE y)
 
VALUE rb_rational_new (VALUE x, VALUE y)
 
static VALUE nurat_s_convert (int argc, VALUE *argv, VALUE klass)
 
VALUE rb_Rational (VALUE x, VALUE y)
 
static VALUE numeric_numerator (VALUE self)
 
static VALUE numeric_denominator (VALUE self)
 
static VALUE numeric_quo (VALUE x, VALUE y)
 
static VALUE integer_numerator (VALUE self)
 
static VALUE integer_denominator (VALUE self)
 
static VALUE float_numerator (VALUE self)
 
static VALUE float_denominator (VALUE self)
 
static VALUE nilclass_to_r (VALUE self)
 
static VALUE nilclass_rationalize (int argc, VALUE *argv, VALUE self)
 
static VALUE integer_to_r (VALUE self)
 
static VALUE integer_rationalize (int argc, VALUE *argv, VALUE self)
 
static void float_decode_internal (VALUE self, VALUE *rf, VALUE *rn)
 
static VALUE float_to_r (VALUE self)
 
VALUE rb_flt_rationalize_with_prec (VALUE flt, VALUE prec)
 
VALUE rb_flt_rationalize (VALUE flt)
 
static VALUE float_rationalize (int argc, VALUE *argv, VALUE self)
 
static int issign (int c)
 
static int read_sign (const char **s)
 
static int isdecimal (int c)
 
static int read_digits (const char **s, int strict, VALUE *num, int *count)
 
static int islettere (int c)
 
static int read_num (const char **s, int numsign, int strict, VALUE *num)
 
static int read_den (const char **s, int strict, VALUE *num)
 
static int read_rat_nos (const char **s, int sign, int strict, VALUE *num)
 
static int read_rat (const char **s, int strict, VALUE *num)
 
static void skip_ws (const char **s)
 
static int parse_rat (const char *s, int strict, VALUE *num)
 
static VALUE string_to_r_strict (VALUE self)
 
static VALUE string_to_r (VALUE self)
 
VALUE rb_cstr_to_rat (const char *s, int strict)
 
void Init_Rational (void)
 

Variables

VALUE rb_cRational
 
static ID id_abs
 
static ID id_cmp
 
static ID id_convert
 
static ID id_eqeq_p
 
static ID id_expt
 
static ID id_fdiv
 
static ID id_idiv
 
static ID id_integer_p
 
static ID id_negate
 
static ID id_to_f
 
static ID id_to_i
 
static ID id_truncate
 
static ID id_i_num
 
static ID id_i_den
 

Macro Definition Documentation

◆ binop

#define binop (   n,
  op 
)
Value:
inline static VALUE \
f_##n(VALUE x, VALUE y)\
{\
return rb_funcall(x, (op), 1, y);\
}
VALUE rb_funcall(VALUE, ID, int,...)
Calls a method.
Definition: vm_eval.c:781
unsigned long VALUE
Definition: ruby.h:88

Definition at line 41 of file rational.c.

◆ f_boolcast

#define f_boolcast (   x)    ((x) ? Qtrue : Qfalse)

Definition at line 37 of file rational.c.

Referenced by f_eqeq_p(), f_lt_p(), f_minus_one_p(), f_one_p(), f_zero_p(), fun2(), and nurat_eqeq_p().

◆ f_ceil

#define f_ceil (   x)    rb_funcall((x), id_ceil, 0)

Definition at line 1444 of file rational.c.

Referenced by nurat_rationalize_internal().

◆ f_denominator

#define f_denominator (   x)    rb_funcall((x), id_denominator, 0)

◆ f_expt10

#define f_expt10 (   x)    f_expt(INT2FIX(10), x)

Referenced by f_round_common(), and read_num().

◆ f_inspect

#define f_inspect   rb_inspect

Definition at line 38 of file rational.c.

Referenced by nurat_inspect(), and string_to_r_strict().

◆ f_lshift

#define f_lshift (   x,
 
)    rb_funcall((x), id_lshift, 1, (n))

Definition at line 1981 of file rational.c.

Referenced by float_to_r(), and rb_flt_rationalize().

◆ f_nonzero_p

#define f_nonzero_p (   x)    (!f_zero_p(x))

Definition at line 196 of file rational.c.

◆ f_numerator

#define f_numerator (   x)    rb_funcall((x), id_numerator, 0)

Definition at line 1779 of file rational.c.

Referenced by nucomp_expt(), nucomp_numerator(), and numeric_numerator().

◆ f_positive_p

#define f_positive_p (   x)    (!f_negative_p(x))

Definition at line 177 of file rational.c.

Referenced by rb_flt_rationalize().

◆ f_quo

#define f_quo (   x,
 
)    rb_funcall((x), id_quo, 1, (y))

Definition at line 1447 of file rational.c.

◆ f_reciprocal

#define f_reciprocal (   x)    f_quo(ONE, (x))

Definition at line 1449 of file rational.c.

Referenced by nurat_rationalize_internal().

◆ f_to_r

#define f_to_r (   x)    rb_funcall((x), id_to_r, 0)

◆ f_to_s

#define f_to_s   rb_obj_as_string

Definition at line 39 of file rational.c.

Referenced by nurat_to_s().

◆ fun1

#define fun1 (   n)
Value:
inline static VALUE \
f_##n(VALUE x)\
{\
return rb_funcall(x, id_##n, 0);\
}
VALUE rb_funcall(VALUE, ID, int,...)
Calls a method.
Definition: vm_eval.c:781
unsigned long VALUE
Definition: ruby.h:88

Definition at line 48 of file rational.c.

◆ fun2

#define fun2 (   n)
Value:
inline static VALUE \
f_##n(VALUE x, VALUE y)\
{\
return rb_funcall(x, id_##n, 1, y);\
}
VALUE rb_funcall(VALUE, ID, int,...)
Calls a method.
Definition: vm_eval.c:781
unsigned long VALUE
Definition: ruby.h:88

Definition at line 55 of file rational.c.

◆ get_dat1

#define get_dat1 (   x)

◆ get_dat2

#define get_dat2 (   x,
 
)
Value:
struct RRational *adat, *bdat;\
adat = ((struct RRational *)(x));\
bdat = ((struct RRational *)(y))

Definition at line 402 of file rational.c.

Referenced by nurat_add(), nurat_cmp(), nurat_div(), nurat_eqeq_p(), nurat_mul(), and nurat_sub().

◆ GMP_GCD_DIGITS

#define GMP_GCD_DIGITS   1

Definition at line 29 of file rational.c.

Referenced by f_gcd().

◆ id_ceil

#define id_ceil   rb_intern("ceil")

Definition at line 1443 of file rational.c.

◆ id_denominator

#define id_denominator   rb_intern("denominator")

Definition at line 1781 of file rational.c.

◆ id_lshift

#define id_lshift   rb_intern("<<")

Definition at line 1980 of file rational.c.

◆ id_numerator

#define id_numerator   rb_intern("numerator")

Definition at line 1778 of file rational.c.

◆ id_quo

#define id_quo   rb_intern("quo")

Definition at line 1446 of file rational.c.

◆ id_to_r

#define id_to_r   rb_intern("to_r")

Definition at line 1784 of file rational.c.

◆ k_exact_one_p

#define k_exact_one_p (   x)    (k_exact_p(x) && f_one_p(x))

Definition at line 270 of file rational.c.

Referenced by nurat_s_convert().

◆ k_exact_p

#define k_exact_p (   x)    (!k_float_p(x))

Definition at line 266 of file rational.c.

Referenced by nurat_expt().

◆ k_exact_zero_p

#define k_exact_zero_p (   x)    (k_exact_p(x) && f_zero_p(x))

Definition at line 269 of file rational.c.

Referenced by nurat_coerce(), nurat_expt(), and nurat_s_convert().

◆ k_inexact_p

#define k_inexact_p (   x)    k_float_p(x)

Definition at line 267 of file rational.c.

◆ NDEBUG

#define NDEBUG

Definition at line 17 of file rational.c.

◆ ONE

#define ONE   INT2FIX(1)

◆ rb_intern

#define rb_intern (   str)    rb_intern_const(str)

Referenced by Init_Rational().

◆ rb_raise_zerodiv

#define rb_raise_zerodiv ( )    rb_raise(rb_eZeroDivError, "divided by 0")

◆ TWO

#define TWO   INT2FIX(2)

Definition at line 27 of file rational.c.

Referenced by nurat_round(), and rb_flt_rationalize().

◆ ZERO

#define ZERO   INT2FIX(0)

Function Documentation

◆ binop()

binop ( mod  ,
'%'   
)

Definition at line 102 of file rational.c.

References FIX2LONG, FIXNUM_P, rb_funcall(), RB_TYPE_P, T_BIGNUM, and ZERO.

◆ f_add()

static VALUE f_add ( VALUE  x,
VALUE  y 
)
inlinestatic

◆ f_addsub()

static VALUE f_addsub ( VALUE  self,
VALUE  anum,
VALUE  aden,
VALUE  bnum,
VALUE  bden,
int  k 
)
inlinestatic

◆ f_cmp()

static VALUE f_cmp ( VALUE  x,
VALUE  y 
)
inlinestatic

◆ f_div()

static VALUE f_div ( VALUE  x,
VALUE  y 
)
inlinestatic

Definition at line 87 of file rational.c.

References FIX2LONG, FIXNUM_P, and rb_funcall().

Referenced by f_lcm(), f_round_common(), nurat_fdiv(), nurat_s_convert(), read_num(), and read_rat_nos().

◆ f_eqeq_p()

static VALUE f_eqeq_p ( VALUE  x,
VALUE  y 
)
inlinestatic

◆ f_format()

static VALUE f_format ( VALUE  self,
VALUE(*)(VALUE func 
)
static

Definition at line 1593 of file rational.c.

References func, get_dat1, rb_str_cat2(), and rb_str_concat().

Referenced by nurat_inspect(), and nurat_to_s().

◆ f_gcd()

static VALUE f_gcd ( VALUE  x,
VALUE  y 
)
inlinestatic

◆ f_gcd_normal()

static VALUE f_gcd_normal ( VALUE  x,
VALUE  y 
)
inlinestatic

Definition at line 324 of file rational.c.

References f_mod, f_negate, f_negative_p(), f_zero_p(), FIX2LONG, FIXNUM_P, i_gcd(), and LONG2NUM.

Referenced by f_gcd(), and rb_gcd_normal().

◆ f_imul()

static VALUE f_imul ( long  a,
long  b 
)
inlinestatic

Definition at line 654 of file rational.c.

References LONG2NUM, MUL_OVERFLOW_LONG_P, rb_big_mul(), rb_int2big(), and ZERO.

Referenced by f_addsub(), f_muldiv(), and nurat_cmp().

◆ f_kind_of_p()

static VALUE f_kind_of_p ( VALUE  x,
VALUE  c 
)
inlinestatic

Definition at line 237 of file rational.c.

References rb_obj_is_kind_of().

Referenced by k_float_p(), k_integer_p(), k_numeric_p(), and k_rational_p().

◆ f_lcm()

static VALUE f_lcm ( VALUE  x,
VALUE  y 
)
inlinestatic

Definition at line 391 of file rational.c.

References f_abs, f_div(), f_gcd(), f_mul, f_zero_p(), and ZERO.

Referenced by rb_gcdlcm(), and rb_lcm().

◆ f_lt_p()

static VALUE f_lt_p ( VALUE  x,
VALUE  y 
)
inlinestatic

Definition at line 95 of file rational.c.

References f_boolcast, FIX2LONG, FIXNUM_P, and rb_funcall().

Referenced by f_round_common(), and nurat_rationalize_internal().

◆ f_minus_one_p()

static VALUE f_minus_one_p ( VALUE  x)
inlinestatic

Definition at line 218 of file rational.c.

References f_boolcast, FIX2LONG, FIXNUM_P, id_eqeq_p, INT2FIX, Qfalse, rb_funcall(), RB_TYPE_P, RRATIONAL, T_BIGNUM, T_FIXNUM, and T_RATIONAL.

Referenced by nurat_expt().

◆ f_muldiv()

static VALUE f_muldiv ( VALUE  self,
VALUE  anum,
VALUE  aden,
VALUE  bnum,
VALUE  bden,
int  k 
)
inlinestatic

◆ f_odd_p()

static VALUE f_odd_p ( VALUE  integer)
inlinestatic

Definition at line 963 of file rational.c.

References INT2FIX, Qfalse, Qtrue, and rb_funcall().

Referenced by nurat_expt().

◆ f_one_p()

static VALUE f_one_p ( VALUE  x)
inlinestatic

◆ f_rational_new2()

static VALUE f_rational_new2 ( VALUE  klass,
VALUE  x,
VALUE  y 
)
inlinestatic

Definition at line 564 of file rational.c.

References assert, k_rational_p(), and nurat_s_canonicalize_internal().

Referenced by nurat_expt(), and nurat_rationalize().

◆ f_rational_new_bang1()

static VALUE f_rational_new_bang1 ( VALUE  klass,
VALUE  x 
)
inlinestatic

Definition at line 461 of file rational.c.

References nurat_s_new_internal(), and ONE.

Referenced by f_round_common(), nurat_cmp(), nurat_coerce(), and nurat_expt().

◆ f_rational_new_no_reduce2()

static VALUE f_rational_new_no_reduce2 ( VALUE  klass,
VALUE  x,
VALUE  y 
)
inlinestatic

◆ f_round_common()

static VALUE f_round_common ( int  argc,
VALUE argv,
VALUE  self,
VALUE(*)(VALUE func 
)
static

◆ f_sub()

static VALUE f_sub ( VALUE  x,
VALUE  y 
)
inlinestatic

◆ f_to_f()

static VALUE f_to_f ( VALUE  x)
inlinestatic

◆ f_zero_p()

static VALUE f_zero_p ( VALUE  x)
inlinestatic

◆ float_decode_internal()

static void float_decode_internal ( VALUE  self,
VALUE rf,
VALUE rn 
)
static

Definition at line 1957 of file rational.c.

References DBL_MANT_DIG, f, INT2FIX, rb_dbl2big(), and RFLOAT_VALUE.

Referenced by float_to_r(), and rb_flt_rationalize().

◆ float_denominator()

static VALUE float_denominator ( VALUE  self)
static

Definition at line 1893 of file rational.c.

References INT2FIX, isinf(), isnan, rb_call_super(), and RFLOAT_VALUE.

Referenced by Init_Rational().

◆ float_numerator()

static VALUE float_numerator ( VALUE  self)
static

Definition at line 1875 of file rational.c.

References isinf(), isnan, rb_call_super(), and RFLOAT_VALUE.

Referenced by Init_Rational().

◆ float_rationalize()

static VALUE float_rationalize ( int  argc,
VALUE argv,
VALUE  self 
)
static

◆ float_to_r()

static VALUE float_to_r ( VALUE  self)
static

Definition at line 2000 of file rational.c.

References f, f_expt, f_lshift, f_mul, f_to_r, FIX2LONG, float_decode_internal(), FLT_RADIX, INT2FIX, ONE, and rb_rational_new2.

Referenced by Init_Rational().

◆ fun1()

fun1 ( abs  )

Definition at line 136 of file rational.c.

References id_to_i, rb_funcall(), rb_str_to_inum(), RB_TYPE_P, and T_STRING.

◆ fun2()

fun2 ( expt  )

Definition at line 163 of file rational.c.

References f_boolcast, FIX2LONG, FIXNUM_P, rb_funcall(), and ZERO.

◆ i_gcd()

static long i_gcd ( long  x,
long  y 
)
inlinestatic

Definition at line 303 of file rational.c.

References t().

Referenced by f_addsub(), f_gcd_normal(), and f_muldiv().

◆ Init_Rational()

void Init_Rational ( void  )

◆ integer_denominator()

static VALUE integer_denominator ( VALUE  self)
static

Definition at line 1859 of file rational.c.

References INT2FIX.

Referenced by Init_Rational().

◆ integer_numerator()

static VALUE integer_numerator ( VALUE  self)
static

Definition at line 1847 of file rational.c.

Referenced by Init_Rational().

◆ integer_rationalize()

static VALUE integer_rationalize ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1950 of file rational.c.

References argc, argv, integer_to_r(), NULL, and rb_scan_args().

Referenced by Init_Rational().

◆ integer_to_r()

static VALUE integer_to_r ( VALUE  self)
static

Definition at line 1937 of file rational.c.

References rb_rational_new1.

Referenced by Init_Rational(), and integer_rationalize().

◆ isdecimal()

static int isdecimal ( int  c)
inlinestatic

Definition at line 2128 of file rational.c.

Referenced by read_digits().

◆ islettere()

static int islettere ( int  c)
inlinestatic

Definition at line 2178 of file rational.c.

Referenced by read_num().

◆ issign()

static int issign ( int  c)
inlinestatic

Definition at line 2110 of file rational.c.

Referenced by read_sign().

◆ k_float_p()

static VALUE k_float_p ( VALUE  x)
inlinestatic

Definition at line 255 of file rational.c.

References f_kind_of_p(), and rb_cFloat.

Referenced by f_round_common().

◆ k_integer_p()

static VALUE k_integer_p ( VALUE  x)
inlinestatic

Definition at line 249 of file rational.c.

References f_kind_of_p(), and rb_cInteger.

Referenced by f_round_common(), nurat_expt(), nurat_int_value(), and nurat_s_convert().

◆ k_numeric_p()

static VALUE k_numeric_p ( VALUE  x)
inlinestatic

Definition at line 243 of file rational.c.

References f_kind_of_p(), and rb_cNumeric.

Referenced by nurat_expt(), nurat_int_check(), and nurat_s_convert().

◆ k_rational_p()

static VALUE k_rational_p ( VALUE  x)
inlinestatic

Definition at line 261 of file rational.c.

References f_kind_of_p(), and rb_cRational.

Referenced by f_rational_new2(), f_rational_new_no_reduce2(), f_round_common(), and nurat_expt().

◆ nilclass_rationalize()

static VALUE nilclass_rationalize ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1921 of file rational.c.

References argc, argv, nilclass_to_r(), NULL, and rb_scan_args().

Referenced by Init_Rational().

◆ nilclass_to_r()

static VALUE nilclass_to_r ( VALUE  self)
static

Definition at line 1908 of file rational.c.

References INT2FIX, and rb_rational_new1.

Referenced by Init_Rational(), and nilclass_rationalize().

◆ numeric_denominator()

static VALUE numeric_denominator ( VALUE  self)
static

Definition at line 1806 of file rational.c.

References f_denominator, and f_to_r.

Referenced by Init_Rational().

◆ numeric_numerator()

static VALUE numeric_numerator ( VALUE  self)
static

Definition at line 1794 of file rational.c.

References f_numerator, and f_to_r.

Referenced by Init_Rational().

◆ numeric_quo()

static VALUE numeric_quo ( VALUE  x,
VALUE  y 
)
static

Definition at line 1821 of file rational.c.

References rb_convert_type(), rb_funcall(), rb_rational_raw1, RB_TYPE_P, T_FLOAT, and T_RATIONAL.

Referenced by Init_Rational().

◆ nurat_add()

static VALUE nurat_add ( VALUE  self,
VALUE  other 
)
static

◆ nurat_ceil()

static VALUE nurat_ceil ( VALUE  self)
static

Definition at line 1223 of file rational.c.

References f_idiv, f_negate, and get_dat1.

Referenced by nurat_ceil_n().

◆ nurat_ceil_n()

static VALUE nurat_ceil_n ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1356 of file rational.c.

References argc, argv, f_round_common(), and nurat_ceil().

Referenced by Init_Rational().

◆ nurat_cmp()

static VALUE nurat_cmp ( VALUE  self,
VALUE  other 
)
static

◆ nurat_coerce()

static VALUE nurat_coerce ( VALUE  self,
VALUE  other 
)
static

◆ nurat_denominator()

static VALUE nurat_denominator ( VALUE  self)
static

Definition at line 643 of file rational.c.

References get_dat1.

Referenced by Init_Rational().

◆ nurat_div()

static VALUE nurat_div ( VALUE  self,
VALUE  other 
)
static

◆ nurat_dumper()

static VALUE nurat_dumper ( VALUE  self)
static

Definition at line 1645 of file rational.c.

Referenced by Init_Rational().

◆ nurat_eqeq_p()

static VALUE nurat_eqeq_p ( VALUE  self,
VALUE  other 
)
static

◆ nurat_expt()

static VALUE nurat_expt ( VALUE  self,
VALUE  other 
)
static

◆ nurat_f_rational()

static VALUE nurat_f_rational ( int  argc,
VALUE argv,
VALUE  klass 
)
static

Definition at line 607 of file rational.c.

References argc, argv, id_convert, rb_cRational, and rb_funcall2.

Referenced by Init_Rational().

◆ nurat_fdiv()

static VALUE nurat_fdiv ( VALUE  self,
VALUE  other 
)
static

Definition at line 955 of file rational.c.

References f_div(), f_to_f(), and f_zero_p().

Referenced by Init_Rational().

◆ nurat_floor()

static VALUE nurat_floor ( VALUE  self)
static

Definition at line 1216 of file rational.c.

References f_idiv, and get_dat1.

Referenced by nurat_floor_n().

◆ nurat_floor_n()

static VALUE nurat_floor_n ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1332 of file rational.c.

References argc, argv, f_round_common(), and nurat_floor().

Referenced by Init_Rational().

◆ nurat_hash()

static VALUE nurat_hash ( VALUE  self)
static

Definition at line 1578 of file rational.c.

References get_dat1, LONG2FIX, NUM2LONG, rb_hash(), and rb_memhash().

Referenced by Init_Rational().

◆ nurat_inspect()

static VALUE nurat_inspect ( VALUE  self)
static

Definition at line 1632 of file rational.c.

References f_format(), f_inspect, rb_str_cat2(), rb_str_concat(), and rb_usascii_str_new2.

Referenced by Init_Rational().

◆ nurat_int_check()

static void nurat_int_check ( VALUE  num)
inlinestatic

Definition at line 481 of file rational.c.

References k_numeric_p(), rb_eTypeError, rb_raise(), RB_TYPE_P, T_BIGNUM, and T_FIXNUM.

Referenced by nurat_int_value().

◆ nurat_int_value()

static VALUE nurat_int_value ( VALUE  num)
inlinestatic

Definition at line 490 of file rational.c.

References f_to_i, k_integer_p(), and nurat_int_check().

Referenced by nurat_s_new(), rb_gcd(), rb_gcdlcm(), and rb_lcm().

◆ nurat_loader()

static VALUE nurat_loader ( VALUE  self,
VALUE  a 
)
static

Definition at line 1652 of file rational.c.

References get_dat1, id_i_den, id_i_num, rb_ivar_get(), RRATIONAL_SET_DEN, and RRATIONAL_SET_NUM.

Referenced by Init_Rational().

◆ nurat_marshal_dump()

static VALUE nurat_marshal_dump ( VALUE  self)
static

Definition at line 1664 of file rational.c.

References get_dat1, rb_assoc_new(), and rb_copy_generic_ivar().

Referenced by Init_Rational().

◆ nurat_marshal_load()

static VALUE nurat_marshal_load ( VALUE  self,
VALUE  a 
)
static

◆ nurat_mul()

static VALUE nurat_mul ( VALUE  self,
VALUE  other 
)
static

◆ nurat_numerator()

static VALUE nurat_numerator ( VALUE  self)
static

Definition at line 624 of file rational.c.

References get_dat1.

Referenced by Init_Rational().

◆ nurat_rationalize()

static VALUE nurat_rationalize ( int  argc,
VALUE argv,
VALUE  self 
)
static

◆ nurat_rationalize_internal()

static void nurat_rationalize_internal ( VALUE  a,
VALUE  b,
VALUE p,
VALUE q 
)
static

◆ nurat_round()

static VALUE nurat_round ( VALUE  self)
static

Definition at line 1254 of file rational.c.

References f_add(), f_idiv, f_mul, f_negate, f_negative_p(), get_dat1, neg, and TWO.

Referenced by nurat_round_n().

◆ nurat_round_n()

static VALUE nurat_round_n ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1405 of file rational.c.

References argc, argv, f_round_common(), and nurat_round().

Referenced by Init_Rational().

◆ nurat_s_alloc()

static VALUE nurat_s_alloc ( VALUE  klass)
static

Definition at line 419 of file rational.c.

References nurat_s_new_internal(), ONE, and ZERO.

Referenced by Init_Rational().

◆ nurat_s_canonicalize_internal()

static VALUE nurat_s_canonicalize_internal ( VALUE  klass,
VALUE  num,
VALUE  den 
)
inlinestatic

◆ nurat_s_canonicalize_internal_no_reduce()

static VALUE nurat_s_canonicalize_internal_no_reduce ( VALUE  klass,
VALUE  num,
VALUE  den 
)
inlinestatic

Definition at line 525 of file rational.c.

References f_cmp(), f_negate, f_one_p(), FIX2INT, nurat_s_new_internal(), rb_raise_zerodiv, and ZERO.

Referenced by f_rational_new_no_reduce2().

◆ nurat_s_convert()

static VALUE nurat_s_convert ( int  argc,
VALUE argv,
VALUE  klass 
)
static

◆ nurat_s_new()

static VALUE nurat_s_new ( int  argc,
VALUE argv,
VALUE  klass 
)
static

Definition at line 545 of file rational.c.

References argc, argv, nurat_int_value(), nurat_s_canonicalize_internal(), ONE, and rb_scan_args().

Referenced by Init_Rational(), and nurat_s_convert().

◆ nurat_s_new_internal()

static VALUE nurat_s_new_internal ( VALUE  klass,
VALUE  num,
VALUE  den 
)
inlinestatic

◆ nurat_sub()

static VALUE nurat_sub ( VALUE  self,
VALUE  other 
)
static

◆ nurat_to_f()

static VALUE nurat_to_f ( VALUE  self)
static

Definition at line 1422 of file rational.c.

References get_dat1.

Referenced by Init_Rational().

◆ nurat_to_r()

static VALUE nurat_to_r ( VALUE  self)
static

Definition at line 1438 of file rational.c.

Referenced by Init_Rational().

◆ nurat_to_s()

static VALUE nurat_to_s ( VALUE  self)
static

Definition at line 1616 of file rational.c.

References f_format(), and f_to_s.

Referenced by Init_Rational().

◆ nurat_truncate()

static VALUE nurat_truncate ( VALUE  self)
static

Definition at line 1245 of file rational.c.

References f_idiv, f_negate, f_negative_p(), and get_dat1.

Referenced by Init_Rational(), and nurat_truncate_n().

◆ nurat_truncate_n()

static VALUE nurat_truncate_n ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1380 of file rational.c.

References argc, argv, f_round_common(), and nurat_truncate().

Referenced by Init_Rational().

◆ parse_rat()

static int parse_rat ( const char *  s,
int  strict,
VALUE num 
)
static

Definition at line 2279 of file rational.c.

References read_rat(), and skip_ws().

Referenced by rb_cstr_to_rat(), string_to_r(), and string_to_r_strict().

◆ rb_cstr_to_rat()

VALUE rb_cstr_to_rat ( const char *  s,
int  strict 
)

Definition at line 2376 of file rational.c.

References parse_rat(), rb_eFloatDomainError, rb_raise(), RB_TYPE_P, and T_FLOAT.

Referenced by str2num().

◆ rb_flt_rationalize()

VALUE rb_flt_rationalize ( VALUE  flt)

◆ rb_flt_rationalize_with_prec()

VALUE rb_flt_rationalize_with_prec ( VALUE  flt,
VALUE  prec 
)

Definition at line 2022 of file rational.c.

References f_abs, f_add(), f_eqeq_p(), f_sub(), f_to_r, nurat_rationalize_internal(), and rb_rational_new2.

Referenced by float_rationalize().

◆ rb_gcd()

VALUE rb_gcd ( VALUE  self,
VALUE  other 
)

Definition at line 1714 of file rational.c.

References f_gcd(), and nurat_int_value().

Referenced by Init_Rational().

◆ rb_gcd_normal()

VALUE rb_gcd_normal ( VALUE  x,
VALUE  y 
)

Definition at line 356 of file rational.c.

References f_gcd_normal().

◆ rb_gcdlcm()

VALUE rb_gcdlcm ( VALUE  self,
VALUE  other 
)

Definition at line 1749 of file rational.c.

References f_gcd(), f_lcm(), nurat_int_value(), and rb_assoc_new().

Referenced by Init_Rational().

◆ rb_lcm()

VALUE rb_lcm ( VALUE  self,
VALUE  other 
)

Definition at line 1732 of file rational.c.

References f_lcm(), and nurat_int_value().

Referenced by Init_Rational(), and nucomp_denominator().

◆ rb_Rational()

VALUE rb_Rational ( VALUE  x,
VALUE  y 
)

Definition at line 1770 of file rational.c.

References nurat_s_convert(), and rb_cRational.

Referenced by BigDecimal_to_r().

◆ rb_rational_new()

VALUE rb_rational_new ( VALUE  x,
VALUE  y 
)

Definition at line 1762 of file rational.c.

References nurat_s_canonicalize_internal(), and rb_cRational.

Referenced by parser_yylex().

◆ rb_rational_raw()

VALUE rb_rational_raw ( VALUE  x,
VALUE  y 
)

Definition at line 1756 of file rational.c.

References nurat_s_new_internal(), and rb_cRational.

◆ rb_rational_reciprocal()

VALUE rb_rational_reciprocal ( VALUE  x)

Definition at line 1696 of file rational.c.

References CLASS_OF, f_rational_new_no_reduce2(), and get_dat1.

Referenced by fix_divide().

◆ read_den()

static int read_den ( const char **  s,
int  strict,
VALUE num 
)
inlinestatic

Definition at line 2233 of file rational.c.

References NULL, and read_digits().

Referenced by read_rat_nos().

◆ read_digits()

static int read_digits ( const char **  s,
int  strict,
VALUE num,
int *  count 
)
static

Definition at line 2134 of file rational.c.

References ALLOCV_END, ALLOCV_N, count, isdecimal(), rb_cstr_to_inum(), strlen(), and ZERO.

Referenced by read_den(), and read_num().

◆ read_num()

static int read_num ( const char **  s,
int  numsign,
int  strict,
VALUE num 
)
static

◆ read_rat()

static int read_rat ( const char **  s,
int  strict,
VALUE num 
)
static

Definition at line 2260 of file rational.c.

References read_rat_nos(), and read_sign().

Referenced by parse_rat().

◆ read_rat_nos()

static int read_rat_nos ( const char **  s,
int  sign,
int  strict,
VALUE num 
)
static

Definition at line 2242 of file rational.c.

References f_div(), FIX2LONG, FIXNUM_P, read_den(), and read_num().

Referenced by read_rat().

◆ read_sign()

static int read_sign ( const char **  s)
static

Definition at line 2116 of file rational.c.

References issign().

Referenced by read_num(), and read_rat().

◆ skip_ws()

static void skip_ws ( const char **  s)
inlinestatic

Definition at line 2272 of file rational.c.

Referenced by parse_rat().

◆ string_to_r()

static VALUE string_to_r ( VALUE  self)
static

◆ string_to_r_strict()

static VALUE string_to_r_strict ( VALUE  self)
static

Variable Documentation

◆ id_abs

ID id_abs
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational().

◆ id_cmp

ID id_cmp
static

Definition at line 33 of file rational.c.

Referenced by f_cmp(), Init_Rational(), and nurat_cmp().

◆ id_convert

ID id_convert
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational(), and nurat_f_rational().

◆ id_eqeq_p

ID id_eqeq_p
static

Definition at line 33 of file rational.c.

Referenced by f_eqeq_p(), f_minus_one_p(), f_one_p(), f_zero_p(), and Init_Rational().

◆ id_expt

ID id_expt
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational(), and nurat_expt().

◆ id_fdiv

ID id_fdiv
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational().

◆ id_i_den

ID id_i_den
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational(), nurat_loader(), and nurat_marshal_load().

◆ id_i_num

ID id_i_num
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational(), nurat_loader(), and nurat_marshal_load().

◆ id_idiv

ID id_idiv
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational().

◆ id_integer_p

ID id_integer_p
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational().

◆ id_negate

ID id_negate
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational().

◆ id_to_f

ID id_to_f
static

Definition at line 33 of file rational.c.

Referenced by f_to_f(), and Init_Rational().

◆ id_to_i

ID id_to_i
static

Definition at line 33 of file rational.c.

Referenced by fun1(), and Init_Rational().

◆ id_truncate

ID id_truncate
static

Definition at line 33 of file rational.c.

Referenced by Init_Rational().

◆ rb_cRational

VALUE rb_cRational