mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2025-01-18 00:56:47 +02:00
prim_concatMap: allocate intermediate list on stack
This commit is contained in:
parent
ee218f99ca
commit
841747b0e6
1 changed files with 15 additions and 7 deletions
|
@ -1651,22 +1651,30 @@ static void prim_concatMap(EvalState & state, const Pos & pos, Value * * args, V
|
||||||
{
|
{
|
||||||
state.forceFunction(*args[0], pos);
|
state.forceFunction(*args[0], pos);
|
||||||
state.forceList(*args[1], pos);
|
state.forceList(*args[1], pos);
|
||||||
auto len = args[1]->listSize();
|
auto nrLists = args[1]->listSize();
|
||||||
|
|
||||||
Value vList;
|
Value lists[nrLists];
|
||||||
state.mkList(vList, len);
|
size_t len = 0;
|
||||||
|
|
||||||
for (unsigned int n = 0; n < len; ++n) {
|
for (unsigned int n = 0; n < nrLists; ++n) {
|
||||||
Value * vElem = args[1]->listElems()[n];
|
Value * vElem = args[1]->listElems()[n];
|
||||||
state.forceValue(*vElem);
|
state.forceValue(*vElem);
|
||||||
state.callFunction(*args[0], *vElem, *(vList.listElems()[n] = state.allocValue()), pos);
|
state.callFunction(*args[0], *vElem, lists[n], pos);
|
||||||
|
state.forceList(lists[n], pos);
|
||||||
|
len += lists[n].listSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
state.concatLists(v, len, vList.listElems(), pos);
|
state.mkList(v, len);
|
||||||
|
auto out = v.listElems();
|
||||||
|
for (unsigned int n = 0, pos = 0; n < nrLists; ++n) {
|
||||||
|
auto l = lists[n].listSize();
|
||||||
|
if (l)
|
||||||
|
memcpy(out + pos, lists[n].listElems(), l * sizeof(Value *));
|
||||||
|
pos += l;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*************************************************************
|
/*************************************************************
|
||||||
* Integer arithmetic
|
* Integer arithmetic
|
||||||
*************************************************************/
|
*************************************************************/
|
||||||
|
|
Loading…
Reference in a new issue