mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
Removed assertion(), tweaked docs, added num_defined() and all_defined()
This commit is contained in:
parent
9a3e2b71f2
commit
80192c53ab
1 changed files with 21 additions and 38 deletions
59
compat.scad
59
compat.scad
|
@ -71,10 +71,21 @@ function remove_undefs(v) = [for (x = v) if (!is_undef(x)) x];
|
||||||
function first_defined(v) = remove_undefs(v)[0];
|
function first_defined(v) = remove_undefs(v)[0];
|
||||||
|
|
||||||
|
|
||||||
|
// Function: num_defined()
|
||||||
|
// Description: Counts how many items in list `v` are not `undef`.
|
||||||
|
function num_defined(v) = sum([for (x = v) is_undef(x)? 0 : 1]);
|
||||||
|
|
||||||
|
|
||||||
// Function: any_defined()
|
// Function: any_defined()
|
||||||
// Description:
|
// Description:
|
||||||
// Returns true if any item in the given array is not `undef`.
|
// Returns true if any item in the given array is not `undef`.
|
||||||
function any_defined(v) = len(remove_undefs(v))>0;
|
function any_defined(v) = num_defined(v)>0;
|
||||||
|
|
||||||
|
|
||||||
|
// Function: all_defined()
|
||||||
|
// Description:
|
||||||
|
// Returns true if all items in the given array are not `undef`.
|
||||||
|
function all_defined(v) = num_defined(v)==len(v);
|
||||||
|
|
||||||
|
|
||||||
// Function: scalar_vec3()
|
// Function: scalar_vec3()
|
||||||
|
@ -99,7 +110,7 @@ function scalar_vec3(v, dflt=undef) =
|
||||||
// Section: Modules
|
// Section: Modules
|
||||||
|
|
||||||
|
|
||||||
// Module: assert_in_list()
|
// Function&Module: assert_in_list()
|
||||||
// Usage:
|
// Usage:
|
||||||
// assert_in_list(argname, val, l, [idx]);
|
// assert_in_list(argname, val, l, [idx]);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -111,16 +122,7 @@ function scalar_vec3(v, dflt=undef) =
|
||||||
// l = The list to look for `val` in.
|
// l = The list to look for `val` in.
|
||||||
// idx = If given, and `l` is a list of lists, look for `val` in the given index of each sublist.
|
// idx = If given, and `l` is a list of lists, look for `val` in the given index of each sublist.
|
||||||
module assert_in_list(argname, val, l, idx=undef) {
|
module assert_in_list(argname, val, l, idx=undef) {
|
||||||
succ = search([val], l, num_returns_per_match=1, index_col_num=idx) != [[]];
|
dummy = assert_in_list(argname, val, l, idx);
|
||||||
if (!succ) {
|
|
||||||
msg = str(
|
|
||||||
"In argument '", argname, "', ",
|
|
||||||
(is_string(val)? str("\"", val, "\"") : val),
|
|
||||||
" must be one of ",
|
|
||||||
(!is_undef(idx)? [for (v=l) v[idx]] : l)
|
|
||||||
);
|
|
||||||
assertion(succ, msg);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function assert_in_list(argname, val, l, idx=undef) =
|
function assert_in_list(argname, val, l, idx=undef) =
|
||||||
|
@ -131,31 +133,12 @@ function assert_in_list(argname, val, l, idx=undef) =
|
||||||
(is_string(val)? str("\"", val, "\"") : val),
|
(is_string(val)? str("\"", val, "\"") : val),
|
||||||
" must be one of ",
|
" must be one of ",
|
||||||
(!is_undef(idx)? [for (v=l) v[idx]] : l)
|
(!is_undef(idx)? [for (v=l) v[idx]] : l)
|
||||||
)
|
),
|
||||||
) assertion(succ, msg);
|
FAILED=succ
|
||||||
|
) assert(FAILED, msg);
|
||||||
|
|
||||||
|
|
||||||
// Module: assertion()
|
// Function&Module: echo_error()
|
||||||
// Usage:
|
|
||||||
// assertion(succ, msg);
|
|
||||||
// Description:
|
|
||||||
// Backwards compatible assert() semi-replacement.
|
|
||||||
// If `succ` is false, then print an error with `msg`.
|
|
||||||
// You can also use this as a function call from a function.
|
|
||||||
// Arguments:
|
|
||||||
// succ = If this is `false`, trigger the assertion.
|
|
||||||
// msg = The message to emit if `succ` is `false`.
|
|
||||||
module assertion(succ, msg) {
|
|
||||||
// assert() will echo the variable name, and `succ` looks confusing there. So we store it in FAILED.
|
|
||||||
FAILED = succ;
|
|
||||||
assert(FAILED, msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
function assertion(succ, msg) =
|
|
||||||
let(FAILED=succ) assert(FAILED, msg);
|
|
||||||
|
|
||||||
|
|
||||||
// Module: echo_error()
|
|
||||||
// Usage:
|
// Usage:
|
||||||
// echo_error(msg, [pfx]);
|
// echo_error(msg, [pfx]);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -172,7 +155,7 @@ function echo_error(msg, pfx="ERROR") =
|
||||||
echo(str("<p style=\"background-color: #ffb0b0\"><b>", pfx, ":</b> ", msg, "</p>"));
|
echo(str("<p style=\"background-color: #ffb0b0\"><b>", pfx, ":</b> ", msg, "</p>"));
|
||||||
|
|
||||||
|
|
||||||
// Module: echo_warning()
|
// Function&Module: echo_warning()
|
||||||
// Usage:
|
// Usage:
|
||||||
// echo_warning(msg, [pfx]);
|
// echo_warning(msg, [pfx]);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -189,7 +172,7 @@ function echo_warning(msg, pfx="WARNING") =
|
||||||
echo(str("<p style=\"background-color: #ffffb0\"><b>", pfx, ":</b> ", msg, "</p>"));
|
echo(str("<p style=\"background-color: #ffffb0\"><b>", pfx, ":</b> ", msg, "</p>"));
|
||||||
|
|
||||||
|
|
||||||
// Module: deprecate()
|
// Function&Module: deprecate()
|
||||||
// Usage:
|
// Usage:
|
||||||
// deprecate(name, [suggest]);
|
// deprecate(name, [suggest]);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -220,7 +203,7 @@ function deprecate(name, suggest=undef) =
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
// Module: deprecate_argument()
|
// Function&Module: deprecate_argument()
|
||||||
// Usage:
|
// Usage:
|
||||||
// deprecate(name, arg, [suggest]);
|
// deprecate(name, arg, [suggest]);
|
||||||
// Description:
|
// Description:
|
||||||
|
|
Loading…
Reference in a new issue