diff --git a/pylib/gyp/generator/msvs.py b/pylib/gyp/generator/msvs.py index ab92979e..705d5e17 100644 --- a/pylib/gyp/generator/msvs.py +++ b/pylib/gyp/generator/msvs.py @@ -1717,14 +1717,17 @@ def _GetCopies(spec): src_bare = src[:-1] base_dir = posixpath.split(src_bare)[0] outer_dir = posixpath.split(src_bare)[1] - cmd = 'cd "%s" && xcopy /e /f /y "%s" "%s\\%s\\"' % ( - _FixPath(base_dir), outer_dir, _FixPath(dst), outer_dir) + fixed_dst = _FixPath(dst) + full_dst = '"%s\\%s\\"' % (fixed_dst, outer_dir) + cmd = 'mkdir %s 2>nul & cd "%s" && xcopy /e /f /y "%s" %s' % ( + full_dst, _FixPath(base_dir), outer_dir, full_dst) copies.append(([src], ['dummy_copies', dst], cmd, - 'Copying %s to %s' % (src, dst))) + 'Copying %s to %s' % (src, fixed_dst))) else: + fix_dst = _FixPath(cpy['destination']) cmd = 'mkdir "%s" 2>nul & set ERRORLEVEL=0 & copy /Y "%s" "%s"' % ( - _FixPath(cpy['destination']), _FixPath(src), _FixPath(dst)) - copies.append(([src], [dst], cmd, 'Copying %s to %s' % (src, dst))) + fix_dst, _FixPath(src), _FixPath(dst)) + copies.append(([src], [dst], cmd, 'Copying %s to %s' % (src, fix_dst))) return copies diff --git a/test/copies/gyptest-all.py b/test/copies/gyptest-all.py index ec38a297..aeccf332 100755 --- a/test/copies/gyptest-all.py +++ b/test/copies/gyptest-all.py @@ -12,11 +12,6 @@ test = TestGyp.TestGyp() -# The test seems to fail on msvs on the waterfall but not the try servers. -# Need to investigate further. -if test.format == 'msvs': - test.skip_test() # bug=536 - test.run_gyp('copies.gyp', '-G', 'xcode_ninja_target_pattern=^(?!copies_null)', chdir='src')