Let malloc infer its attributes
Malloc should not force '@safe' or '@nogc' on constructors which are not. For example, TaskPool's ctor is not '@nogc' but was assumed as such thanks to the delegate cast happening in malloc. Likewise, the ctor or the arguments might not be '@safe', or any other attributes, but they were be mistakenly marked as such.
This commit is contained in:
parent
3fd907edd4
commit
e7688361ba
|
@ -18,20 +18,18 @@ void print(ARGS...)(string str, ARGS args)
|
|||
}
|
||||
|
||||
T mallocT(T, ARGS...)(ARGS args)
|
||||
@trusted @nogc {
|
||||
{
|
||||
import core.stdc.stdlib : malloc;
|
||||
import std.conv : emplace;
|
||||
|
||||
T ret = () @trusted {
|
||||
enum size = __traits(classInstanceSize, T);
|
||||
auto ret = cast(T)malloc(size);
|
||||
T r = cast(T)malloc(size);
|
||||
static if (hasIndirections!T)
|
||||
GC.addRange(cast(void*)ret, __traits(classInstanceSize, T));
|
||||
scope doit = { emplace!T((cast(void*)ret)[0 .. size], args); };
|
||||
static if (__traits(compiles, () nothrow { typeof(doit).init(); })) // NOTE: doing the typeof thing here, because LDC 1.7.0 otherwise thinks doit gets escaped here
|
||||
(cast(void delegate() @nogc nothrow)doit)();
|
||||
else
|
||||
(cast(void delegate() @nogc)doit)();
|
||||
return ret;
|
||||
GC.addRange(cast(void*)r, size);
|
||||
return r;
|
||||
}();
|
||||
return emplace!T(ret, args);
|
||||
}
|
||||
|
||||
void freeT(T)(ref T inst) @nogc
|
||||
|
|
Loading…
Reference in a new issue