mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	* bignum.c (rb_integer_float_cmp): renamed from rb_big_float_cmp.
* internal.h: follow the above change. * numeric.c: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@36405 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
		
							parent
							
								
									94735e9e54
								
							
						
					
					
						commit
						cf469774d1
					
				
					 4 changed files with 25 additions and 17 deletions
				
			
		|  | @ -1,3 +1,11 @@ | ||||||
|  | Mon Jul 16 18:40:26 2012  Tanaka Akira  <akr@fsij.org> | ||||||
|  | 
 | ||||||
|  | 	* bignum.c (rb_integer_float_cmp): renamed from rb_big_float_cmp. | ||||||
|  | 
 | ||||||
|  | 	* internal.h: follow the above change. | ||||||
|  | 
 | ||||||
|  | 	* numeric.c: ditto. | ||||||
|  | 
 | ||||||
| Mon Jul 16 17:57:54 2012  Tanaka Akira  <akr@fsij.org> | Mon Jul 16 17:57:54 2012  Tanaka Akira  <akr@fsij.org> | ||||||
| 
 | 
 | ||||||
| 	* bignum.c (rb_big_float_cmp): compare an integer and float precisely. | 	* bignum.c (rb_big_float_cmp): compare an integer and float precisely. | ||||||
|  |  | ||||||
							
								
								
									
										8
									
								
								bignum.c
									
										
									
									
									
								
							
							
						
						
									
										8
									
								
								bignum.c
									
										
									
									
									
								
							|  | @ -1432,7 +1432,7 @@ rb_big_to_f(VALUE x) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| VALUE | VALUE | ||||||
