Tweaked version number for using assert() and functional echo()

This commit is contained in:
Revar Desmera 2019-03-27 02:33:52 -07:00
parent 4aabbe200e
commit 0fa53eee96

View file

@ -52,27 +52,27 @@ function default(v,dflt=undef) = v==undef? dflt : v;
// Function: is_def() // Function: is_def()
// Description: Returns true if given value is not `undef`. // Description: Returns true if given value is not `undef`.
function is_def(v) = (version_num()>=20190303)? !is_undef(v) : (v != undef); function is_def(v) = (version_num() >= 20190100)? !is_undef(v) : (v != undef);
// Function: is_str() // Function: is_str()
// Description: Given a value, returns true if it is a string. // Description: Given a value, returns true if it is a string.
function is_str(v) = (version_num()>=20190303)? is_string(v) : (is_def(v) && is_def(len(v)) && (len(str(v,v)) == len(v)*2)); function is_str(v) = (version_num() >= 20190100)? is_string(v) : (is_def(v) && is_def(len(v)) && (len(str(v,v)) == len(v)*2));
// Function: is_boolean() // Function: is_boolean()
// Description: Given a value, returns true if it is a boolean. // Description: Given a value, returns true if it is a boolean.
function is_boolean(v) = (version_num()>=20190303)? is_bool(v) : (!is_str(v) && (str(v) == "true" || str(v) == "false")); function is_boolean(v) = (version_num() >= 20190100)? is_bool(v) : (!is_str(v) && (str(v) == "true" || str(v) == "false"));
// Function: is_scalar() // Function: is_scalar()
// Description: Given a value, returns true if it is a scalar number. // Description: Given a value, returns true if it is a scalar number.
function is_scalar(v) = (version_num()>=20190303)? is_num(v) : (!is_boolean(v) && is_def(v+0)); function is_scalar(v) = (version_num() >= 20190100)? is_num(v) : (!is_boolean(v) && is_def(v+0));
// Function: is_array() // Function: is_array()
// Description: Given a value, returns true if it is an array/list/vector. // Description: Given a value, returns true if it is an array/list/vector.
function is_array(v) = (version_num()>=20190303)? is_list(v) : (!is_str(v) && is_def(len(v))); function is_array(v) = (version_num() >= 20190100)? is_list(v) : (!is_str(v) && is_def(len(v)));
// Function: get_radius() // Function: get_radius()
@ -140,7 +140,7 @@ function scalar_vec3(v, dflt=undef) =
// Function: f_echo() // Function: f_echo()
// Description: If possible, echo a message from a function. // Description: If possible, echo a message from a function.
function f_echo(msg) = (version_num() >= 20190303)? echo(msg) : 0; function f_echo(msg) = (version_num() >= 20190100)? echo(msg) : 0;
// Section: Modules // Section: Modules
@ -151,6 +151,7 @@ function f_echo(msg) = (version_num() >= 20190303)? echo(msg) : 0;
// assert_in_list(argname, val, l, [idx]); // assert_in_list(argname, val, l, [idx]);
// Description: // Description:
// Emulates the newer OpenSCAD `assert()` with an `in_list()` test. // Emulates the newer OpenSCAD `assert()` with an `in_list()` test.
// You can also use this as a function call from a function.
// Arguments: // Arguments:
// argname = The name of the argument value being tested. // argname = The name of the argument value being tested.
// val = The value to test if it exists in the list. // val = The value to test if it exists in the list.
@ -185,12 +186,14 @@ function assert_in_list(argname, val, l, idx=undef) =
// Usage: // Usage:
// assertion(succ, msg); // assertion(succ, msg);
// Description: // Description:
// Backwards compatible assert() semi-replacement. If `succ` is false, then print an error with `msg`. // 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: // Arguments:
// succ = If this is `false`, trigger the assertion. // succ = If this is `false`, trigger the assertion.
// msg = The message to emit if `succ` is `false`. // msg = The message to emit if `succ` is `false`.
module assertion(succ, msg) { module assertion(succ, msg) {
if (version_num() >= 20190303) { if (version_num() >= 20190100) {
// assert() will echo the variable name, and `succ` looks confusing there. So we store it in FAILED. // assert() will echo the variable name, and `succ` looks confusing there. So we store it in FAILED.
FAILED = succ; FAILED = succ;
assert(FAILED, msg); assert(FAILED, msg);
@ -200,45 +203,49 @@ module assertion(succ, msg) {
} }
function assertion(succ, msg) = function assertion(succ, msg) =
(version_num() >= 20190303)? (version_num() >= 20190100)? let(FAILED=succ) assert(FAILED, msg) : 0;
let(FAILED=succ) assert(FAILED, msg) :
(!succ)? echo_error(msg) : 0;
// Module: echo_error() // Module: echo_error()
// Usage: // Usage:
// echo_error(msg, [pfx]); // echo_error(msg, [pfx]);
// Description: Emulates printing of an error message. The text will be shaded red. // Description:
// Emulates printing of an error message. The text will be shaded red.
// You can also use this as a function call from a function.
// Arguments: // Arguments:
// msg = The message to print. // msg = The message to print.
// pfx = The prefix to print before `msg`. Default: `ERROR` // pfx = The prefix to print before `msg`. Default: `ERROR`
module echo_error(msg, pfx="ERROR") { module echo_error(msg, pfx="ERROR") {
echo(str("<p style=\"background-color: #a00\"><b>", pfx, ":</b> ", msg, "</p>")); echo(str("<p style=\"background-color: #ffb0b0\"><b>", pfx, ":</b> ", msg, "</p>"));
} }
function echo_error(msg, pfx="ERROR") = function echo_error(msg, pfx="ERROR") =
f_echo(str("<p style=\"background-color: #a00\"><b>", pfx, ":</b> ", msg, "</p>")); f_echo(str("<p style=\"background-color: #ffb0b0\"><b>", pfx, ":</b> ", msg, "</p>"));
// Module: echo_warning() // Module: echo_warning()
// Usage: // Usage:
// echo_warning(msg, [pfx]); // echo_warning(msg, [pfx]);
// Description: Emulates printing of a warning message. The text will be shaded yellow. // Description:
// Emulates printing of a warning message. The text will be shaded yellow.
// You can also use this as a function call from a function.
// Arguments: // Arguments:
// msg = The message to print. // msg = The message to print.
// pfx = The prefix to print before `msg`. Default: `WARNING` // pfx = The prefix to print before `msg`. Default: `WARNING`
module echo_warning(msg, pfx="WARNING") { module echo_warning(msg, pfx="WARNING") {
echo(str("<p style=\"background-color: #ee0\"><b>", pfx, ":</b> ", msg, "</p>")); echo(str("<p style=\"background-color: #ffffb0\"><b>", pfx, ":</b> ", msg, "</p>"));
} }
function echo_warning(msg, pfx="WARNING") = function echo_warning(msg, pfx="WARNING") =
f_echo(str("<p style=\"background-color: #ee0\"><b>", pfx, ":</b> ", msg, "</p>")); f_echo(str("<p style=\"background-color: #ffffb0\"><b>", pfx, ":</b> ", msg, "</p>"));
// Module: deprecate() // Module: deprecate()
// Usage: // Usage:
// deprecate(name, [suggest]); // deprecate(name, [suggest]);
// Description: Show module deprecation warnings. // Description:
// Show module deprecation warnings.
// You can also use this as a function call from a function.
// Arguments: // Arguments:
// name = The name of the module that is deprecated. // name = The name of the module that is deprecated.
// suggest = If given, the module to recommend using instead. // suggest = If given, the module to recommend using instead.
@ -267,9 +274,11 @@ function deprecate(name, suggest=undef) =
// Module: deprecate_argument() // Module: deprecate_argument()
// Usage: // Usage:
// deprecate(name, arg, [suggest]); // deprecate(name, arg, [suggest]);
// Description: Show module argument deprecation warnings. // Description:
// Show argument deprecation warnings.
// You can also use this as a function call from a function.
// Arguments: // Arguments:
// name = The name of the module the deprecated argument is used in. // name = The name of the module/function the deprecated argument is used in.
// arg = The name of the deprecated argument. // arg = The name of the deprecated argument.
// suggest = If given, the argument to recommend using instead. // suggest = If given, the argument to recommend using instead.
module deprecate_argument(name, arg, suggest=undef) { module deprecate_argument(name, arg, suggest=undef) {