Phillip J. Eby | 069159b | 2006-04-18 04:05:34 +0000 | [diff] [blame] | 1 | from distutils.core import Extension as _Extension |
| 2 | from dist import _get_unpatched |
| 3 | _Extension = _get_unpatched(_Extension) |
| 4 | |
| 5 | try: |
| 6 | from Pyrex.Distutils.build_ext import build_ext |
| 7 | except ImportError: |
| 8 | have_pyrex = False |
| 9 | else: |
| 10 | have_pyrex = True |
| 11 | |
| 12 | |
| 13 | class Extension(_Extension): |
| 14 | """Extension that uses '.c' files in place of '.pyx' files""" |
| 15 | |
| 16 | if not have_pyrex: |
Tim Peters | 584b0e0 | 2006-04-18 17:32:12 +0000 | [diff] [blame^] | 17 | # convert .pyx extensions to .c |
Phillip J. Eby | 069159b | 2006-04-18 04:05:34 +0000 | [diff] [blame] | 18 | def __init__(self,*args,**kw): |
| 19 | _Extension.__init__(self,*args,**kw) |
| 20 | sources = [] |
| 21 | for s in self.sources: |
| 22 | if s.endswith('.pyx'): |
| 23 | sources.append(s[:-3]+'c') |
| 24 | else: |
| 25 | sources.append(s) |
| 26 | self.sources = sources |
| 27 | |
| 28 | class Library(Extension): |
| 29 | """Just like a regular Extension, but built as a library instead""" |
| 30 | |
| 31 | import sys, distutils.core, distutils.extension |
| 32 | distutils.core.Extension = Extension |
| 33 | distutils.extension.Extension = Extension |
| 34 | if 'distutils.command.build_ext' in sys.modules: |
| 35 | sys.modules['distutils.command.build_ext'].Extension = Extension |