Merge pull request #211 from adrianVmariano/master

fixed in_list bug
This commit is contained in:
Revar Desmera 2020-07-21 19:23:48 -07:00 committed by GitHub
commit 68459776e2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
28 changed files with 50 additions and 42 deletions

View File

@ -91,7 +91,11 @@ function slice(arr,st,end) = let(
// in_list("bar", ["foo", "bar", "baz"]); // Returns true. // in_list("bar", ["foo", "bar", "baz"]); // Returns true.
// in_list("bee", ["foo", "bar", "baz"]); // Returns false. // in_list("bee", ["foo", "bar", "baz"]); // Returns false.
// in_list("bar", [[2,"foo"], [4,"bar"], [3,"baz"]], idx=1); // Returns true. // in_list("bar", [[2,"foo"], [4,"bar"], [3,"baz"]], idx=1); // Returns true.
function in_list(x,l,idx=undef) = search([x], l, num_returns_per_match=1, index_col_num=idx) != [[]]; function in_list(val,list,idx=undef) =
let( s = search([val], list, num_returns_per_match=1, index_col_num=idx)[0] )
s==[] ? false
: is_undef(idx) ? val==list[s]
: val==list[s][idx];
// Function: min_index() // Function: min_index()

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/hull.scad> include <../hull.scad>
testpoints_on_sphere = [ for(p = testpoints_on_sphere = [ for(p =

View File

@ -1,5 +1,5 @@
include<BOSL2/std.scad> include<../std.scad>
include<BOSL2/polyhedra.scad> include<../polyhedra.scad>
$fn=96; $fn=96;

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_ident() { module test_ident() {

View File

@ -1,5 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
// List/Array Ops // List/Array Ops
@ -16,6 +15,11 @@ module test_in_list() {
assert(in_list("bar", ["foo", "bar", "baz"])); assert(in_list("bar", ["foo", "bar", "baz"]));
assert(!in_list("bee", ["foo", "bar", "baz"])); assert(!in_list("bee", ["foo", "bar", "baz"]));
assert(in_list("bar", [[2,"foo"], [4,"bar"], [3,"baz"]], idx=1)); assert(in_list("bar", [[2,"foo"], [4,"bar"], [3,"baz"]], idx=1));
assert(!in_list(undef, [3,4,5]));
assert(in_list(undef,[3,4,undef,5]));
assert(!in_list(3,[]));
assert(!in_list(3,[4,5,[3]]));
} }
test_in_list(); test_in_list();

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_typeof() { module test_typeof() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_point2d() { module test_point2d() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/cubetruss.scad> include <../cubetruss.scad>
module test_cubetruss_dist() { module test_cubetruss_dist() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_standard_anchors() { module test_standard_anchors() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_is_edge_array() { module test_is_edge_array() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
// Can't test echo output as yet. Include these for coverage calculations. // Can't test echo output as yet. Include these for coverage calculations.

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_point_on_segment2d() { module test_point_on_segment2d() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/linear_bearings.scad> include <../linear_bearings.scad>
module test_get_lmXuu_bearing_diam() { module test_get_lmXuu_bearing_diam() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
// Simple Calculations // Simple Calculations

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_HSL() { module test_HSL() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_square() { module test_square() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/strings.scad> include <../strings.scad>
function rec_cmp(a,b,eps=1e-9) = function rec_cmp(a,b,eps=1e-9) =

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/queues.scad> include <../queues.scad>
module test_queue_init() { module test_queue_init() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/hull.scad> include <../hull.scad>
module test_prismoid() { module test_prismoid() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_turtle() { module test_turtle() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/skin.scad> include <../skin.scad>
module test_skin() { module test_skin() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/stacks.scad> include <../stacks.scad>
module test_stack_init() { module test_stack_init() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/strings.scad> include <../strings.scad>
module test_upcase() { module test_upcase() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/structs.scad> include <../structs.scad>
module test_struct_set() { module test_struct_set() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_translate() { module test_translate() {

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_is_vector() { module test_is_vector() {
@ -60,7 +60,7 @@ module test_vabs() {
} }
test_vabs(); test_vabs();
include <BOSL2/strings.scad> include <../strings.scad>
module test_vang() { module test_vang() {
assert(vang([1,0])==0); assert(vang([1,0])==0);
assert(vang([0,1])==90); assert(vang([0,1])==90);

View File

@ -1,4 +1,4 @@
include <BOSL2/std.scad> include <../std.scad>
module test_bosl_version() { module test_bosl_version() {

View File

@ -1,5 +1,5 @@
include <BOSL2/std.scad> include <../std.scad>
include <BOSL2/vnf.scad> include <../vnf.scad>
module test_is_vnf() { module test_is_vnf() {