Fixed bug in list_set and arg order

This commit is contained in:
Adrian Mariano 2019-06-28 18:26:05 -04:00
parent d64b836e8b
commit 48b154b9f8
2 changed files with 5 additions and 5 deletions

View file

@ -171,7 +171,7 @@ function deduplicate(list, eps=EPSILON) =
// Function: list_set() // Function: list_set()
// Usage: // Usage:
// list_set(indices, values, list, [dflt], [minlen]) // list_set(list, indices, values, [dflt], [minlen])
// Description: // Description:
// Takes the input list and returns a new list such that `list[indices[i]] = values[i]` for all of // Takes the input list and returns a new list such that `list[indices[i]] = values[i]` for all of
// the (index,value) pairs supplied. If you supply `indices` that are beyond the length of the list // the (index,value) pairs supplied. If you supply `indices` that are beyond the length of the list
@ -180,12 +180,12 @@ function deduplicate(list, eps=EPSILON) =
// order but run time will be (much) faster for long lists if it is already sorted. Reptitions are // order but run time will be (much) faster for long lists if it is already sorted. Reptitions are
// not allowed. // not allowed.
// Arguments: // Arguments:
// list = List to set items in. Default: []
// indices = List of indices into `list` to set. // indices = List of indices into `list` to set.
// values = List of values to set. // values = List of values to set.
// list = List to set items in.
// dflt = Default value to store in sparse skipped indices. // dflt = Default value to store in sparse skipped indices.
// minlen = Minimum length to expand list to. // minlen = Minimum length to expand list to.
function list_set(indices,values,list=[],dflt=0,minlen=0) = function list_set(list=[],indices,values,dflt=0,minlen=0) =
!is_list(indices) ? list_set(list,[indices],[values],dflt) : !is_list(indices) ? list_set(list,[indices],[values],dflt) :
assert(len(indices)==len(values),"Index list and value list must have the same length") assert(len(indices)==len(values),"Index list and value list must have the same length")
let( let(
@ -272,7 +272,7 @@ function list_bset(indexset, valuelist, dflt=0) =
let( let(
trueind = search([true], indexset,0)[0] trueind = search([true], indexset,0)[0]
) concat( ) concat(
list_set(trueind, valuelist, dflt=dflt), // Fill in all of the values list_set([],trueind, valuelist, dflt=dflt), // Fill in all of the values
replist(dflt,len(indexset)-max(trueind)-1) // Add trailing values so length matches indexset replist(dflt,len(indexset)-max(trueind)-1) // Add trailing values so length matches indexset
); );

View file

@ -25,7 +25,7 @@ function struct_set(struct, keyword, value=undef, grow=true) =
let(ind=search([keyword],struct,1,0)[0]) let(ind=search([keyword],struct,1,0)[0])
(ind==[] ? assert(grow,str("Unknown keyword \"",keyword)) (ind==[] ? assert(grow,str("Unknown keyword \"",keyword))
concat(struct, [[keyword,value]]) : concat(struct, [[keyword,value]]) :
list_set([ind], [[keyword,value]],struct)) : list_set(struct, [ind], [[keyword,value]])) :
_parse_pairs(struct,keyword,grow); _parse_pairs(struct,keyword,grow);
function _parse_pairs(spec, input, grow=true, index=0, result=undef) = function _parse_pairs(spec, input, grow=true, index=0, result=undef) =