summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTarek Ziadé <ziade.tarek@gmail.com>2009-05-19 16:22:57 (GMT)
committerTarek Ziadé <ziade.tarek@gmail.com>2009-05-19 16:22:57 (GMT)
commit822eb844006fb78a0551b0f55547b46cf8607e8a (patch)
tree7b44f9b425e5d10c342211894f23068d71fac584
parentf84d7e9ed21294f6001345ddc6b2a8c4894ab70c (diff)
downloadcpython-822eb844006fb78a0551b0f55547b46cf8607e8a.zip
cpython-822eb844006fb78a0551b0f55547b46cf8607e8a.tar.gz
cpython-822eb844006fb78a0551b0f55547b46cf8607e8a.tar.bz2
Merged revisions 72781 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r72781 | tarek.ziade | 2009-05-19 18:17:21 +0200 (Tue, 19 May 2009) | 1 line fixed the 'package' option of build_ext ........
-rw-r--r--Lib/distutils/command/build_ext.py24
-rw-r--r--Lib/distutils/tests/test_build_ext.py22
-rw-r--r--Misc/NEWS3
3 files changed, 38 insertions, 11 deletions
diff --git a/Lib/distutils/command/build_ext.py b/Lib/distutils/command/build_ext.py
index eb4cb05..31e036b 100644
--- a/Lib/distutils/command/build_ext.py
+++ b/Lib/distutils/command/build_ext.py
@@ -629,19 +629,21 @@ class build_ext(Command):
The file is located in `build_lib` or directly in the package
(inplace option).
"""
- if self.inplace:
- fullname = self.get_ext_fullname(ext_name)
- modpath = fullname.split('.')
- package = '.'.join(modpath[0:-1])
- base = modpath[-1]
- build_py = self.get_finalized_command('build_py')
- package_dir = os.path.abspath(build_py.get_package_dir(package))
- filename = self.get_ext_filename(ext_name)
- return os.path.join(package_dir, filename)
- else:
- filename = self.get_ext_filename(ext_name)
+ fullname = self.get_ext_fullname(ext_name)
+ filename = self.get_ext_filename(fullname)
+ if not self.inplace:
+ # no further work needed
return os.path.join(self.build_lib, filename)
+ # the inplace option requires to find the package directory
+ # using the build_py command
+ modpath = fullname.split('.')
+ package = '.'.join(modpath[0:-1])
+ base = modpath[-1]
+ build_py = self.get_finalized_command('build_py')
+ package_dir = os.path.abspath(build_py.get_package_dir(package))
+ return os.path.join(package_dir, filename)
+
def get_ext_fullname(self, ext_name):
"""Returns the fullname of a given extension name.
diff --git a/Lib/distutils/tests/test_build_ext.py b/Lib/distutils/tests/test_build_ext.py
index add2923..4ea11a1 100644
--- a/Lib/distutils/tests/test_build_ext.py
+++ b/Lib/distutils/tests/test_build_ext.py
@@ -336,6 +336,28 @@ class BuildExtTestCase(TempdirManager,
so_dir = os.path.dirname(so_file)
self.assertEquals(so_dir, cmd.build_lib)
+ # inplace = 0, cmd.package = 'bar'
+ cmd.package = 'bar'
+ path = cmd.get_ext_fullpath('foo')
+ # checking that the last directory is bar
+ path = os.path.split(path)[0]
+ lastdir = os.path.split(path)[-1]
+ self.assertEquals(lastdir, cmd.package)
+
+ # inplace = 1, cmd.package = 'bar'
+ cmd.inplace = 1
+ other_tmp_dir = os.path.realpath(self.mkdtemp())
+ old_wd = os.getcwd()
+ os.chdir(other_tmp_dir)
+ try:
+ path = cmd.get_ext_fullpath('foo')
+ finally:
+ os.chdir(old_wd)
+ # checking that the last directory is bar
+ path = os.path.split(path)[0]
+ lastdir = os.path.split(path)[-1]
+ self.assertEquals(lastdir, cmd.package)
+
def test_suite():
src = _get_source_filename()
if not os.path.exists(src):
diff --git a/Misc/NEWS b/Misc/NEWS
index bb028d9..7ecbd3f 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -618,6 +618,9 @@ Core and Builtins
Library
-------
+- Issue #6062: In distutils, fixed the package option of build_ext. Feedback
+ and tests on pywin32 by Tim Golden.
+
- Issue #6053: Fixed distutils tests on win32. patch by Hirokazu Yamamoto.
- Issue #6046: Fixed the library extension when distutils build_ext is used