From f1146572dd3c427fcad1129a6909ff45515ac6a3 Mon Sep 17 00:00:00 2001 From: Greg Ward Date: Wed, 1 Mar 2000 14:43:49 +0000 Subject: In compile/link methods: ensure that the directory we expect to be writing to exists before calling the compiler/linker. --- Lib/distutils/unixccompiler.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) 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) -- cgit v0.12