mirror of
				https://github.com/janet-lang/janet
				synced 2025-10-25 04:37:42 +00:00 
			
		
		
		
	Differentiate total order comparison and numeric comparison
This commit is contained in:
		| @@ -296,7 +296,7 @@ int dst_modf(DstArgs args) { | |||||||
|  |  | ||||||
| /* Comparison */ | /* Comparison */ | ||||||
| #define DST_DEFINE_COMPARATOR(name, pred)\ | #define DST_DEFINE_COMPARATOR(name, pred)\ | ||||||
| static int dst_math_##name(DstArgs args) {\ | static int dst_##name(DstArgs args) {\ | ||||||
|     int32_t i;\ |     int32_t i;\ | ||||||
|     for (i = 0; i < args.n - 1; i++) {\ |     for (i = 0; i < args.n - 1; i++) {\ | ||||||
|         if (dst_compare(args.v[i], args.v[i+1]) pred) {\ |         if (dst_compare(args.v[i], args.v[i+1]) pred) {\ | ||||||
| @@ -314,7 +314,7 @@ DST_DEFINE_COMPARATOR(notdescending, > 0) | |||||||
| DST_DEFINE_COMPARATOR(notascending, < 0) | DST_DEFINE_COMPARATOR(notascending, < 0) | ||||||
|  |  | ||||||
| /* Boolean logic */ | /* Boolean logic */ | ||||||
| static int dst_math_equal(DstArgs args) { | static int dst_strict_equal(DstArgs args) { | ||||||
|     int32_t i; |     int32_t i; | ||||||
|     for (i = 0; i < args.n - 1; i++) { |     for (i = 0; i < args.n - 1; i++) { | ||||||
|         if (!dst_equals(args.v[i], args.v[i+1])) { |         if (!dst_equals(args.v[i], args.v[i+1])) { | ||||||
| @@ -326,7 +326,7 @@ static int dst_math_equal(DstArgs args) { | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| static int dst_math_notequal(DstArgs args) { | static int dst_strict_notequal(DstArgs args) { | ||||||
|     int32_t i; |     int32_t i; | ||||||
|     for (i = 0; i < args.n - 1; i++) { |     for (i = 0; i < args.n - 1; i++) { | ||||||
|         if (dst_equals(args.v[i], args.v[i+1])) { |         if (dst_equals(args.v[i], args.v[i+1])) { | ||||||
| @@ -338,11 +338,46 @@ static int dst_math_notequal(DstArgs args) { | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| static int dst_math_not(DstArgs args) { | static int dst_not(DstArgs args) { | ||||||
|     *args.ret = dst_wrap_boolean(args.n == 0 || !dst_truthy(args.v[0])); |     *args.ret = dst_wrap_boolean(args.n == 0 || !dst_truthy(args.v[0])); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static int toreal(Dst x, double *out) { | ||||||
|  |     if (dst_checktype(x, DST_REAL)) { | ||||||
|  |         *out = dst_unwrap_real(x); | ||||||
|  |         return 0; | ||||||
|  |     } else if (dst_checktype(x, DST_INTEGER)) { | ||||||
|  |         *out = (double)dst_unwrap_integer(x); | ||||||
|  |         return 0; | ||||||
|  |     } else { | ||||||
|  |         return -1; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #define DEF_NUMERIC_COMP(name, op) \ | ||||||
|  | int dst_numeric_##name(DstArgs args) { \ | ||||||
|  |     int32_t i; \ | ||||||
|  |     for (i = 1; i < args.n; i++) { \ | ||||||
|  |         int xbad, ybad; \ | ||||||
|  |         double x, y; \ | ||||||
|  |         xbad = toreal(args.v[0], &x); \ | ||||||
|  |         ybad = toreal(args.v[1], &y); \ | ||||||
|  |         if (xbad | ybad) return dst_throw(args, "expected number"); \ | ||||||
|  |         if (!(x op y)) { \ | ||||||
|  |             return dst_return(args, dst_wrap_false()); \ | ||||||
|  |         } \ | ||||||
|  |     } \ | ||||||
|  |     return dst_return(args, dst_wrap_true()); \ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | DEF_NUMERIC_COMP(gt, >) | ||||||
|  | DEF_NUMERIC_COMP(lt, <) | ||||||
|  | DEF_NUMERIC_COMP(lte, <=) | ||||||
|  | DEF_NUMERIC_COMP(gte, >=) | ||||||
|  | DEF_NUMERIC_COMP(eq, ==) | ||||||
|  | DEF_NUMERIC_COMP(neq, !=) | ||||||
|  |  | ||||||
| static const DstReg cfuns[] = { | static const DstReg cfuns[] = { | ||||||
|     {"int", dst_int}, |     {"int", dst_int}, | ||||||
|     {"real", dst_real}, |     {"real", dst_real}, | ||||||
| @@ -351,12 +386,18 @@ static const DstReg cfuns[] = { | |||||||
|     {"*", dst_multiply}, |     {"*", dst_multiply}, | ||||||
|     {"/", dst_divide}, |     {"/", dst_divide}, | ||||||
|     {"%", dst_modulo}, |     {"%", dst_modulo}, | ||||||
|     {"=", dst_math_equal}, |     {"=", dst_strict_equal}, | ||||||
|     {"not=", dst_math_notequal}, |     {"not=", dst_strict_notequal}, | ||||||
|     {"<", dst_math_ascending}, |     {"order<", dst_ascending}, | ||||||
|     {">", dst_math_descending}, |     {"order>", dst_descending}, | ||||||
|     {"<=", dst_math_notdescending}, |     {"order<=", dst_notdescending}, | ||||||
|     {">=", dst_math_notascending}, |     {"order>=", dst_notascending}, | ||||||
|  |     {"==", dst_numeric_eq}, | ||||||
|  |     {"not==", dst_numeric_neq}, | ||||||
|  |     {"<", dst_numeric_lt}, | ||||||
|  |     {">", dst_numeric_gt}, | ||||||
|  |     {"<=", dst_numeric_lte}, | ||||||
|  |     {">=", dst_numeric_gte}, | ||||||
|     {"|", dst_bor}, |     {"|", dst_bor}, | ||||||
|     {"&", dst_band}, |     {"&", dst_band}, | ||||||
|     {"^", dst_bxor}, |     {"^", dst_bxor}, | ||||||
| @@ -364,7 +405,7 @@ static const DstReg cfuns[] = { | |||||||
|     {">>", dst_lshift}, |     {">>", dst_lshift}, | ||||||
|     {"<<", dst_rshift}, |     {"<<", dst_rshift}, | ||||||
|     {">>>", dst_lshiftu}, |     {">>>", dst_lshiftu}, | ||||||
|     {"not", dst_math_not}, |     {"not", dst_not}, | ||||||
|     {"cos", dst_cos}, |     {"cos", dst_cos}, | ||||||
|     {"sin", dst_sin}, |     {"sin", dst_sin}, | ||||||
|     {"tan", dst_tan}, |     {"tan", dst_tan}, | ||||||
|   | |||||||
| @@ -118,7 +118,6 @@ int dst_compare(Dst x, Dst y) { | |||||||
|             case DST_TRUE: |             case DST_TRUE: | ||||||
|                 return 0; |                 return 0; | ||||||
|             case DST_REAL: |             case DST_REAL: | ||||||
|                  |  | ||||||
|                 /* Check for nans to ensure total order */ |                 /* Check for nans to ensure total order */ | ||||||
|                 if (dst_unwrap_real(x) != dst_unwrap_real(x)) |                 if (dst_unwrap_real(x) != dst_unwrap_real(x)) | ||||||
|                     return dst_unwrap_real(y) != dst_unwrap_real(y) |                     return dst_unwrap_real(y) != dst_unwrap_real(y) | ||||||
|   | |||||||
| @@ -40,12 +40,18 @@ int dst_subtract(DstArgs args); | |||||||
| int dst_multiply(DstArgs args); | int dst_multiply(DstArgs args); | ||||||
| int dst_divide(DstArgs args); | int dst_divide(DstArgs args); | ||||||
| int dst_modulo(DstArgs args); | int dst_modulo(DstArgs args); | ||||||
| int dst_math_equal(DstArgs args); | int dst_strict_equal(DstArgs args); | ||||||
| int dst_math_notequal(DstArgs args); | int dst_strict_notequal(DstArgs args); | ||||||
| int dst_math_ascending(DstArgs args); | int dst_ascending(DstArgs args); | ||||||
| int dst_math_descending(DstArgs args); | int dst_descending(DstArgs args); | ||||||
| int dst_math_notdescending(DstArgs args); | int dst_notdescending(DstArgs args); | ||||||
| int dst_math_notascending(DstArgs args); | int dst_notascending(DstArgs args); | ||||||
|  | int dst_numeric_eq(DstArgs args); | ||||||
|  | int dst_numeric_neq(DstArgs args); | ||||||
|  | int dst_numeric_gt(DstArgs args); | ||||||
|  | int dst_numeric_lt(DstArgs args); | ||||||
|  | int dst_numeric_gte(DstArgs args); | ||||||
|  | int dst_numeric_lte(DstArgs args); | ||||||
| int dst_bor(DstArgs args); | int dst_bor(DstArgs args); | ||||||
| int dst_band(DstArgs args); | int dst_band(DstArgs args); | ||||||
| int dst_bxor(DstArgs args); | int dst_bxor(DstArgs args); | ||||||
| @@ -53,7 +59,7 @@ int dst_bnot(DstArgs args); | |||||||
| int dst_lshift(DstArgs args); | int dst_lshift(DstArgs args); | ||||||
| int dst_rshift(DstArgs args); | int dst_rshift(DstArgs args); | ||||||
| int dst_lshiftu(DstArgs args); | int dst_lshiftu(DstArgs args); | ||||||
| int dst_math_not(DstArgs args); | int dst_not(DstArgs args); | ||||||
| int dst_cos(DstArgs args); | int dst_cos(DstArgs args); | ||||||
| int dst_sin(DstArgs args); | int dst_sin(DstArgs args); | ||||||
| int dst_tan(DstArgs args); | int dst_tan(DstArgs args); | ||||||
|   | |||||||
| @@ -47,7 +47,7 @@ | |||||||
| (assert (>= 6 5 4 4 3 2 1) "greater than or equal to integers") | (assert (>= 6 5 4 4 3 2 1) "greater than or equal to integers") | ||||||
| (assert (>= 6.0 5.0 4.0 4.0 3.0 2.0 1.0) "greater than or equal to reals") | (assert (>= 6.0 5.0 4.0 4.0 3.0 2.0 1.0) "greater than or equal to reals") | ||||||
|  |  | ||||||
| (assert (< nil false true | (assert (order< nil false true | ||||||
| 	(fiber (fn [x] x)) | 	(fiber (fn [x] x)) | ||||||
|     1 1.0 "hi" |     1 1.0 "hi" | ||||||
| 	(quote hello) | 	(quote hello) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 bakpakin
					bakpakin