diff options
author | Gregory Szorc <gregory.szorc@gmail.com> | 2012-03-09 18:56:33 +0000 |
---|---|---|
committer | Gregory Szorc <gregory.szorc@gmail.com> | 2012-03-09 18:56:33 +0000 |
commit | 07c32218f448b7637d4acad8e87ce7cfaef0277e (patch) | |
tree | 09b98f3a686f3007b5a47266efe414b6d86712b0 /bindings/python/llvm/core.py | |
parent | 5992f67e683b665392f45b167fe5c9abd91455c9 (diff) | |
download | external_llvm-07c32218f448b7637d4acad8e87ce7cfaef0277e.zip external_llvm-07c32218f448b7637d4acad8e87ce7cfaef0277e.tar.gz external_llvm-07c32218f448b7637d4acad8e87ce7cfaef0277e.tar.bz2 |
[llvm.py] Make ObjectFile destructor work
Previous code had a double free in MemoryBuffer. The tests now pass.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@152422 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'bindings/python/llvm/core.py')
-rw-r--r-- | bindings/python/llvm/core.py | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/bindings/python/llvm/core.py b/bindings/python/llvm/core.py index 5a3bd51..bd9f8aa 100644 --- a/bindings/python/llvm/core.py +++ b/bindings/python/llvm/core.py @@ -7,6 +7,7 @@ # #===------------------------------------------------------------------------===# +from .common import LLVMObject from .common import get_library from ctypes import POINTER @@ -33,7 +34,7 @@ class MemoryBuffer(object): if filename is None: raise Exception("filename argument must be defined") - memory = c_void_p(None) + memory = LLVMObject() out = c_char_p(None) result = lib.LLVMCreateMemoryBufferWithContentsOfFile(filename, @@ -43,17 +44,23 @@ class MemoryBuffer(object): raise Exception("Could not create memory buffer: %s" % out.value) self._memory = memory + self._as_parameter_ = self._memory + self._owned = True def __del__(self): - lib.LLVMDisposeMemoryBuffer(self._memory) + if self._owned: + lib.LLVMDisposeMemoryBuffer(self._memory) def from_param(self): - return self._memory + return self._as_parameter_ + + def release_ownership(self): + self._owned = False def register_library(library): library.LLVMCreateMemoryBufferWithContentsOfFile.argtypes = [c_char_p, - POINTER(c_void_p), POINTER(c_char_p)] + POINTER(LLVMObject), POINTER(c_char_p)] library.LLVMCreateMemoryBufferWithContentsOfFile.restype = bool library.LLVMDisposeMemoryBuffer.argtypes = [c_void_p] |