summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Lib/distutils/unixccompiler.py7
1 files changed, 6 insertions, 1 deletions
diff --git a/Lib/distutils/unixccompiler.py b/Lib/distutils/unixccompiler.py
index 770a543..77d12d3 100644
--- a/Lib/distutils/unixccompiler.py
+++ b/Lib/distutils/unixccompiler.py
@@ -159,6 +159,8 @@ class UnixCCompiler (CCompiler):
if extra_postargs is None:
extra_postargs = []
+ if output_dir is not None:
+ self.mkpath (output_dir)
for (source,object) in srcobj:
self.spawn ([self.cc] + cc_args +
[source, '-o', object] +
@@ -167,7 +169,7 @@ class UnixCCompiler (CCompiler):
# Have to re-fetch list of object filenames, because we want to
# return *all* of them, including those that weren't recompiled on
# this call!
- return self.object_filenames (orig_sources, output_dir)
+ return self.object_filenames (orig_sources, output_dir=output_dir)
def _fix_link_args (self, output_dir, libraries, library_dirs):
@@ -226,6 +228,7 @@ class UnixCCompiler (CCompiler):
newer = newer_group (objects, output_filename)
if self.force or newer:
+ self.mkpath (os.path.dirname (output_filename))
self.spawn ([self.archiver,
self.archiver_options,
output_filename] +
@@ -298,6 +301,7 @@ class UnixCCompiler (CCompiler):
ld_args[:0] = extra_preargs
if extra_postargs:
ld_args.extend (extra_postargs)
+ self.mkpath (os.path.dirname (output_filename))
self.spawn ([self.ld_shared] + ld_args)
else:
self.announce ("skipping %s (up-to-date)" % output_filename)
@@ -340,6 +344,7 @@ class UnixCCompiler (CCompiler):
ld_args[:0] = extra_preargs
if extra_postargs:
ld_args.extend (extra_postargs)
+ self.mkpath (os.path.dirname (output_filename))
self.spawn ([self.ld_exec] + ld_args)
else:
self.announce ("skipping %s (up-to-date)" % output_filename)