python: Shapely: 1.6.4.post2 -> 1.7.0

This commit is contained in:
Raphael Borun Das Gupta 2020-03-29 13:15:20 +02:00 committed by Jon
parent dac0d8be65
commit 4bbb0e83b1
2 changed files with 58 additions and 35 deletions

View File

@ -5,11 +5,11 @@
buildPythonPackage rec { buildPythonPackage rec {
pname = "Shapely"; pname = "Shapely";
version = "1.6.4.post2"; version = "1.7.0";
src = fetchPypi { src = fetchPypi {
inherit pname version; inherit pname version;
sha256 = "c4b87bb61fc3de59fc1f85e71a79b0c709dc68364d9584473697aad4aa13240f"; sha256 = "07lmrihj6pa7f99m97hbf2anqlhhwippcdz03bqkyihnlkhry6p2";
}; };
nativeBuildInputs = [ nativeBuildInputs = [

View File

@ -1,9 +1,9 @@
diff --git a/shapely/geos.py b/shapely/geos.py diff --git a/shapely/geos.py b/shapely/geos.py
index 09bf1ab..837aa98 100644 index d5a67d2..19b7ffc 100644
--- a/shapely/geos.py --- a/shapely/geos.py
+++ b/shapely/geos.py +++ b/shapely/geos.py
@@ -55,100 +55,10 @@ def load_dll(libname, fallbacks=None, mode=DEFAULT_MODE): @@ -61,123 +61,11 @@ def load_dll(libname, fallbacks=None, mode=DEFAULT_MODE):
"Could not find lib {0} or load any of its variants {1}.".format( "Could not find lib {} or load any of its variants {}.".format(
libname, fallbacks or [])) libname, fallbacks or []))
-_lgeos = None -_lgeos = None
@ -16,15 +16,25 @@ index 09bf1ab..837aa98 100644
- if len(geos_whl_so) == 1: - if len(geos_whl_so) == 1:
- _lgeos = CDLL(geos_whl_so[0]) - _lgeos = CDLL(geos_whl_so[0])
- LOG.debug("Found GEOS DLL: %r, using it.", _lgeos) - LOG.debug("Found GEOS DLL: %r, using it.", _lgeos)
- elif hasattr(sys, 'frozen'):
- geos_pyinstaller_so = glob.glob(os.path.join(sys.prefix, 'libgeos_c-*.so.*'))
- if len(geos_pyinstaller_so) == 1:
- _lgeos = CDLL(geos_pyinstaller_so[0])
- LOG.debug("Found GEOS DLL: %r, using it.", _lgeos)
- elif os.getenv('CONDA_PREFIX', ''):
- # conda package.
- _lgeos = CDLL(os.path.join(sys.prefix, 'lib', 'libgeos_c.so'))
- else: - else:
- alt_paths = [ - alt_paths = [
- 'libgeos_c.so.1', - 'libgeos_c.so.1',
- 'libgeos_c.so', - 'libgeos_c.so',
- # anaconda
- os.path.join(sys.prefix, "lib", "libgeos_c.so"),
- ] - ]
- _lgeos = load_dll('geos_c', fallbacks=alt_paths) - _lgeos = load_dll('geos_c', fallbacks=alt_paths)
- free = load_dll('c').free - # Necessary for environments with only libc.musl
- c_alt_paths = [
- 'libc.musl-x86_64.so.1'
- ]
- free = load_dll('c', fallbacks=c_alt_paths).free
- free.argtypes = [c_void_p] - free.argtypes = [c_void_p]
- free.restype = None - free.restype = None
- -
@ -32,10 +42,19 @@ index 09bf1ab..837aa98 100644
- # Test to see if we have a delocated wheel with a GEOS dylib. - # Test to see if we have a delocated wheel with a GEOS dylib.
- geos_whl_dylib = os.path.abspath(os.path.join(os.path.dirname( - geos_whl_dylib = os.path.abspath(os.path.join(os.path.dirname(
- __file__), '.dylibs/libgeos_c.1.dylib')) - __file__), '.dylibs/libgeos_c.1.dylib'))
-
- if os.path.exists(geos_whl_dylib): - if os.path.exists(geos_whl_dylib):
- handle = CDLL(None)
- if hasattr(handle, "initGEOS_r"):
- LOG.debug("GEOS already loaded")
- _lgeos = handle
- else:
- _lgeos = CDLL(geos_whl_dylib) - _lgeos = CDLL(geos_whl_dylib)
- LOG.debug("Found GEOS DLL: %r, using it.", _lgeos) - LOG.debug("Found GEOS DLL: %r, using it.", _lgeos)
- -
- elif os.getenv('CONDA_PREFIX', ''):
- # conda package.
- _lgeos = CDLL(os.path.join(sys.prefix, 'lib', 'libgeos_c.dylib'))
- else: - else:
- if hasattr(sys, 'frozen'): - if hasattr(sys, 'frozen'):
- try: - try:
@ -52,12 +71,12 @@ index 09bf1ab..837aa98 100644
- os.path.join(sys._MEIPASS, 'libgeos_c.1.dylib')) - os.path.join(sys._MEIPASS, 'libgeos_c.1.dylib'))
- else: - else:
- alt_paths = [ - alt_paths = [
- # anaconda
- os.path.join(sys.prefix, "lib", "libgeos_c.dylib"),
- # The Framework build from Kyng Chaos - # The Framework build from Kyng Chaos
- "/Library/Frameworks/GEOS.framework/Versions/Current/GEOS", - "/Library/Frameworks/GEOS.framework/Versions/Current/GEOS",
- # macports - # macports
- '/opt/local/lib/libgeos_c.dylib', - '/opt/local/lib/libgeos_c.dylib',
- # homebrew
- '/usr/local/lib/libgeos_c.dylib',
- ] - ]
- _lgeos = load_dll('geos_c', fallbacks=alt_paths) - _lgeos = load_dll('geos_c', fallbacks=alt_paths)
- -
@ -66,10 +85,16 @@ index 09bf1ab..837aa98 100644
- free.restype = None - free.restype = None
- -
-elif sys.platform == 'win32': -elif sys.platform == 'win32':
- if os.getenv('CONDA_PREFIX', ''):
- # conda package.
- _lgeos = CDLL(os.path.join(sys.prefix, 'Library', 'bin', 'geos_c.dll'))
- else:
- try: - try:
- egg_dlls = os.path.abspath( - egg_dlls = os.path.abspath(
- os.path.join(os.path.dirname(__file__), 'DLLs')) - os.path.join(os.path.dirname(__file__), 'DLLs'))
- if hasattr(sys, "frozen"): - if hasattr(sys, '_MEIPASS'):
- wininst_dlls = sys._MEIPASS
- elif hasattr(sys, "frozen"):
- wininst_dlls = os.path.normpath( - wininst_dlls = os.path.normpath(
- os.path.abspath(sys.executable + '../../DLLS')) - os.path.abspath(sys.executable + '../../DLLS'))
- else: - else:
@ -77,9 +102,7 @@ index 09bf1ab..837aa98 100644
- original_path = os.environ['PATH'] - original_path = os.environ['PATH']
- os.environ['PATH'] = "%s;%s;%s" % \ - os.environ['PATH'] = "%s;%s;%s" % \
- (egg_dlls, wininst_dlls, original_path) - (egg_dlls, wininst_dlls, original_path)
- _lgeos = load_dll("geos_c.dll", fallbacks=[ - _lgeos = load_dll("geos_c.dll")
- os.path.join(sys.prefix, "Library", "lib", "geos_c.dll"),
- ])
- except (ImportError, WindowsError, OSError): - except (ImportError, WindowsError, OSError):
- raise - raise
- -
@ -89,7 +112,7 @@ index 09bf1ab..837aa98 100644
- except WindowsError: - except WindowsError:
- # XXX: See http://trac.gispython.org/projects/PCL/ticket/149 - # XXX: See http://trac.gispython.org/projects/PCL/ticket/149
- pass - pass
-
-elif sys.platform == 'sunos5': -elif sys.platform == 'sunos5':
- _lgeos = load_dll('geos_c', fallbacks=['libgeos_c.so.1', 'libgeos_c.so']) - _lgeos = load_dll('geos_c', fallbacks=['libgeos_c.so.1', 'libgeos_c.so'])
- free = CDLL('libc.so.1').free - free = CDLL('libc.so.1').free