extension.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. """distutils.extension
  2. Provides the Extension class, used to describe C/C++ extension
  3. modules in setup scripts.
  4. Overridden to support f2py.
  5. """
  6. from __future__ import division, absolute_import, print_function
  7. import sys
  8. import re
  9. from distutils.extension import Extension as old_Extension
  10. if sys.version_info[0] >= 3:
  11. basestring = str
  12. cxx_ext_re = re.compile(r'.*[.](cpp|cxx|cc)\Z', re.I).match
  13. fortran_pyf_ext_re = re.compile(r'.*[.](f90|f95|f77|for|ftn|f|pyf)\Z', re.I).match
  14. class Extension(old_Extension):
  15. """
  16. Parameters
  17. ----------
  18. name : str
  19. Extension name.
  20. sources : list of str
  21. List of source file locations relative to the top directory of
  22. the package.
  23. extra_compile_args : list of str
  24. Extra command line arguments to pass to the compiler.
  25. extra_f77_compile_args : list of str
  26. Extra command line arguments to pass to the fortran77 compiler.
  27. extra_f90_compile_args : list of str
  28. Extra command line arguments to pass to the fortran90 compiler.
  29. """
  30. def __init__(
  31. self, name, sources,
  32. include_dirs=None,
  33. define_macros=None,
  34. undef_macros=None,
  35. library_dirs=None,
  36. libraries=None,
  37. runtime_library_dirs=None,
  38. extra_objects=None,
  39. extra_compile_args=None,
  40. extra_link_args=None,
  41. export_symbols=None,
  42. swig_opts=None,
  43. depends=None,
  44. language=None,
  45. f2py_options=None,
  46. module_dirs=None,
  47. extra_f77_compile_args=None,
  48. extra_f90_compile_args=None,):
  49. old_Extension.__init__(
  50. self, name, [],
  51. include_dirs=include_dirs,
  52. define_macros=define_macros,
  53. undef_macros=undef_macros,
  54. library_dirs=library_dirs,
  55. libraries=libraries,
  56. runtime_library_dirs=runtime_library_dirs,
  57. extra_objects=extra_objects,
  58. extra_compile_args=extra_compile_args,
  59. extra_link_args=extra_link_args,
  60. export_symbols=export_symbols)
  61. # Avoid assert statements checking that sources contains strings:
  62. self.sources = sources
  63. # Python 2.4 distutils new features
  64. self.swig_opts = swig_opts or []
  65. # swig_opts is assumed to be a list. Here we handle the case where it
  66. # is specified as a string instead.
  67. if isinstance(self.swig_opts, basestring):
  68. import warnings
  69. msg = "swig_opts is specified as a string instead of a list"
  70. warnings.warn(msg, SyntaxWarning, stacklevel=2)
  71. self.swig_opts = self.swig_opts.split()
  72. # Python 2.3 distutils new features
  73. self.depends = depends or []
  74. self.language = language
  75. # numpy_distutils features
  76. self.f2py_options = f2py_options or []
  77. self.module_dirs = module_dirs or []
  78. self.extra_f77_compile_args = extra_f77_compile_args or []
  79. self.extra_f90_compile_args = extra_f90_compile_args or []
  80. return
  81. def has_cxx_sources(self):
  82. for source in self.sources:
  83. if cxx_ext_re(str(source)):
  84. return True
  85. return False
  86. def has_f2py_sources(self):
  87. for source in self.sources:
  88. if fortran_pyf_ext_re(source):
  89. return True
  90. return False
  91. # class Extension