git » pyalpm.git » commit 99c0072

Revert memleak patch which causes 'random' segfauts since the handle is still

author Jelle van der Waa
2019-01-18 17:30:44 UTC
committer Jelle van der Waa
2019-01-18 17:30:44 UTC
parent c178c935c24592ba795dd0c34d1874eed8485bc8

Revert memleak patch which causes 'random' segfauts since the handle is still

used while it's already cleaned up.

PKGBUILD +10 -3
memleak.patch +44 -0

diff --git a/PKGBUILD b/PKGBUILD
index 7b54be7..538b860 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -2,16 +2,23 @@
 
 pkgname=pyalpm
 pkgver=0.8.5
-pkgrel=1
+pkgrel=2
 pkgdesc="Libalpm bindings for Python 3"
 arch=('x86_64')
 url="https://git.archlinux.org/pyalpm.git/"
 license=('GPL')
 makedepends=('git' 'python-pytest')
 depends=('python>=3.6' 'pacman>=5.0')
-source=("git+https://git.archlinux.org/pyalpm.git#commit=6b47d1655688fe2957ef52a16aeca8b474546df2")
+source=("git+https://git.archlinux.org/pyalpm.git#commit=6b47d1655688fe2957ef52a16aeca8b474546df2" "memleak.patch")
 validpgpkeys=('E499C79F53C96A54E572FEE1C06086337C50773E')
-sha512sums=('SKIP')
+sha512sums=('SKIP'
+            'b7dacb28bc13f5c9fb9c9295d1a3d323b7b7c0893d69b110f3036b73a4930e8463b5a19011b0e5996ff55157768376c2e53ab97c557afe29bbe3b5d0c8a1e027')
+
+prepare() {
+  cd ${srcdir}/${pkgname}
+  # Rever memleak patch
+  patch -NRp1 -i ${srcdir}/memleak.patch
+}
 
 build() {
   cd ${srcdir}/${pkgname}
diff --git a/memleak.patch b/memleak.patch
new file mode 100644
index 0000000..1a90dfa
--- /dev/null
+++ b/memleak.patch
@@ -0,0 +1,44 @@
+From c02555c5d83e63b1a308e7c165d5615198e6d813 Mon Sep 17 00:00:00 2001
+From: Jelle van der Waa <jelle@vdwaa.nl>
+Date: Wed, 16 Jan 2019 09:30:28 +0100
+Subject: src: dealloc alpm_handle when object goes out of scope
+
+By default alpm_handle is leaked when Handle is out of scope since
+alpm_release is never called. Call alpm_release in tp_dealloc to
+actually free the alloc'd memory.
+---
+ src/handle.c | 11 +++++++++++
+ 1 file changed, 11 insertions(+)
+
+diff --git a/src/handle.c b/src/handle.c
+index 08853f0..5e196df 100644
+--- a/src/handle.c
++++ b/src/handle.c
+@@ -377,6 +377,16 @@ static PyMethodDef pyalpm_handle_methods[] = {
+   {NULL, NULL, 0, NULL},
+ };
+ 
++static void pyalpm_dealloc(PyObject* self) {
++  alpm_handle_t *handle = ALPM_HANDLE(self);
++  int ret = alpm_release(handle);
++  if (ret == -1) {
++    PyErr_Format(alpm_error, "unable to release alpm handle");
++  }
++  handle = NULL;
++  Py_TYPE(self)->tp_free((PyObject *)self);
++}
++
+ PyTypeObject AlpmHandleType = {
+   PyVarObject_HEAD_INIT(NULL, 0)
+   "alpm.Handle",       /*tp_name*/
+@@ -387,6 +397,7 @@ PyTypeObject AlpmHandleType = {
+   .tp_methods = pyalpm_handle_methods,
+   .tp_getset = pyalpm_handle_getset,
+   .tp_new = pyalpm_initialize,
++  .tp_dealloc = (destructor) pyalpm_dealloc,
+ };
+ 
+ /** Initializes Handle class in module */
+-- 
+cgit v1.2.1-1-g437b
+