From 4c08f74ef54d41f22c40a653b81c599b72a894a1 2011-11-22 12:58:07 From: Szabolcs Horvát Date: 2011-11-22 12:58:07 Subject: [PATCH] Cleaner minimum version comparison using setuptools to reduce chance of breakage (0.11 broke with pyzmq 2.1.10) --- diff --git a/IPython/zmq/__init__.py b/IPython/zmq/__init__.py index 553bb6d..03cef4e 100644 --- a/IPython/zmq/__init__.py +++ b/IPython/zmq/__init__.py @@ -9,21 +9,18 @@ # Verify zmq version dependency >= 2.1.4 #----------------------------------------------------------------------------- -import re import warnings +from pkg_resources import parse_version as V def check_for_zmq(minimum_version, module='IPython.zmq'): - min_vlist = [int(n) for n in minimum_version.split('.')] - try: import zmq except ImportError: raise ImportError("%s requires pyzmq >= %s"%(module, minimum_version)) pyzmq_version = zmq.__version__ - vlist = [int(n) for n in re.findall(r'\d+', pyzmq_version)] - - if 'dev' not in pyzmq_version and vlist < min_vlist: + + if V(pyzmq_version) < V(minimum_version): raise ImportError("%s requires pyzmq >= %s, but you have %s"%( module, minimum_version, pyzmq_version)) @@ -33,7 +30,7 @@ def check_for_zmq(minimum_version, module='IPython.zmq'): if not hasattr(zmq, 'ROUTER'): zmq.ROUTER = zmq.XREP - if zmq.zmq_version() >= '4.0.0': + if V(zmq.zmq_version()) >= V('4.0.0'): warnings.warn("""libzmq 4 detected. It is unlikely that IPython's zmq code will work properly. Please install libzmq stable, which is 2.1.x or 2.2.x""",