diff options
| author | Mike Wey | 2012-04-09 14:35:41 +0200 |
|---|---|---|
| committer | Mike Wey | 2012-04-09 14:35:41 +0200 |
| commit | 811e5806d29c0856b182c278ec544a7fe4be4175 (patch) | |
| tree | 051e33ec2af526c070b982f01cd59b5ba2ae6931 /dmagick/Image.d | |
| parent | 90958a9bc18b13cb76581eea7ab7d99b8d831601 (diff) | |
Don't try to use the D GC when creating blobs.
This causes segfaults, see issue #4.
Diffstat (limited to 'dmagick/Image.d')
| -rw-r--r-- | dmagick/Image.d | 33 |
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; } /** |
