mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-21 03:49:38 +00:00
Merge remote-tracking branch 'upstream/revarbat_dev'
This commit is contained in:
commit
5b83107023
2 changed files with 731 additions and 2 deletions
197
fnliterals.scad
197
fnliterals.scad
|
@ -467,7 +467,7 @@ function f_2arg(func) =
|
|||
// fn_va4 = f_lt(a=p1,c=p2); // = function() vector_angle(p1,b,p2);
|
||||
function f_3arg(func) =
|
||||
function(a,b,c)
|
||||
a==undef && b==undef && c==undef? func :
|
||||
a==undef && b==undef && c==undef? function(x,y,z) func(x,y,z) :
|
||||
a==undef && b==undef? function(x,y) func(x,y,c) :
|
||||
a==undef && c==undef? function(x,y) func(x,b,y) :
|
||||
b==undef && c==undef? function(x,y) func(a,x,y) :
|
||||
|
@ -1442,4 +1442,199 @@ function f_norm(a) = f_1arg(function(a) norm(a))(a);
|
|||
function f_cross(a,b) = f_2arg(function(a,b) cross(a,b))(a,b);
|
||||
|
||||
|
||||
// Section: Type Queries
|
||||
|
||||
// Function: f_is_def()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_def();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_def(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_string(), f_is_list()
|
||||
function f_is_def(x) = f_1arg(function (x) is_def(x));
|
||||
|
||||
|
||||
// Function: f_is_undef()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_undef();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_undef(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_bool(), f_is_num(), f_is_string(), f_is_list()
|
||||
function f_is_undef(x) = f_1arg(function (x) is_undef(x));
|
||||
|
||||
|
||||
// Function: f_is_bool()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_bool();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_bool(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_num(), f_is_string(), f_is_list()
|
||||
function f_is_bool(x) = f_1arg(function (x) is_bool(x));
|
||||
|
||||
|
||||
// Function: f_is_num()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_num();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_num(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_string(), f_is_list()
|
||||
function f_is_num(x) = f_1arg(function (x) is_num(x));
|
||||
|
||||
|
||||
// Function: f_is_int()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_int();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_int(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_string(), f_is_list()
|
||||
function f_is_int(x) = f_1arg(function (x) is_int(x));
|
||||
|
||||
|
||||
// Function: f_is_nan()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_nan();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_nan(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_nan(x) = f_1arg(function (x) is_nan(x));
|
||||
|
||||
|
||||
// Function: f_is_finite()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_finite();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_finite(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_finite(x) = f_1arg(function (x) is_finite(x));
|
||||
|
||||
|
||||
// Function: f_is_string()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_string();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_string(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_list()
|
||||
function f_is_string(x) = f_1arg(function (x) is_string(x));
|
||||
|
||||
|
||||
// Function: f_is_list()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_list();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_list(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_list(x) = f_1arg(function (x) is_list(x));
|
||||
|
||||
|
||||
// Function: f_is_range()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_range();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_range(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_range(x) = f_1arg(function (x) is_range(x));
|
||||
|
||||
|
||||
// Function: f_is_function()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_function();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_function(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_function(x) = f_1arg(function (x) is_function(x));
|
||||
|
||||
|
||||
// Function: f_is_vector()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_vector();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_vector(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_vector(a,b) = f_2arg(function (a,b) is_vector(a,b));
|
||||
|
||||
|
||||
// Function: f_is_path()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_path();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_path(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_path(a,b) = f_2arg(function (a,b) is_path(a,b));
|
||||
|
||||
|
||||
// Function: f_is_region()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_region();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_region(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_region(a) = f_1arg(function (a) is_region(a));
|
||||
|
||||
|
||||
// Function: f_is_vnf()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_vnf();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_vnf(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_vnf(a) = f_1arg(function (a) is_vnf(a));
|
||||
|
||||
|
||||
// Function: f_is_patch()
|
||||
// Topics: Function Literals, Type Queries
|
||||
// Usage:
|
||||
// fn = f_is_patch();
|
||||
// Description:
|
||||
// A factory that returns function literals equivalent to `is_patch(a)`.
|
||||
// Arguments:
|
||||
// a = If given, replaces the argument.
|
||||
// See Also: f_is_undef(), f_is_bool(), f_is_num(), f_is_int(), f_is_string(), f_is_list()
|
||||
function f_is_patch(a) = f_1arg(function (a) is_patch(a));
|
||||
|
||||
|
||||
|
||||
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
||||
|
|
|
@ -150,7 +150,7 @@ test_f_2arg();
|
|||
|
||||
|
||||
module test_f_3arg() {
|
||||
assert_equal(str(f_3arg(function (a,b,c) a+b+c)), "function(a, b, c) ((((a == undef) && (b == undef)) && (c == undef)) ? func : (((a == undef) && (b == undef)) ? function(x, y) func(x, y, c) : (((a == undef) && (c == undef)) ? function(x, y) func(x, b, y) : (((b == undef) && (c == undef)) ? function(x, y) func(a, x, y) : ((a == undef) ? function(x) func(x, b, c) : ((b == undef) ? function(x) func(a, x, c) : ((c == undef) ? function(x) func(a, b, x) : function() func(a, b, c))))))))");
|
||||
assert_equal(str(f_3arg(function (a,b,c) a+b+c)), "function(a, b, c) ((((a == undef) && (b == undef)) && (c == undef)) ? function(x, y, z) func(x, y, z) : (((a == undef) && (b == undef)) ? function(x, y) func(x, y, c) : (((a == undef) && (c == undef)) ? function(x, y) func(x, b, y) : (((b == undef) && (c == undef)) ? function(x, y) func(a, x, y) : ((a == undef) ? function(x) func(x, b, c) : ((b == undef) ? function(x) func(a, x, c) : ((c == undef) ? function(x) func(a, b, x) : function() func(a, b, c))))))))");
|
||||
assert_equal(str(f_3arg(function (a,b,c) a+b+c)(3)), "function(x, y) func(a, x, y)");
|
||||
assert_equal(str(f_3arg(function (a,b,c) a+b+c)(3,4)), "function(x) func(a, b, x)");
|
||||
assert_equal(str(f_3arg(function (a,b,c) a+b+c)(3,4,1)), "function() func(a, b, c)");
|
||||
|
@ -210,6 +210,36 @@ module _test_fn2arg(dafunc,tests) {
|
|||
}
|
||||
|
||||
|
||||
module _test_fn3arg(dafunc,tests) {
|
||||
assert_equal(str(dafunc()), "function(x, y, z) func(x, y, z)");
|
||||
assert_equal(str(dafunc(3)), "function(x, y) func(a, x, y)");
|
||||
assert_equal(str(dafunc(a=3)), "function(x, y) func(a, x, y)");
|
||||
assert_equal(str(dafunc(b=3)), "function(x, y) func(x, b, y)");
|
||||
assert_equal(str(dafunc(c=3)), "function(x, y) func(x, y, c)");
|
||||
assert_equal(str(dafunc(3,4)), "function(x) func(a, b, x)");
|
||||
assert_equal(str(dafunc(a=3,b=4)), "function(x) func(a, b, x)");
|
||||
assert_equal(str(dafunc(a=3,c=4)), "function(x) func(a, x, c)");
|
||||
assert_equal(str(dafunc(b=3,c=4)), "function(x) func(x, b, c)");
|
||||
assert_equal(str(dafunc(3,4,5)), "function() func(a, b, c)");
|
||||
for (test = tests) {
|
||||
a = test[0];
|
||||
b = test[1];
|
||||
c = test[2];
|
||||
r = test[3];
|
||||
assert_equal(dafunc(a=a,b=b,c=c)(), r);
|
||||
assert_equal(dafunc(a,b,c)(), r);
|
||||
assert_equal(dafunc(a)(b,c), r);
|
||||
assert_equal(dafunc(b=b,c=c)(a), r);
|
||||
assert_equal(dafunc(a=a,c=c)(b), r);
|
||||
assert_equal(dafunc(a=a,b=b)(c), r);
|
||||
assert_equal(dafunc(a=a)(b,c), r);
|
||||
assert_equal(dafunc(b=b)(a,c), r);
|
||||
assert_equal(dafunc(c=c)(a,b), r);
|
||||
assert_equal(dafunc()(a,b,c), r);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
module test_f_cmp() {
|
||||
_test_fn2arg(
|
||||
function (a,b) f_cmp(a,b),
|
||||
|
@ -461,5 +491,509 @@ module test_f_pow() {
|
|||
test_f_pow();
|
||||
|
||||
|
||||
module test_f_sin() {
|
||||
_test_fn1arg(
|
||||
function (a) f_sin(a),
|
||||
[[-270,1],[-180,0],[-90,-1],[0,0],[90,1],[180,0],[270,-1],[360,0]]
|
||||
);
|
||||
}
|
||||
test_f_sin();
|
||||
|
||||
|
||||
module test_f_cos() {
|
||||
_test_fn1arg(
|
||||
function (a) f_cos(a),
|
||||
[[-270,0],[-180,-1],[-90,0],[0,1],[90,0],[180,-1],[270,0],[360,1]]
|
||||
);
|
||||
}
|
||||
test_f_cos();
|
||||
|
||||
|
||||
module test_f_tan() {
|
||||
_test_fn1arg(
|
||||
function (a) f_tan(a),
|
||||
[[-135,1],[-45,-1],[0,0],[45,1],[135,-1]]
|
||||
);
|
||||
}
|
||||
test_f_tan();
|
||||
|
||||
|
||||
module test_f_asin() {
|
||||
_test_fn1arg(
|
||||
function (a) f_asin(a),
|
||||
[[-1,-90],[0,0],[1,90]]
|
||||
);
|
||||
}
|
||||
test_f_asin();
|
||||
|
||||
|
||||
module test_f_acos() {
|
||||
_test_fn1arg(
|
||||
function (a) f_acos(a),
|
||||
[[-1,180],[-0.5,120],[0,90],[0.5,60],[1,0]]
|
||||
);
|
||||
}
|
||||
test_f_acos();
|
||||
|
||||
|
||||
module test_f_atan() {
|
||||
_test_fn1arg(
|
||||
function (a) f_atan(a),
|
||||
[[-1,-45],[0,0],[1,45]]
|
||||
);
|
||||
}
|
||||
test_f_atan();
|
||||
|
||||
|
||||
module test_f_atan2() {
|
||||
_test_fn2arg(
|
||||
function (a,b) f_atan2(a,b),
|
||||
[[-1,0,-90],[-1,1,-45],[0,1,0],[1,0,90],[1,1,45]]
|
||||
);
|
||||
}
|
||||
test_f_atan();
|
||||
|
||||
|
||||
module test_f_exp() {
|
||||
_test_fn1arg(
|
||||
function (a) f_exp(a),
|
||||
[[-1,exp(-1)],[0,1],[1,exp(1)]]
|
||||
);
|
||||
}
|
||||
test_f_exp();
|
||||
|
||||
|
||||
module test_f_ln() {
|
||||
_test_fn1arg(
|
||||
function (a) f_ln(a),
|
||||
[[1,0],[1,ln(1)],[10,ln(10)]]
|
||||
);
|
||||
}
|
||||
test_f_ln();
|
||||
|
||||
|
||||
module test_f_log() {
|
||||
_test_fn1arg(
|
||||
function (a) f_log(a),
|
||||
[[1,0],[100,2],[10000,4]]
|
||||
);
|
||||
}
|
||||
test_f_log();
|
||||
|
||||
|
||||
module test_f_sqr() {
|
||||
_test_fn1arg(
|
||||
function (a) f_sqr(a),
|
||||
[[-5,25],[5,25],[9,81]]
|
||||
);
|
||||
}
|
||||
test_f_sqr();
|
||||
|
||||
|
||||
module test_f_sqrt() {
|
||||
_test_fn1arg(
|
||||
function (a) f_sqrt(a),
|
||||
[[25,5],[16,4],[81,9]]
|
||||
);
|
||||
}
|
||||
test_f_sqrt();
|
||||
|
||||
|
||||
module test_f_sign() {
|
||||
_test_fn1arg(
|
||||
function (a) f_sign(a),
|
||||
[[-99,-1],[-1,-1],[0,0],[1,1],[99,1]]
|
||||
);
|
||||
}
|
||||
test_f_sign();
|
||||
|
||||
|
||||
module test_f_abs() {
|
||||
_test_fn1arg(
|
||||
function (a) f_abs(a),
|
||||
[[-99,99],[-1,1],[0,0],[1,1],[99,99]]
|
||||
);
|
||||
}
|
||||
test_f_abs();
|
||||
|
||||
|
||||
module test_f_neg() {
|
||||
_test_fn1arg(
|
||||
function (a) f_neg(a),
|
||||
[[-99,99],[-1,1],[0,0],[1,-1],[99,-99]]
|
||||
);
|
||||
}
|
||||
test_f_neg();
|
||||
|
||||
|
||||
module test_f_ceil() {
|
||||
_test_fn1arg(
|
||||
function (a) f_ceil(a),
|
||||
[[-9.9,-9],[-9.1,-9],[-1,-1],[0,0],[1,1],[1.1,2],[1.9,2],[9.1,10],[9.9,10]]
|
||||
);
|
||||
}
|
||||
test_f_ceil();
|
||||
|
||||
|
||||
module test_f_floor() {
|
||||
_test_fn1arg(
|
||||
function (a) f_floor(a),
|
||||
[[-9.9,-10],[-9.1,-10],[-1,-1],[0,0],[1,1],[1.1,1],[1.9,1],[9.1,9],[9.9,9]]
|
||||
);
|
||||
}
|
||||
test_f_floor();
|
||||
|
||||
|
||||
module test_f_round() {
|
||||
_test_fn1arg(
|
||||
function (a) f_round(a),
|
||||
[[-9.9,-10],[-9.5,-10],[-9.1,-9],[-1,-1],[0,0],[1,1],[1.1,1],[1.9,2],[9.1,9],[9.5,10],[9.9,10]]
|
||||
);
|
||||
}
|
||||
test_f_round();
|
||||
|
||||
|
||||
module test_f_cross() {
|
||||
_test_fn2arg(
|
||||
function (a,b) f_cross(a,b),
|
||||
[[UP,LEFT,FWD], [BACK+RIGHT,FWD,DOWN]]
|
||||
);
|
||||
}
|
||||
test_f_cross();
|
||||
|
||||
|
||||
module test_f_norm() {
|
||||
_test_fn1arg(
|
||||
function (a) f_norm(a),
|
||||
[[UP,1], [BACK+RIGHT,sqrt(2)], [[3,4],5]]
|
||||
);
|
||||
}
|
||||
test_f_norm();
|
||||
|
||||
|
||||
module test_f_chr() {
|
||||
_test_fn1arg(
|
||||
function (a) f_chr(a),
|
||||
[[65,"A"],[97,"a"],[70,"F"],[102,"f"],[48,"0"],[57,"9"]]
|
||||
);
|
||||
}
|
||||
test_f_chr();
|
||||
|
||||
|
||||
module test_f_ord() {
|
||||
_test_fn1arg(
|
||||
function (a) f_ord(a),
|
||||
[["A",65],["a",97],["F",70],["f",102],["0",48],["9",57]]
|
||||
);
|
||||
}
|
||||
test_f_ord();
|
||||
|
||||
|
||||
module test_f_len() {
|
||||
_test_fn1arg(
|
||||
function (a) f_len(a),
|
||||
[["A",1],["abc",3],["foobar",6],["freeb",5],["",0],["9",1]]
|
||||
);
|
||||
}
|
||||
test_f_len();
|
||||
|
||||
|
||||
module test_f_str() {
|
||||
_test_fn1arg(
|
||||
function (a) f_str(a),
|
||||
[[123,"123"],[true,"true"],[false,"false"],[undef,"undef"],[3.14159,"3.14159"],[[3,4,5,true],"[3, 4, 5, true]"]]
|
||||
);
|
||||
}
|
||||
test_f_str();
|
||||
|
||||
|
||||
module test_f_str2() {
|
||||
_test_fn2arg(
|
||||
function (a,b) f_str2(a,b),
|
||||
[[12,34,"1234"], [[3,4,5,true],"foo","[3, 4, 5, true]foo"], ["foo","bar","foobar"]]
|
||||
);
|
||||
}
|
||||
test_f_str2();
|
||||
|
||||
|
||||
module test_f_str3() {
|
||||
_test_fn3arg(
|
||||
function (a,b,c) f_str3(a,b,c),
|
||||
[[12,34,56,"123456"], [[3,4,5,true],"foo","bar","[3, 4, 5, true]foobar"], ["foo",88,"baz","foo88baz"]]
|
||||
);
|
||||
}
|
||||
test_f_str3();
|
||||
|
||||
|
||||
module test_f_min() {
|
||||
_test_fn1arg(
|
||||
function (a) f_min(a),
|
||||
[[[8,3,7,4],3], [[-4,-5,-6,-7],-7], [[4,8,2,-3,3,8,0,-5,9,6],-5]]
|
||||
);
|
||||
}
|
||||
test_f_min();
|
||||
|
||||
|
||||
module test_f_max() {
|
||||
_test_fn1arg(
|
||||
function (a) f_max(a),
|
||||
[[[8,3,7,4],8], [[-4,-5,-6,-7],-4], [[4,8,2,-3,3,8,0,-5,9,6],9]]
|
||||
);
|
||||
}
|
||||
test_f_max();
|
||||
|
||||
|
||||
module test_f_min2() {
|
||||
_test_fn2arg(
|
||||
function (a,b) f_min2(a,b),
|
||||
[[8,3,3], [-6,-7,-7], [-4,13,-4]]
|
||||
);
|
||||
}
|
||||
test_f_min2();
|
||||
|
||||
|
||||
module test_f_max2() {
|
||||
_test_fn2arg(
|
||||
function (a,b) f_max2(a,b),
|
||||
[[8,3,8], [-4,-5,-4], [-3,7,7]]
|
||||
);
|
||||
}
|
||||
test_f_max2();
|
||||
|
||||
|
||||
module test_f_min3() {
|
||||
_test_fn3arg(
|
||||
function (a,b,c) f_min3(a,b,c),
|
||||
[[8,3,5,3], [-6,-7,5,-7], [-4,13,5,-4]]
|
||||
);
|
||||
}
|
||||
test_f_min3();
|
||||
|
||||
|
||||
module test_f_max3() {
|
||||
_test_fn3arg(
|
||||
function (a,b,c) f_max3(a,b,c),
|
||||
[[8,3,5,8], [-4,-5,4,4], [-3,7,4,7]]
|
||||
);
|
||||
}
|
||||
test_f_max3();
|
||||
|
||||
|
||||
module test_f_is_bool() {
|
||||
testfn = f_is_bool();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, true],
|
||||
[true, true],
|
||||
[0, false],
|
||||
[3, false],
|
||||
["foo", false],
|
||||
[[4,5,6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_bool();
|
||||
|
||||
|
||||
module test_f_is_def() {
|
||||
testfn = f_is_def();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, true],
|
||||
[true, true],
|
||||
[0, true],
|
||||
[3, true],
|
||||
["foo", true],
|
||||
[[4,5,6], true]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_def();
|
||||
|
||||
|
||||
module test_f_is_undef() {
|
||||
testfn = f_is_undef();
|
||||
for (test = [
|
||||
[undef, true],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[0, false],
|
||||
[3, false],
|
||||
["foo", false],
|
||||
[[4,5,6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_undef();
|
||||
|
||||
|
||||
module test_f_is_num() {
|
||||
testfn = f_is_num();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4.5, true],
|
||||
[-4, true],
|
||||
[0, true],
|
||||
[1.5, true],
|
||||
[3, true],
|
||||
[INF, true],
|
||||
[-INF, true],
|
||||
[NAN, false],
|
||||
["foo", false],
|
||||
[[4,5,6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_num();
|
||||
|
||||
|
||||
module test_f_is_int() {
|
||||
testfn = f_is_int();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4, true],
|
||||
[-4.5, false],
|
||||
[0, true],
|
||||
[1.5, false],
|
||||
[3, true],
|
||||
[INF, false],
|
||||
[-INF, false],
|
||||
[NAN, false],
|
||||
["foo", false],
|
||||
[[4,5,6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_int();
|
||||
|
||||
|
||||
module test_f_is_nan() {
|
||||
testfn = f_is_nan();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4, false],
|
||||
[-4.5, false],
|
||||
[0, false],
|
||||
[1.5, false],
|
||||
[3, false],
|
||||
[INF, false],
|
||||
[-INF, false],
|
||||
[NAN, true],
|
||||
["foo", false],
|
||||
[[4,5,6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_nan();
|
||||
|
||||
|
||||
module test_f_is_finite() {
|
||||
testfn = f_is_finite();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4, true],
|
||||
[0, true],
|
||||
[1.5, true],
|
||||
[3, true],
|
||||
[INF, false],
|
||||
[-INF, false],
|
||||
[NAN, false],
|
||||
["foo", false],
|
||||
[[4,5,6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_finite();
|
||||
|
||||
|
||||
module test_f_is_string() {
|
||||
testfn = f_is_string();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4, false],
|
||||
[0, false],
|
||||
[1.5, false],
|
||||
[3, false],
|
||||
[INF, false],
|
||||
[-INF, false],
|
||||
[NAN, false],
|
||||
["", true],
|
||||
["foo", true],
|
||||
[[4,5,6], false],
|
||||
[[4:1:6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_string();
|
||||
|
||||
|
||||
module test_f_is_list() {
|
||||
testfn = f_is_list();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4, false],
|
||||
[0, false],
|
||||
[1.5, false],
|
||||
[3, false],
|
||||
[INF, false],
|
||||
[-INF, false],
|
||||
[NAN, false],
|
||||
["", false],
|
||||
["foo", false],
|
||||
[[4,5,6], true],
|
||||
[[4:1:6], false]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_list();
|
||||
|
||||
|
||||
module test_f_is_path() {
|
||||
testfn = f_is_path();
|
||||
for (test = [
|
||||
[undef, false],
|
||||
[false, false],
|
||||
[true, false],
|
||||
[-4, false],
|
||||
[0, false],
|
||||
[1.5, false],
|
||||
[3, false],
|
||||
[INF, false],
|
||||
[-INF, false],
|
||||
[NAN, false],
|
||||
["", false],
|
||||
["foo", false],
|
||||
[[4,5,6], false],
|
||||
[[4:1:6], false],
|
||||
[square(100), true],
|
||||
[circle(100), true]
|
||||
]) {
|
||||
assert(testfn(test[0]), test[1]);
|
||||
}
|
||||
}
|
||||
test_f_is_path();
|
||||
|
||||
|
||||
|
||||
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
||||
|
|
Loading…
Reference in a new issue