On Friday, 25 October 2013 at 07:19:48 UTC, Namespace wrote:
On Friday, 25 October 2013 at 00:00:36 UTC, Andrei Alexandrescu wrote:
On 10/24/13 2:38 PM, Namespace wrote:
On Thursday, 24 October 2013 at 21:31:42 UTC, Namespace wrote:
Awesome! Will Appender get an option to use a suitable allocator?

A dream of me, that will probably never come true, would be also
something like this:
----
with (Mallocator) {
   int[] arr;
   arr ~= 42; /// will use Mallocator.it.allocate internal
}
----

Oddly enough this can be actually done.

with (setAllocator!Mallocator)
{
  ...
}

setAllcator returns an rvalue that changes the global allocator to the Mallocator in the constructor, and restores it to whatever it was in the destructor.


Andrei

Are you saying that this code:
----
with (setAllocator!Mallocator) {
    int[] arr;
    arr ~= 42; [1]
}
----
use the mallocator for [1]? So no GC memory is needed?

Another examaple:
----
with (setAllocator!ScopeAllocator) {
    int[] arr;
    arr ~= 42; [1]
}
----
Did [1] use ScopeAllocator for memory allocation? And is the memory of arr automatically collected at the end of the scope with ScopeAllocator?

This is impossible because with() has already another meaning. However nothing stops from inventing another name for this. Compiler can insert calls to druntime as well to other context dependent functions. After allocator design is defined we can move on to step 2, implementing this idea.

Reply via email to