From: David Bremner Date: Sat, 7 Mar 2015 07:31:14 +0000 (+0100) Subject: python: replace hardcoding of SONAME version X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=aed5ec4350809aef34ae8290f8eda2069444b171;p=notmuch.git python: replace hardcoding of SONAME version Failing to update this string in globals.py causes failures when the SONAME changes. In order to hopefully reduce the number of such errors, automate the process of setting the SONAME in the python bindings. --- diff --git a/Makefile.local b/Makefile.local index 81ee3477..6d547423 100644 --- a/Makefile.local +++ b/Makefile.local @@ -107,7 +107,9 @@ dist: $(TAR_FILE) .PHONY: update-versions update-versions: - sed -i "s/^__VERSION__[[:blank:]]*=.*$$/__VERSION__ = \'${VERSION}\'/" $(PV_FILE) + sed -i -e "s/^__VERSION__[[:blank:]]*=.*$$/__VERSION__ = \'${VERSION}\'/" \ + -e "s/^SOVERSION[[:blank:]]*=.*$$/SOVERSION = \'${LIBNOTMUCH_VERSION_MAJOR}\'/" \ + ${PV_FILE} # We invoke make recursively only to force ordering of our phony # targets in the case of parallel invocation of make (-j). diff --git a/bindings/python/notmuch/globals.py b/bindings/python/notmuch/globals.py index 24b25d36..4c49d51d 100644 --- a/bindings/python/notmuch/globals.py +++ b/bindings/python/notmuch/globals.py @@ -18,15 +18,16 @@ Copyright 2010 Sebastian Spaeth """ from ctypes import CDLL, Structure, POINTER +from version import SOVERSION #----------------------------------------------------------------------------- #package-global instance of the notmuch library try: from os import uname if uname()[0] == 'Darwin': - nmlib = CDLL("libnotmuch.4.dylib") + nmlib = CDLL("libnotmuch.{0:s}.dylib".format(SOVERSION)) else: - nmlib = CDLL("libnotmuch.so.4") + nmlib = CDLL("libnotmuch.so.{0:s}".format(SOVERSION)) except: raise ImportError("Could not find shared 'notmuch' library.") diff --git a/bindings/python/notmuch/version.py b/bindings/python/notmuch/version.py index f719fdf4..35744d34 100644 --- a/bindings/python/notmuch/version.py +++ b/bindings/python/notmuch/version.py @@ -1,2 +1,3 @@ # this file should be kept in sync with ../../../version __VERSION__ = '0.19' +SOVERSION = '4'