author | Jelle van der Waa
<jelle@archlinux.org> 2019-01-18 17:30:44 UTC |
committer | Jelle van der Waa
<jelle@archlinux.org> 2019-01-18 17:30:44 UTC |
parent | c178c935c24592ba795dd0c34d1874eed8485bc8 |
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 +