| rb_big_float_cmp(VALUE x, VALUE y) | rb_integer_float_cmp(VALUE x, VALUE y) | ||||||
| { | { | ||||||
|     double a = RFLOAT_VALUE(y); |     double a = RFLOAT_VALUE(y); | ||||||
|     double yi, yf; |     double yi, yf; | ||||||
|  | @ -1506,7 +1506,7 @@ rb_big_cmp(VALUE x, VALUE y) | ||||||
| 	break; | 	break; | ||||||
| 
 | 
 | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         return rb_big_float_cmp(x, y); |         return rb_integer_float_cmp(x, y); | ||||||
| 
 | 
 | ||||||
|       default: |       default: | ||||||
| 	return rb_num_coerce_cmp(x, y, rb_intern("<=>")); | 	return rb_num_coerce_cmp(x, y, rb_intern("<=>")); | ||||||
|  | @ -1549,7 +1549,7 @@ big_op(VALUE x, VALUE y, enum big_op_t op) | ||||||
| 	break; | 	break; | ||||||
| 
 | 
 | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         rel = rb_big_float_cmp(x, y); |         rel = rb_integer_float_cmp(x, y); | ||||||
|         break; |         break; | ||||||
| 
 | 
 | ||||||
|       default: |       default: | ||||||
|  | @ -1654,7 +1654,7 @@ rb_big_eq(VALUE x, VALUE y) | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
| 	break; | 	break; | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         return rb_big_float_cmp(x, y) == INT2FIX(0) ? Qtrue : Qfalse; |         return rb_integer_float_cmp(x, y) == INT2FIX(0) ? Qtrue : Qfalse; | ||||||
|       default: |       default: | ||||||
| 	return rb_equal(y, x); | 	return rb_equal(y, x); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -49,7 +49,7 @@ VALUE rb_ary_cat(VALUE, const VALUE *, long); | ||||||
| /* bignum.c */ | /* bignum.c */ | ||||||
| VALUE rb_big_fdiv(VALUE x, VALUE y); | VALUE rb_big_fdiv(VALUE x, VALUE y); | ||||||
| VALUE rb_big_uminus(VALUE x); | VALUE rb_big_uminus(VALUE x); | ||||||
| VALUE rb_big_float_cmp(VALUE x, VALUE y); | VALUE rb_integer_float_cmp(VALUE x, VALUE y); | ||||||
| 
 | 
 | ||||||
| /* class.c */ | /* class.c */ | ||||||
| VALUE rb_obj_methods(int argc, VALUE *argv, VALUE obj); | VALUE rb_obj_methods(int argc, VALUE *argv, VALUE obj); | ||||||
|  |  | ||||||
							
								
								
									
										24
									
								
								numeric.c
									
										
									
									
									
								
							
							
						
						
									
										24
									
								
								numeric.c
									
										
									
									
									
								
							|  | @ -1055,7 +1055,7 @@ flo_eq(VALUE x, VALUE y) | ||||||
|     switch (TYPE(y)) { |     switch (TYPE(y)) { | ||||||
|       case T_FIXNUM: |       case T_FIXNUM: | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
|         return rb_big_float_cmp(y, x) == INT2FIX(0) ? Qtrue : Qfalse; |         return rb_integer_float_cmp(y, x) == INT2FIX(0) ? Qtrue : Qfalse; | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
| 	b = RFLOAT_VALUE(y); | 	b = RFLOAT_VALUE(y); | ||||||
| #if defined(_MSC_VER) && _MSC_VER < 1300 | #if defined(_MSC_VER) && _MSC_VER < 1300 | ||||||
|  | @ -1123,7 +1123,7 @@ flo_cmp(VALUE x, VALUE y) | ||||||
|       case T_FIXNUM: |       case T_FIXNUM: | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
|       { |       { | ||||||
|         VALUE rel = rb_big_float_cmp(y, x); |         VALUE rel = rb_integer_float_cmp(y, x); | ||||||
|         if (FIXNUM_P(rel)) |         if (FIXNUM_P(rel)) | ||||||
|             return INT2FIX(-FIX2INT(rel)); |             return INT2FIX(-FIX2INT(rel)); | ||||||
|         return rel; |         return rel; | ||||||
|  | @ -1165,7 +1165,7 @@ flo_gt(VALUE x, VALUE y) | ||||||
|       case T_FIXNUM: |       case T_FIXNUM: | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
|       { |       { | ||||||
|         VALUE rel = rb_big_float_cmp(y, x); |         VALUE rel = rb_integer_float_cmp(y, x); | ||||||
|         if (FIXNUM_P(rel)) |         if (FIXNUM_P(rel)) | ||||||
|             return -FIX2INT(rel) > 0 ? Qtrue : Qfalse; |             return -FIX2INT(rel) > 0 ? Qtrue : Qfalse; | ||||||
|         return Qfalse; |         return Qfalse; | ||||||
|  | @ -1205,7 +1205,7 @@ flo_ge(VALUE x, VALUE y) | ||||||
|       case T_FIXNUM: |       case T_FIXNUM: | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
|       { |       { | ||||||
|         VALUE rel = rb_big_float_cmp(y, x); |         VALUE rel = rb_integer_float_cmp(y, x); | ||||||
|         if (FIXNUM_P(rel)) |         if (FIXNUM_P(rel)) | ||||||
|             return -FIX2INT(rel) >= 0 ? Qtrue : Qfalse; |             return -FIX2INT(rel) >= 0 ? Qtrue : Qfalse; | ||||||
|         return Qfalse; |         return Qfalse; | ||||||
|  | @ -1244,7 +1244,7 @@ flo_lt(VALUE x, VALUE y) | ||||||
|       case T_FIXNUM: |       case T_FIXNUM: | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
|       { |       { | ||||||
|         VALUE rel = rb_big_float_cmp(y, x); |         VALUE rel = rb_integer_float_cmp(y, x); | ||||||
|         if (FIXNUM_P(rel)) |         if (FIXNUM_P(rel)) | ||||||
|             return -FIX2INT(rel) < 0 ? Qtrue : Qfalse; |             return -FIX2INT(rel) < 0 ? Qtrue : Qfalse; | ||||||
|         return Qfalse; |         return Qfalse; | ||||||
|  | @ -1284,7 +1284,7 @@ flo_le(VALUE x, VALUE y) | ||||||
|       case T_FIXNUM: |       case T_FIXNUM: | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
|       { |       { | ||||||
|         VALUE rel = rb_big_float_cmp(y, x); |         VALUE rel = rb_integer_float_cmp(y, x); | ||||||
|         if (FIXNUM_P(rel)) |         if (FIXNUM_P(rel)) | ||||||
|             return -FIX2INT(rel) <= 0 ? Qtrue : Qfalse; |             return -FIX2INT(rel) <= 0 ? Qtrue : Qfalse; | ||||||
|         return Qfalse; |         return Qfalse; | ||||||
|  | @ -2947,7 +2947,7 @@ fix_equal(VALUE x, VALUE y) | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
| 	return rb_big_eq(y, x); | 	return rb_big_eq(y, x); | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         return rb_big_float_cmp(x, y) == INT2FIX(0) ? Qtrue : Qfalse; |         return rb_integer_float_cmp(x, y) == INT2FIX(0) ? Qtrue : Qfalse; | ||||||
|       default: |       default: | ||||||
| 	return num_equal(x, y); | 	return num_equal(x, y); | ||||||
|     } |     } | ||||||
|  | @ -2975,7 +2975,7 @@ fix_cmp(VALUE x, VALUE y) | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
| 	return rb_big_cmp(rb_int2big(FIX2LONG(x)), y); | 	return rb_big_cmp(rb_int2big(FIX2LONG(x)), y); | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         return rb_big_float_cmp(x, y); |         return rb_integer_float_cmp(x, y); | ||||||
|       default: |       default: | ||||||
| 	return rb_num_coerce_cmp(x, y, rb_intern("<=>")); | 	return rb_num_coerce_cmp(x, y, rb_intern("<=>")); | ||||||
|     } |     } | ||||||
|  | @ -3000,7 +3000,7 @@ fix_gt(VALUE x, VALUE y) | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
| 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) > 0 ? Qtrue : Qfalse; | 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) > 0 ? Qtrue : Qfalse; | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         return rb_big_float_cmp(x, y) == INT2FIX(1) ? Qtrue : Qfalse; |         return rb_integer_float_cmp(x, y) == INT2FIX(1) ? Qtrue : Qfalse; | ||||||
|       default: |       default: | ||||||
| 	return rb_num_coerce_relop(x, y, '>'); | 	return rb_num_coerce_relop(x, y, '>'); | ||||||
|     } |     } | ||||||
|  | @ -3026,7 +3026,7 @@ fix_ge(VALUE x, VALUE y) | ||||||
| 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) >= 0 ? Qtrue : Qfalse; | 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) >= 0 ? Qtrue : Qfalse; | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         { |         { | ||||||
|           VALUE rel = rb_big_float_cmp(x, y); |           VALUE rel = rb_integer_float_cmp(x, y); | ||||||
|           return rel == INT2FIX(1) || rel == INT2FIX(0) ? Qtrue : Qfalse; |           return rel == INT2FIX(1) || rel == INT2FIX(0) ? Qtrue : Qfalse; | ||||||
|         } |         } | ||||||
|       default: |       default: | ||||||
|  | @ -3053,7 +3053,7 @@ fix_lt(VALUE x, VALUE y) | ||||||
|       case T_BIGNUM: |       case T_BIGNUM: | ||||||
| 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) < 0 ? Qtrue : Qfalse; | 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) < 0 ? Qtrue : Qfalse; | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         return rb_big_float_cmp(x, y) == INT2FIX(-1) ? Qtrue : Qfalse; |         return rb_integer_float_cmp(x, y) == INT2FIX(-1) ? Qtrue : Qfalse; | ||||||
|       default: |       default: | ||||||
| 	return rb_num_coerce_relop(x, y, '<'); | 	return rb_num_coerce_relop(x, y, '<'); | ||||||
|     } |     } | ||||||
|  | @ -3079,7 +3079,7 @@ fix_le(VALUE x, VALUE y) | ||||||
| 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) <= 0 ? Qtrue : Qfalse; | 	return FIX2INT(rb_big_cmp(rb_int2big(FIX2LONG(x)), y)) <= 0 ? Qtrue : Qfalse; | ||||||
|       case T_FLOAT: |       case T_FLOAT: | ||||||
|         { |         { | ||||||
|           VALUE rel = rb_big_float_cmp(x, y); |           VALUE rel = rb_integer_float_cmp(x, y); | ||||||
|           return rel == INT2FIX(-1) || rel == INT2FIX(0) ? Qtrue : Qfalse; |           return rel == INT2FIX(-1) || rel == INT2FIX(0) ? Qtrue : Qfalse; | ||||||
|         } |         } | ||||||
|       default: |       default: | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 akr
						akr