Commit df02315c authored by Jason Madden's avatar Jason Madden Committed by GitHub

Merge pull request #1614 from gevent/issue1480

Rename C accelerator modules to avoid clashes.
parents 66d56aba 59f1e9c2
Rename gevent's C accelerator extension modules using a prefix to
avoid clashing with other C extensions.
...@@ -48,81 +48,89 @@ from _setupares import ARES ...@@ -48,81 +48,89 @@ from _setupares import ARES
CORE = cythonize1(build_libev_extension()) CORE = cythonize1(build_libev_extension())
# Get access to the greenlet header file. # Modules that we cythonize for performance.
# Be careful not to use simple names for these modules,
SEMAPHORE = Extension(name="gevent.__semaphore", # as the non-static symbols cython generates do not include
# the module name. Thus an extension of 'gevent._queue'
# results in symbols like 'PyInit__queue', which is the same
# symbol used by the standard library _queue accelerator module.
# The name of the .pxd file must match the local name of the accelerator
# extension; however, sadly, the generated .c and .html files will
# still use the same name as the .py source.
SEMAPHORE = Extension(name="gevent._gevent_c_semaphore",
sources=["src/gevent/_semaphore.py"], sources=["src/gevent/_semaphore.py"],
depends=['src/gevent/__semaphore.pxd'], depends=['src/gevent/_gevent_c_semaphore.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
LOCAL = Extension(name="gevent._local", LOCAL = Extension(name="gevent._gevent_clocal",
sources=["src/gevent/local.py"], sources=["src/gevent/local.py"],
depends=['src/gevent/_local.pxd'], depends=['src/gevent/_gevent_clocal.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
GREENLET = Extension(name="gevent._greenlet", GREENLET = Extension(name="gevent._gevent_cgreenlet",
sources=[ sources=[
"src/gevent/greenlet.py", "src/gevent/greenlet.py",
], ],
depends=[ depends=[
'src/gevent/_greenlet.pxd', 'src/gevent/_gevent_cgreenlet.pxd',
'src/gevent/__ident.pxd', 'src/gevent/_gevent_c_ident.pxd',
'src/gevent/_ident.py' 'src/gevent/_ident.py'
], ],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
ABSTRACT_LINKABLE = Extension(name="gevent.__abstract_linkable", ABSTRACT_LINKABLE = Extension(name="gevent._gevent_c_abstract_linkable",
sources=["src/gevent/_abstract_linkable.py"], sources=["src/gevent/_abstract_linkable.py"],
depends=['src/gevent/__abstract_linkable.pxd'], depends=['src/gevent/_gevent_c_abstract_linkable.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
IDENT = Extension(name="gevent.__ident", IDENT = Extension(name="gevent._gevent_c_ident",
sources=["src/gevent/_ident.py"], sources=["src/gevent/_ident.py"],
depends=['src/gevent/__ident.pxd'], depends=['src/gevent/_gevent_c_ident.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
IMAP = Extension(name="gevent.__imap", IMAP = Extension(name="gevent._gevent_c_imap",
sources=["src/gevent/_imap.py"], sources=["src/gevent/_imap.py"],
depends=['src/gevent/__imap.pxd'], depends=['src/gevent/_gevent_c_imap.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
EVENT = Extension(name="gevent._event", EVENT = Extension(name="gevent._gevent_cevent",
sources=["src/gevent/event.py"], sources=["src/gevent/event.py"],
depends=['src/gevent/_event.pxd'], depends=['src/gevent/_gevent_cevent.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
QUEUE = Extension(name="gevent._queue", QUEUE = Extension(name="gevent._gevent_cqueue",
sources=["src/gevent/queue.py"], sources=["src/gevent/queue.py"],
depends=['src/gevent/_queue.pxd'], depends=['src/gevent/_gevent_cqueue.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
HUB_LOCAL = Extension(name="gevent.__hub_local", HUB_LOCAL = Extension(name="gevent._gevent_c_hub_local",
sources=["src/gevent/_hub_local.py"], sources=["src/gevent/_hub_local.py"],
depends=['src/gevent/__hub_local.pxd'], depends=['src/gevent/_gevent_c_hub_local.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
WAITER = Extension(name="gevent.__waiter", WAITER = Extension(name="gevent._gevent_c_waiter",
sources=["src/gevent/_waiter.py"], sources=["src/gevent/_waiter.py"],
depends=['src/gevent/__waiter.pxd'], depends=['src/gevent/_gevent_c_waiter.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
HUB_PRIMITIVES = Extension(name="gevent.__hub_primitives", HUB_PRIMITIVES = Extension(name="gevent._gevent_c_hub_primitives",
sources=["src/gevent/_hub_primitives.py"], sources=["src/gevent/_hub_primitives.py"],
depends=['src/gevent/__hub_primitives.pxd'], depends=['src/gevent/_gevent_c_hub_primitives.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
GLT_PRIMITIVES = Extension(name="gevent.__greenlet_primitives", GLT_PRIMITIVES = Extension(name="gevent._gevent_c_greenlet_primitives",
sources=["src/gevent/_greenlet_primitives.py"], sources=["src/gevent/_greenlet_primitives.py"],
depends=['src/gevent/__greenlet_primitives.pxd'], depends=['src/gevent/_gevent_c_greenlet_primitives.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
TRACER = Extension(name="gevent.__tracer", TRACER = Extension(name="gevent._gevent_c_tracer",
sources=["src/gevent/_tracer.py"], sources=["src/gevent/_tracer.py"],
depends=['src/gevent/__tracer.pxd'], depends=['src/gevent/_gevent_c_tracer.pxd'],
include_dirs=get_include_dirs()) include_dirs=get_include_dirs())
......
cimport cython cimport cython
from gevent.__greenlet_primitives cimport SwitchOutGreenletWithLoop from gevent._gevent_c_greenlet_primitives cimport SwitchOutGreenletWithLoop
from gevent.__hub_local cimport get_hub_noargs as get_hub from gevent._gevent_c_hub_local cimport get_hub_noargs as get_hub
cdef InvalidSwitchError cdef InvalidSwitchError
cdef Timeout cdef Timeout
......
from gevent.__greenlet_primitives cimport SwitchOutGreenletWithLoop from gevent._gevent_c_greenlet_primitives cimport SwitchOutGreenletWithLoop
cdef _threadlocal cdef _threadlocal
......
cimport cython cimport cython
from gevent.__greenlet_primitives cimport SwitchOutGreenletWithLoop from gevent._gevent_c_greenlet_primitives cimport SwitchOutGreenletWithLoop
from gevent.__hub_local cimport get_hub_noargs as get_hub from gevent._gevent_c_hub_local cimport get_hub_noargs as get_hub
from gevent.__waiter cimport Waiter from gevent._gevent_c_waiter cimport Waiter
from gevent.__waiter cimport MultipleWaiter from gevent._gevent_c_waiter cimport MultipleWaiter
cdef InvalidSwitchError cdef InvalidSwitchError
cdef _waiter cdef _waiter
......
cimport cython cimport cython
from gevent._greenlet cimport Greenlet from gevent._gevent_cgreenlet cimport Greenlet
from gevent.__semaphore cimport Semaphore from gevent._gevent_c_semaphore cimport Semaphore
from gevent._queue cimport UnboundQueue from gevent._gevent_cqueue cimport UnboundQueue
@cython.freelist(100) @cython.freelist(100)
@cython.internal @cython.internal
......
cimport cython cimport cython
from gevent.__abstract_linkable cimport AbstractLinkable from gevent._gevent_c_abstract_linkable cimport AbstractLinkable
cdef Timeout cdef Timeout
......
cimport cython cimport cython
from gevent.__greenlet_primitives cimport SwitchOutGreenletWithLoop from gevent._gevent_c_greenlet_primitives cimport SwitchOutGreenletWithLoop
from gevent.__hub_local cimport get_hub_noargs as get_hub from gevent._gevent_c_hub_local cimport get_hub_noargs as get_hub
cdef sys cdef sys
cdef ConcurrentObjectUseError cdef ConcurrentObjectUseError
......
cimport cython cimport cython
from gevent.__hub_local cimport get_hub_noargs as get_hub from gevent._gevent_c_hub_local cimport get_hub_noargs as get_hub
from gevent.__abstract_linkable cimport AbstractLinkable from gevent._gevent_c_abstract_linkable cimport AbstractLinkable
cdef _None cdef _None
cdef reraise cdef reraise
......
# cython: auto_pickle=False # cython: auto_pickle=False
cimport cython cimport cython
from gevent.__ident cimport IdentRegistry from gevent._gevent_c_ident cimport IdentRegistry
from gevent.__hub_local cimport get_hub_noargs as get_hub from gevent._gevent_c_hub_local cimport get_hub_noargs as get_hub
from gevent.__waiter cimport Waiter from gevent._gevent_c_waiter cimport Waiter
from gevent.__greenlet_primitives cimport SwitchOutGreenletWithLoop from gevent._gevent_c_greenlet_primitives cimport SwitchOutGreenletWithLoop
cdef bint _PYPY cdef bint _PYPY
cdef sys_getframe cdef sys_getframe
......
# cython: auto_pickle=False # cython: auto_pickle=False
cimport cython cimport cython
from gevent._greenlet cimport Greenlet from gevent._gevent_cgreenlet cimport Greenlet
cdef bint _PYPY cdef bint _PYPY
cdef ref cdef ref
......
cimport cython cimport cython
from gevent.__waiter cimport Waiter from gevent._gevent_c_waiter cimport Waiter
from gevent._event cimport Event from gevent._gevent_cevent cimport Event
from gevent.__hub_local cimport get_hub_noargs as get_hub from gevent._gevent_c_hub_local cimport get_hub_noargs as get_hub
cdef bint _greenlet_imported cdef bint _greenlet_imported
cdef _heappush cdef _heappush
......
...@@ -75,9 +75,19 @@ def copy_globals(source, ...@@ -75,9 +75,19 @@ def copy_globals(source,
def import_c_accel(globs, cname): def import_c_accel(globs, cname):
""" """
Import the C-accelerator for the __name__ Import the C-accelerator for the *cname*
and copy its globals. and copy its globals.
The *cname* should be hardcoded to match the expected
C accelerator module.
Unless PURE_PYTHON is set (in the environment or automatically
on PyPy), then the C-accelerator is required.
""" """
if not cname.startswith('gevent._gevent_c'):
# Old module code that hasn't been updated yet.
cname = cname.replace('gevent._',
'gevent._gevent_c')
name = globs.get('__name__') name = globs.get('__name__')
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
# that's a new feature that we don't need or want to allow in a gevent # that's a new feature that we don't need or want to allow in a gevent
# point release. # point release.
# cython: emit_code_comments=False, auto_pickle=False # cython: emit_code_comments=False, auto_pickle=False, language_level=3str
# NOTE: We generally cannot use the Cython IF directive as documented # NOTE: We generally cannot use the Cython IF directive as documented
# at # at
...@@ -19,6 +19,9 @@ ...@@ -19,6 +19,9 @@
# C file for all platforms so that end users that don't use a binary # C file for all platforms so that end users that don't use a binary
# wheel don't have to sit through cythonpp and other steps the Makefile does. # wheel don't have to sit through cythonpp and other steps the Makefile does.
# See https://github.com/gevent/gevent/issues/1076 # See https://github.com/gevent/gevent/issues/1076
# We compile in 3str mode, which should mean we get absolute import
# by default.
from __future__ import absolute_import
cimport cython cimport cython
cimport libev cimport libev
...@@ -33,14 +36,11 @@ cdef extern from "Python.h": ...@@ -33,14 +36,11 @@ cdef extern from "Python.h":
int Py_ReprEnter(object) int Py_ReprEnter(object)
void Py_ReprLeave(object) void Py_ReprLeave(object)
# Work around lack of absolute_import in Cython import sys
# Note for PY3: not doing so will leave reference to locals() on import import os
# (reproducible under Python 3.3, not under Python 3.4; see test__refcount_core.py) import traceback
sys = __import__('sys', level=0) import signal as signalmodule
os = __import__('os', level=0) from gevent import getswitchinterval
traceback = __import__('traceback', level=0)
signalmodule = __import__('signal', level=0)
getswitchinterval = __import__('gevent', level=0).getswitchinterval
__all__ = ['get_version', __all__ = ['get_version',
......
...@@ -71,7 +71,7 @@ class TestCExt(greentest.TestCase): ...@@ -71,7 +71,7 @@ class TestCExt(greentest.TestCase):
def test_c_extension(self): def test_c_extension(self):
self.assertEqual(IdentRegistry.__module__, self.assertEqual(IdentRegistry.__module__,
'gevent.__ident') 'gevent._gevent_c_ident')
......
...@@ -828,9 +828,9 @@ class TestCExt(greentest.TestCase): # pragma: no cover (we only do coverage on p ...@@ -828,9 +828,9 @@ class TestCExt(greentest.TestCase): # pragma: no cover (we only do coverage on p
def test_c_extension(self): def test_c_extension(self):
self.assertEqual(greenlet.Greenlet.__module__, self.assertEqual(greenlet.Greenlet.__module__,
'gevent._greenlet') 'gevent._gevent_cgreenlet')
self.assertEqual(greenlet.SpawnedLink.__module__, self.assertEqual(greenlet.SpawnedLink.__module__,
'gevent._greenlet') 'gevent._gevent_cgreenlet')
@greentest.skipWithCExtensions("Needs pure python") @greentest.skipWithCExtensions("Needs pure python")
class TestPure(greentest.TestCase): class TestPure(greentest.TestCase):
......
...@@ -414,7 +414,7 @@ class TestCExt(greentest.TestCase): # pragma: no cover ...@@ -414,7 +414,7 @@ class TestCExt(greentest.TestCase): # pragma: no cover
def test_c_extension(self): def test_c_extension(self):
self.assertEqual(local.__module__, self.assertEqual(local.__module__,
'gevent._local') 'gevent._gevent_clocal')
@greentest.skipWithCExtensions("Needs pure-python") @greentest.skipWithCExtensions("Needs pure-python")
class TestPure(greentest.TestCase): class TestPure(greentest.TestCase):
......
...@@ -91,7 +91,7 @@ class TestCExt(greentest.TestCase): ...@@ -91,7 +91,7 @@ class TestCExt(greentest.TestCase):
def test_c_extension(self): def test_c_extension(self):
self.assertEqual(Semaphore.__module__, self.assertEqual(Semaphore.__module__,
'gevent.__semaphore') 'gevent._gevent_c_semaphore')
class SwitchWithFixedHash(object): class SwitchWithFixedHash(object):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment