Small-size-optimized Appender
Per Nordlöw
per.nordlow at gmail.com
Fri Oct 16 19:06:33 UTC 2020
Would appreciated feedback on this small-size-optimized Appender
/** Small-Size-Optimized (SSO) `Appender`.
*/
struct SSOAppender(T, size_t smallCapacity)
if (smallCapacity >= 1)
{
import std.array : Appender;
import fixed_array : FixedArray;
void put(T x) @trusted
{
if (_isLarge)
_large.put(x);
else if (_small.full)
{
import std.algorithm.mutation : moveEmplaceAll;
T[smallCapacity] tmp = void;
moveEmplaceAll(_small[], tmp[0 .. _small.length]);
import core.lifetime : emplace;
emplace!Large(&_large);
_large.put(tmp[]);
_large.put(x);
_isLarge = 1;
}
else
_small.put(x);
}
inout(T)[] data() inout return scope
{
if (_isLarge)
return _large.data[];
else
return _small[];
}
private:
alias Small = FixedArray!(T, smallCapacity);
alias Large = Appender!(T[]);
union
{
Small _small;
Large _large;
}
bool _isLarge;
}
I can inline `FixedArray` into a static array if wanted. It's
basically a static array with a length that provides a put API.
Source:
https://github.com/nordlow/phobos-next/blob/e914975613e9a5153313acf29b1b183326823ca3/src/nxt/sso_appender.d
More information about the Digitalmars-d
mailing list