Added typeof(), is_str(), is_type(). Moved no_children() to errors.scad.

This commit is contained in:
Revar Desmera 2019-10-30 19:52:53 -07:00
parent dded2eefa6
commit fa572fc398
2 changed files with 65 additions and 19 deletions

View file

@ -8,15 +8,63 @@
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////
// Section: Handling `undef`s. // Section: Type handling helpers.
// Function: typeof()
// Usage:
// typ = typeof(x);
// Description:
// Returns a string representing the type of the value. One of "undef", "boolean", "number", "string", "list", or "range"
function typeof(x) =
is_undef(x)? "undef" :
is_bool(x)? "boolean" :
is_num(x)? "number" :
is_string(x)? "string" :
is_list(x)? "list" :
"range";
// Function: is_type()
// Usage:
// b = is_type(x, types);
// Description:
// Returns true if the type of the value `x` is one of those given as strings in the list `types`.
// Valid types are "undef", "boolean", "number", "string", "list", or "range"
// Arguments:
// x = The value to check the type of.
// types = A list of types to check
// Example:
// is_str_or_list = is_type("foo", ["string","list"]); // Returns: true
// is_str_or_list2 = is_type([1,2,3], ["string","list"]); // Returns: true
// is_str_or_list3 = is_type(2, ["string","list"]); // Returns: false
// is_str = is_type("foo", "string"); // Returns: true
// is_str2 = is_type([3,4], "string"); // Returns: false
// is_str3 = is_type(["foo"], "string"); // Returns: false
// is_str4 = is_type(3, "string"); // Returns: false
function is_type(x,types) =
is_list(types)? in_list(typeof(x),types) :
is_string(types)? typeof(x) == types :
assert(is_list(types)||is_string(types));
// Function: is_def() // Function: is_def()
// Usage: // Usage:
// is_def(v) // is_def(x)
// Description: // Description:
// Returns true if `v` is not `undef`. False if `v==undef`. // Returns true if `x` is not `undef`. False if `x==undef`.
function is_def(v) = !is_undef(v); function is_def(x) = !is_undef(x);
// Function: is_str()
// Usage:
// is_str(x)
// Description:
// Returns true if `x` is a string. A shortcut for `is_string()`.
function is_str(x) = is_string(x);
// Section: Handling `undef`s.
// Function: default() // Function: default()
@ -119,21 +167,6 @@ function get_height(h=undef,l=undef,height=undef,dflt=undef) =
first_defined([h,l,height,dflt]); first_defined([h,l,height,dflt]);
// Module: no_children()
// Usage:
// no_children($children);
// Description:
// Assert that the calling module does not support children. Prints an error message to this effect and fails if children are present,
// as indicated by its argument.
// Arguments:
// $children = number of children the module has.
module no_children(count)
{
assert(count==0, str("Module ",parent_module(1),"() does not support child modules"));
}
// Function: scalar_vec3() // Function: scalar_vec3()
// Usage: // Usage:
// scalar_vec3(v, [dflt]); // scalar_vec3(v, [dflt]);

View file

@ -40,6 +40,19 @@ function assert_in_list(argname, val, l, idx=undef) =
) assert(FAILED, msg); ) assert(FAILED, msg);
// Module: no_children()
// Usage:
// no_children($children);
// Description:
// Assert that the calling module does not support children. Prints an error message to this effect and fails if children are present,
// as indicated by its argument.
// Arguments:
// $children = number of children the module has.
module no_children(count) {
assert(count==0, str("Module ",parent_module(1),"() does not support child modules"));
}
// Function&Module: echo_error() // Function&Module: echo_error()
// Usage: // Usage:
// echo_error(msg, [pfx]); // echo_error(msg, [pfx]);