mirror of
				https://github.com/msgpack/msgpack-python.git
				synced 2025-10-25 22:54:11 +00:00 
			
		
		
		
	do not install cython as build dependency (#610)
User can not cythonize during `pip install msgpack`. So remove cython from build dependency. If user need to use another Cython, user should download sdist, unzip, manually cythonize, and `pip install .`.
This commit is contained in:
		
							parent
							
								
									9cea8b6da2
								
							
						
					
					
						commit
						0b1c47b06b
					
				
					 2 changed files with 1 additions and 50 deletions
				
			
		|  | @ -1,9 +1,5 @@ | ||||||
| [build-system] | [build-system] | ||||||
| requires = [ | requires = ["setuptools >= 69.5.1"] | ||||||
|     # Also declared in requirements.txt, if updating here please also update there |  | ||||||
|     "Cython~=3.0.10", |  | ||||||
|     "setuptools >= 69.5.1", |  | ||||||
| ] |  | ||||||
| build-backend = "setuptools.build_meta" | build-backend = "setuptools.build_meta" | ||||||
| 
 | 
 | ||||||
| [project] | [project] | ||||||
|  |  | ||||||
							
								
								
									
										45
									
								
								setup.py
									
										
									
									
									
								
							
							
						
						
									
										45
									
								
								setup.py
									
										
									
									
									
								
							|  | @ -3,52 +3,9 @@ import os | ||||||
| import sys | import sys | ||||||
| 
 | 
 | ||||||
| from setuptools import Extension, setup | from setuptools import Extension, setup | ||||||
| from setuptools.command.build_ext import build_ext |  | ||||||
| from setuptools.command.sdist import sdist |  | ||||||
| 
 | 
 | ||||||
| PYPY = hasattr(sys, "pypy_version_info") | PYPY = hasattr(sys, "pypy_version_info") | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| class NoCython(Exception): |  | ||||||
|     pass |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| try: |  | ||||||
|     import Cython.Compiler.Main as cython_compiler |  | ||||||
| 
 |  | ||||||
|     have_cython = True |  | ||||||
| except ImportError: |  | ||||||
|     have_cython = False |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| def cythonize(src): |  | ||||||
|     if not have_cython: |  | ||||||
|         raise Exception("Cython is required for building from checkout") |  | ||||||
|     sys.stderr.write(f"cythonize: {src!r}\n") |  | ||||||
|     cython_compiler.compile([src]) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| def ensure_source(src): |  | ||||||
|     pyx = os.path.splitext(src)[0] + ".pyx" |  | ||||||
| 
 |  | ||||||
|     if not os.path.exists(src) or have_cython and os.stat(src).st_mtime < os.stat(pyx).st_mtime: |  | ||||||
|         cythonize(pyx) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| class BuildExt(build_ext): |  | ||||||
|     def build_extension(self, ext): |  | ||||||
|         for src in ext.sources: |  | ||||||
|             ensure_source(src) |  | ||||||
|         return build_ext.build_extension(self, ext) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Cython is required for sdist |  | ||||||
| class Sdist(sdist): |  | ||||||
|     def __init__(self, *args, **kwargs): |  | ||||||
|         cythonize("msgpack/_cmsgpack.pyx") |  | ||||||
|         sdist.__init__(self, *args, **kwargs) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| libraries = [] | libraries = [] | ||||||
| macros = [] | macros = [] | ||||||
| ext_modules = [] | ext_modules = [] | ||||||
|  | @ -69,9 +26,7 @@ if not PYPY and not os.environ.get("MSGPACK_PUREPYTHON"): | ||||||
|     ) |     ) | ||||||
| del libraries, macros | del libraries, macros | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| setup( | setup( | ||||||
|     cmdclass={"build_ext": BuildExt, "sdist": Sdist}, |  | ||||||
|     ext_modules=ext_modules, |     ext_modules=ext_modules, | ||||||
|     packages=["msgpack"], |     packages=["msgpack"], | ||||||
| ) | ) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Inada Naoki
						Inada Naoki