summaryrefslogtreecommitdiff
path: root/dmagick/Image.d
diff options
context:
space:
mode:
Diffstat (limited to 'dmagick/Image.d')
-rw-r--r--dmagick/Image.d33
1 files changed, 6 insertions, 27 deletions
diff --git a/dmagick/Image.d b/dmagick/Image.d
index dcbb7c5..ea74403 100644
--- a/dmagick/Image.d
+++ b/dmagick/Image.d
@@ -2961,42 +2961,21 @@ class Image
void[] toBlob(string magick = null, size_t depth = 0)
{
size_t length;
-
- AcquireMemoryHandler oldMalloc;
- ResizeMemoryHandler oldRealloc;
- DestroyMemoryHandler oldFree;
+ ExceptionInfo* exceptionInfo = AcquireExceptionInfo();
if ( magick !is null )
this.magick = magick;
if ( depth != 0 )
this.depth = depth;
- //Use the D GC to accolate the blob.
- GetMagickMemoryMethods(&oldMalloc, &oldRealloc, &oldFree);
- SetMagickMemoryMethods(&Image.malloc, &Image.realloc, &Image.free);
- scope(exit) SetMagickMemoryMethods(oldMalloc, oldRealloc, oldFree);
-
- void* blob = ImageToBlob(options.imageInfo, imageRef, &length, DMagickExceptionInfo());
+ void* blob = ImageToBlob(options.imageInfo, imageRef, &length, exceptionInfo);
- return blob[0 .. length];
- }
+ DMagickException.throwException(exceptionInfo);
- private extern(C)
- {
- static void* malloc(size_t sz)
- {
- return GC.malloc(sz, GC.BlkAttr.NO_SCAN);
- }
+ void[] dBlob = blob[0 .. length].dup;
+ RelinquishMagickMemory(blob);
- static void* realloc(void* p, size_t sz)
- {
- return GC.realloc(p, sz, GC.BlkAttr.NO_SCAN);
- }
-
- static void free(void* p)
- {
- GC.free(p);
- }
+ return dBlob;
}
/**