Index: BugPoint/compile-custom.ll =================================================================== --- BugPoint/compile-custom.ll +++ BugPoint/compile-custom.ll @@ -1,4 +1,4 @@ -; RUN: bugpoint -load %llvmshlibdir/BugpointPasses%shlibext --compile-custom --compile-command="%python %s.py arg1 arg2" --output-prefix %t %s | FileCheck %s +; RUN: bugpoint -load %llvmshlibdir/BugpointPasses%shlibext --compile-custom --compile-command="%python %^s.py arg1 arg2" --output-prefix %t %s | FileCheck %s ; REQUIRES: loadable_module ; Test that arguments are correctly passed in --compile-command. The output Index: DebugInfo/llvm-symbolizer-split-dwarf-empty.test =================================================================== --- DebugInfo/llvm-symbolizer-split-dwarf-empty.test +++ DebugInfo/llvm-symbolizer-split-dwarf-empty.test @@ -1,7 +1,7 @@ REQUIRES: shell RUN: cd %T RUN: cp %p/Inputs/split-dwarf-empty.dwo %T -RUN: echo "%p/Inputs/split-dwarf-empty.o 0xdeadbeef" > %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-empty.o\" 0xdeadbeef" > %t.input RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ RUN: --default-arch=i386 < %t.input | FileCheck %s Index: DebugInfo/llvm-symbolizer.test =================================================================== --- DebugInfo/llvm-symbolizer.test +++ DebugInfo/llvm-symbolizer.test @@ -1,44 +1,44 @@ -RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400559" > %t.input -RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64.debuglink 0x400559" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400436" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400528" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400586" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004e8" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004f4" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x8dc" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0xa05" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x987" >> %t.input -RUN: echo "%p/Inputs/dwarfdump-inl-test.high_pc.elf-x86-64 0x568" >> %t.input -RUN: echo "\"%p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x640" >> %t.input -RUN: echo "\"%p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x633" >> %t.input -RUN: echo "\"%p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x62d" >> %t.input -RUN: echo "%p/Inputs/macho-universal 0x1f84" >> %t.input -RUN: echo "%p/Inputs/macho-universal:i386 0x1f67" >> %t.input -RUN: echo "%p/Inputs/macho-universal:x86_64 0x100000f05" >> %t.input -RUN: echo "%p/Inputs/llvm-symbolizer-dwo-test 0x400514" >> %t.input -RUN: echo "%p/Inputs/fission-ranges.elf-x86_64 0x720" >> %t.input -RUN: echo "%p/Inputs/arange-overlap.elf-x86_64 0x714" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test.elf-x86-64\" 0x400559" > %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test.elf-x86-64.debuglink\" 0x400559" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test.elf-x86-64\" 0x400436" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test.elf-x86-64\" 0x400528" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test.elf-x86-64\" 0x400586" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test2.elf-x86-64\" 0x4004e8" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test2.elf-x86-64\" 0x4004f4" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test4.elf-x86-64\" 0x62c" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-inl-test.elf-x86-64\" 0x8dc" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-inl-test.elf-x86-64\" 0xa05" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-inl-test.elf-x86-64\" 0x987" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-inl-test.high_pc.elf-x86-64\" 0x568" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x640" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x633" >> %t.input +RUN: echo "\"%^p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x62d" >> %t.input +RUN: echo "\"%^p/Inputs/macho-universal\" 0x1f84" >> %t.input +RUN: echo "\"%^p/Inputs/macho-universal:i386\" 0x1f67" >> %t.input +RUN: echo "\"%^p/Inputs/macho-universal:x86_64\" 0x100000f05" >> %t.input +RUN: echo "\"%^p/Inputs/llvm-symbolizer-dwo-test\" 0x400514" >> %t.input +RUN: echo "\"%^p/Inputs/fission-ranges.elf-x86_64\" 0x720" >> %t.input +RUN: echo "\"%^p/Inputs/arange-overlap.elf-x86_64\" 0x714" >> %t.input RUN: cp %p/Inputs/split-dwarf-test.dwo %T -RUN: echo "%p/Inputs/split-dwarf-test 0x4005d4" >> %t.input -RUN: echo "%p/Inputs/split-dwarf-test 0x4005c4" >> %t.input -RUN: echo "%p/Inputs/cross-cu-inlining.x86_64-macho.o 0x17" >> %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-test\" 0x4005d4" >> %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-test\" 0x4005c4" >> %t.input +RUN: echo "\"%^p/Inputs/cross-cu-inlining.x86_64-macho.o\" 0x17" >> %t.input RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file -RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4005d4" >> %t.input -RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4005c4" >> %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-test-nogmlt\" 0x4005d4" >> %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-test-nogmlt\" 0x4005c4" >> %t.input RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable RUN: rm %T/split-dwarf-test.dwo -RUN: echo "%p/Inputs/split-dwarf-test 0x4005d4" >> %t.input -RUN: echo "%p/Inputs/split-dwarf-test 0x4005c4" >> %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-test\" 0x4005d4" >> %t.input +RUN: echo "\"%^p/Inputs/split-dwarf-test\" 0x4005c4" >> %t.input RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s @@ -138,7 +138,7 @@ MISSING-FILE: LLVMSymbolizer: error reading file: {{[Nn]}}o such file or directory -RUN: echo "%p/Inputs/macho-universal 0x1f84" > %t.input3 +RUN: echo "\"%^p/Inputs/macho-universal\" 0x1f84" > %t.input3 RUN: llvm-symbolizer < %t.input3 | FileCheck %s --check-prefix=UNKNOWN-ARCH UNKNOWN-ARCH-NOT: main @@ -171,7 +171,7 @@ STRIPPED: global_func -RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" > %t.input7 +RUN: echo "\"%^p/Inputs/dwarfdump-test4.elf-x86-64\" 0x62c" > %t.input7 RUN: llvm-symbolizer --functions=short --demangle=false < %t.input7 \ RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME Index: GetRepositoryPath =================================================================== --- GetRepositoryPath +++ GetRepositoryPath @@ -9,11 +9,11 @@ exit 1 } -if [ $# != 1 ] || [ ! -d $1 ]; then +if [ $# != 1 ] || [ ! -d "$1" ]; then usage; fi -cd $1 +cd "$1" if [ -d .svn ]; then svn info | grep '^URL:' | cut -d: -f2- elif [ -f .git/svn/.metadata ]; then Index: GetSourceVersion =================================================================== --- GetSourceVersion +++ GetSourceVersion @@ -9,11 +9,11 @@ exit 1 } -if [ $# != 1 ] || [ ! -d $1 ]; then +if [ $# != 1 ] || [ ! -d "$1" ]; then usage; fi -cd $1 +cd "$1" if [ -d .svn ]; then svnversion | sed -e "s#\([0-9]*\)[A-Z]*#\1#" elif [ -f .git/svn/.metadata ]; then Index: GettingStartedVS.rst =================================================================== --- GettingStartedVS.rst +++ GettingStartedVS.rst @@ -54,9 +54,6 @@ `_. Version 2.7 and newer are known to work. You will need `GnuWin32 `_ tools, too. -Do not install the LLVM directory tree into a path containing spaces (e.g. -``C:\Documents and Settings\...``) as the configure step will fail. - Getting Started =============== Index: LibDriver/libpath.test =================================================================== --- LibDriver/libpath.test +++ LibDriver/libpath.test @@ -2,7 +2,7 @@ RUN: llvm-mc -triple=x86_64-pc-windows-msvc -filetype=obj -o %T/a/foo.obj %S/Inputs/a.s RUN: llvm-mc -triple=x86_64-pc-windows-msvc -filetype=obj -o %T/b/foo.obj %S/Inputs/b.s -RUN: env "LIB=%T/a;%T/b" llvm-lib /out:%t1.lib foo.obj +RUN: env "LIB=%^T/a;%^T/b" llvm-lib /out:%t1.lib foo.obj RUN: llvm-nm %t1.lib | FileCheck --check-prefix=A %s RUN: llvm-lib /out:%t2.lib /libpath:%T/a /libpath:%T/b foo.obj Index: Object/mri-addmod.test =================================================================== --- Object/mri-addmod.test +++ Object/mri-addmod.test @@ -1,5 +1,5 @@ ; RUN: echo create %t.a > %t.mri -; RUN: echo "addmod \"%p/Inputs/trivial-object-test.elf-x86-64\" " >> %t.mri +; RUN: echo "addmod \"%^p/Inputs/trivial-object-test.elf-x86-64\" " >> %t.mri ; RUN: echo save >> %t.mri ; RUN: echo end >> %t.mri Index: Object/nm-archive.test =================================================================== --- Object/nm-archive.test +++ Object/nm-archive.test @@ -29,7 +29,7 @@ RUN: llvm-nm %t2 | FileCheck %s -check-prefix BITCODE RUN: rm -f %t2 -RUN: echo /out:%t2 %t1 > %t.rsp +RUN: echo "\"/out:%^t2\" \"%^t1\"" > %t.rsp RUN: llvm-lib @%t.rsp RUN: llvm-nm %t2 | FileCheck %s -check-prefix BITCODE Index: Other/ResponseFile.ll =================================================================== --- Other/ResponseFile.ll +++ Other/ResponseFile.ll @@ -3,8 +3,8 @@ ; file for us. Tokenization with quotes is tested in unittests. ; On Windows, paths contain \ characters, which are escape characters in ; GNU-style response files. So replace \ with \\ to make the tests work there. -; RUN: echo %s | sed -e 's:\\:\\\\:g' > %t.list1 -; RUN: echo "-time-passes @%t.list1" | sed -e 's:\\:\\\\:g' > %t.list2 +; RUN: echo "\"%^s\"" | sed -e 's:\\:\\\\:g' > %t.list1 +; RUN: echo "-time-passes \"@%^t.list1\"" | sed -e 's:\\:\\\\:g' > %t.list2 ; RUN: llvm-as @%t.list2 -o %t.bc ; RUN: llvm-nm %t.bc 2>&1 | FileCheck %s Index: ThinLTO/X86/prefix_replace.ll =================================================================== --- ThinLTO/X86/prefix_replace.ll +++ ThinLTO/X86/prefix_replace.ll @@ -7,7 +7,7 @@ ; RUN: rm -f %T/newpath/prefix_replace.o.thinlto.bc ; RUN: llvm-lto -thinlto-action=thinlink -o %t.index.bc %T/oldpath/prefix_replace.o -; RUN: llvm-lto -thinlto-action=distributedindexes -thinlto-prefix-replace="%T/oldpath/;%T/newpath/" -thinlto-index %t.index.bc %T/oldpath/prefix_replace.o +; RUN: llvm-lto -thinlto-action=distributedindexes -thinlto-prefix-replace="%^T/oldpath/;%^T/newpath/" -thinlto-index %t.index.bc %T/oldpath/prefix_replace.o ; RUN: ls %T/newpath/prefix_replace.o.thinlto.bc Index: Transforms/GCOVProfiling/function-numbering.ll =================================================================== --- Transforms/GCOVProfiling/function-numbering.ll +++ Transforms/GCOVProfiling/function-numbering.ll @@ -2,7 +2,7 @@ ; functions aren't emitted. ; Inject metadata to set the .gcno file location -; RUN: echo '!14 = !{!"%/T/function-numbering.ll", !0}' > %t1 +; RUN: echo '!14 = !{!"%^/T/function-numbering.ll", !0}' > %t1 ; RUN: cat %s %t1 > %t2 ; RUN: opt -insert-gcov-profiling -S < %t2 | FileCheck --check-prefix GCDA %s Index: Transforms/GCOVProfiling/global-ctor.ll =================================================================== --- Transforms/GCOVProfiling/global-ctor.ll +++ Transforms/GCOVProfiling/global-ctor.ll @@ -1,4 +1,4 @@ -; RUN: echo '!16 = !{!"%/T/global-ctor.ll", !0}' > %t1 +; RUN: echo '!16 = !{!"%^/T/global-ctor.ll", !0}' > %t1 ; RUN: cat %s %t1 > %t2 ; RUN: opt -insert-gcov-profiling -disable-output < %t2 ; RUN: not grep '_GLOBAL__sub_I_global-ctor' %T/global-ctor.gcno Index: Transforms/GCOVProfiling/linezero.ll =================================================================== --- Transforms/GCOVProfiling/linezero.ll +++ Transforms/GCOVProfiling/linezero.ll @@ -1,7 +1,7 @@ -; RUN: sed -e 's|PATTERN|%/T|g' %s | opt -insert-gcov-profiling -disable-output +; RUN: sed -e 's|PATTERN|%^/T|g' %s | opt -insert-gcov-profiling -disable-output ; RUN: rm %T/linezero.gcno -; RUN: sed -e 's|PATTERN|%/T|g' %s | opt -passes=insert-gcov-profiling -disable-output +; RUN: sed -e 's|PATTERN|%^/T|g' %s | opt -passes=insert-gcov-profiling -disable-output ; RUN: rm %T/linezero.gcno ; This is a crash test. Index: Transforms/GCOVProfiling/linkagename.ll =================================================================== --- Transforms/GCOVProfiling/linkagename.ll +++ Transforms/GCOVProfiling/linkagename.ll @@ -1,4 +1,4 @@ -; RUN: echo '!9 = !{!"%/T/linkagename.ll", !0}' > %t1 +; RUN: echo '!9 = !{!"%^/T/linkagename.ll", !0}' > %t1 ; RUN: cat %s %t1 > %t2 ; RUN: opt -insert-gcov-profiling -disable-output < %t2 ; RUN: grep _Z3foov %T/linkagename.gcno Index: Transforms/GCOVProfiling/return-block.ll =================================================================== --- Transforms/GCOVProfiling/return-block.ll +++ Transforms/GCOVProfiling/return-block.ll @@ -1,5 +1,5 @@ ; Inject metadata to set the .gcno file location -; RUN: echo '!19 = !{!"%/T/return-block.ll", !0}' > %t1 +; RUN: echo '!19 = !{!"%^/T/return-block.ll", !0}' > %t1 ; RUN: cat %s %t1 > %t2 ; By default, the return block is last. Index: Transforms/GCOVProfiling/three-element-mdnode.ll =================================================================== --- Transforms/GCOVProfiling/three-element-mdnode.ll +++ Transforms/GCOVProfiling/three-element-mdnode.ll @@ -1,4 +1,4 @@ -; RUN: echo '!10 = !{!"%/T/aaa.gcno", !"%/T/bbb.gcda", !0}' > %t1 +; RUN: echo '!10 = !{!"%^/T/aaa.gcno", !"%/T/bbb.gcda", !0}' > %t1 ; RUN: cat %s %t1 > %t2 ; RUN: opt -insert-gcov-profiling -S -o %t3 < %t2 ; RUN: grep _Z3foov %T/aaa.gcno Index: Transforms/GCOVProfiling/version.ll =================================================================== --- Transforms/GCOVProfiling/version.ll +++ Transforms/GCOVProfiling/version.ll @@ -1,4 +1,4 @@ -; RUN: echo '!9 = !{!"%/T/version.ll", !0}' > %t1 +; RUN: echo '!9 = !{!"%^/T/version.ll", !0}' > %t1 ; RUN: cat %s %t1 > %t2 ; RUN: opt -insert-gcov-profiling -disable-output < %t2 ; RUN: head -c8 %T/version.gcno | grep '^oncg.204' Index: lit.cfg =================================================================== --- lit.cfg +++ lit.cfg @@ -209,13 +209,13 @@ config.substitutions.append( ('%llc_dwarf', llc_dwarf) ) # Add site-specific substitutions. -config.substitutions.append( ('%gold', config.gold_executable) ) -config.substitutions.append( ('%go', config.go_executable) ) -config.substitutions.append( ('%llvmshlibdir', config.llvm_shlib_dir) ) -config.substitutions.append( ('%shlibext', config.llvm_shlib_ext) ) -config.substitutions.append( ('%exeext', config.llvm_exe_ext) ) -config.substitutions.append( ('%python', config.python_executable) ) -config.substitutions.append( ('%host_cc', config.host_cc) ) +config.substitutions.append( ('%gold', lit.util.escapeSpaces(config.gold_executable)) ) +config.substitutions.append( ('%go', lit.util.escapeSpaces(config.go_executable)) ) +config.substitutions.append( ('%llvmshlibdir', lit.util.escapeSpaces(config.llvm_shlib_dir)) ) +config.substitutions.append( ('%shlibext', lit.util.escapeSpaces(config.llvm_shlib_ext)) ) +config.substitutions.append( ('%exeext', lit.util.escapeSpaces(config.llvm_exe_ext)) ) +config.substitutions.append( ('%python', lit.util.escapeSpaces(config.python_executable)) ) +config.substitutions.append( ('%host_cc', lit.util.escapeSpaces(config.host_cc)) ) # Provide the path to asan runtime lib if available. On darwin, this lib needs # to be loaded via DYLD_INSERT_LIBRARIES before libLTO.dylib in case the files @@ -331,7 +331,7 @@ # Warn, but still provide a substitution. lit_config.note('Did not find ' + tool_name + ' in ' + llvm_tools_dir) tool_path = llvm_tools_dir + '/' + tool_name - config.substitutions.append((pattern, tool_pipe + tool_path)) + config.substitutions.append((pattern, tool_pipe + lit.util.escapeSpaces(tool_path))) # For tools that are optional depending on the config, we won't warn # if they're missing. @@ -346,7 +346,7 @@ if not tool_path: # Provide a substitution anyway, for the sake of consistent errors. tool_path = llvm_tools_dir + '/' + tool_name - config.substitutions.append((pattern, tool_pipe + tool_path)) + config.substitutions.append((pattern, tool_pipe + lit.util.escapeSpaces(tool_path))) ### Targets Index: lit/lit/ShUtil.py =================================================================== --- lit/lit/ShUtil.py +++ lit/lit/ShUtil.py @@ -2,6 +2,7 @@ import itertools import lit.util +from lit.util import escapeChar from lit.ShCommands import Command, Pipeline, Seq class ShLexer: @@ -31,12 +32,14 @@ def lex_arg_fast(self, c): # Get the leading whitespace free section. chunk = self.data[self.pos - 1:].split(None, 1)[0] - + + escape_char = escapeChar(self.win32Escapes) + # If it has special characters, the fast path failed. if ('|' in chunk or '&' in chunk or '<' in chunk or '>' in chunk or "'" in chunk or '"' in chunk or - ';' in chunk or '\\' in chunk): + ';' in chunk or escape_char in chunk): return None self.pos = self.pos - 1 + len(chunk) @@ -71,8 +74,8 @@ elif c == "'": self.eat() str += self.lex_arg_quoted("'") - elif not self.win32Escapes and c == '\\': - # Outside of a string, '\\' escapes everything. + elif c == escapeChar(self.win32Escapes): + # Outside of a string, '\\' (or '^' on windows) escapes everything. self.eat() if self.pos == self.end: lit.util.warning( Index: lit/lit/TestRunner.py =================================================================== --- lit/lit/TestRunner.py +++ lit/lit/TestRunner.py @@ -8,7 +8,7 @@ import lit.ShUtil as ShUtil import lit.Test as Test import lit.util -from lit.util import to_bytes, to_string +from lit.util import to_bytes, to_string, escapeSpaces from lit.BooleanExpression import BooleanExpression class InternalShellError(Exception): @@ -673,53 +673,100 @@ return tmpDir, tmpBase def getDefaultSubstitutions(test, tmpDir, tmpBase, normalize_slashes=False): - sourcepath = test.getSourcePath() - sourcedir = os.path.dirname(sourcepath) + sourcePath = test.getSourcePath() + sourceDir = os.path.dirname(sourcePath) + + normSourcePath = sourcePath.replace('\\', '/') + normSourceDir = sourceDir.replace('\\', '/') + normTmpDir = tmpDir.replace('\\', '/') + normTmpBase = tmpBase.replace('\\', '/') # Normalize slashes, if requested. if normalize_slashes: - sourcepath = sourcepath.replace('\\', '/') - sourcedir = sourcedir.replace('\\', '/') - tmpDir = tmpDir.replace('\\', '/') - tmpBase = tmpBase.replace('\\', '/') + sourcePath = normSourcePath + sourceDir = normSourceDir + tmpDir = normTmpDir + tmpBase = normTmpBase + + # handle spaces in paths + escapedSourcePath = escapeSpaces(sourcePath) + escapedSourceDir = escapeSpaces(sourceDir) + escapedTmpDir = escapeSpaces(tmpDir) + escapedTmpBase = escapeSpaces(tmpBase) # We use #_MARKER_# to hide %% while we do the other substitutions. substitutions = [] substitutions.extend([('%%', '#_MARKER_#')]) substitutions.extend(test.config.substitutions) - substitutions.extend([('%s', sourcepath), - ('%S', sourcedir), - ('%p', sourcedir), + substitutions.extend([('%s', escapedSourcePath), + ('%S', escapedSourceDir), + ('%p', escapedSourceDir), ('%{pathsep}', os.pathsep), - ('%t', tmpBase + '.tmp'), - ('%T', tmpDir), + ('%t', escapedTmpBase + '.tmp'), + ('%T', escapedTmpDir), ('#_MARKER_#', '%')]) + # "%^[STpst]" should not have spaces escaped. + substitutions.extend([ + ('%\^s', sourcePath), + ('%\^S', sourceDir), + ('%\^p', sourceDir), + ('%\^t', tmpBase + '.tmp'), + ('%\^T', tmpDir), + ]) + # "%/[STpst]" should be normalized. substitutions.extend([ - ('%/s', sourcepath.replace('\\', '/')), - ('%/S', sourcedir.replace('\\', '/')), - ('%/p', sourcedir.replace('\\', '/')), - ('%/t', tmpBase.replace('\\', '/') + '.tmp'), - ('%/T', tmpDir.replace('\\', '/')), + ('%/s', escapeSpaces(normSourcePath)), + ('%/S', escapeSpaces(normSourceDir)), + ('%/p', escapeSpaces(normSourceDir)), + ('%/t', escapeSpaces(normTmpBase + '.tmp')), + ('%/T', escapeSpaces(normTmpDir)), ]) - # "%:[STpst]" are paths without colons. + # "%^/[STpst]" should be normalized and unescaped. + substitutions.extend([ + ('%\^/s', normSourcePath), + ('%\^/S', normSourceDir), + ('%\^/p', normSourceDir), + ('%\^/t', normTmpBase + '.tmp'), + ('%\^/T', normTmpDir), + ]) + + # "%:[STpst]" are escaped paths without colons. + if kIsWindows: + substitutions.extend([ + ('%:s', re.sub(r'^(.):', r'\1', escapedSourcePath)), + ('%:S', re.sub(r'^(.):', r'\1', escapedSourceDir)), + ('%:p', re.sub(r'^(.):', r'\1', escapedSourceDir)), + ('%:t', re.sub(r'^(.):', r'\1', escapedTmpBase) + '.tmp'), + ('%:T', re.sub(r'^(.):', r'\1', escapedTmpDir)), + ]) + else: + substitutions.extend([ + ('%:s', escapedSourcePath), + ('%:S', escapedSourceDir), + ('%:p', escapedSourceDir), + ('%:t', escapedTmpBase + '.tmp'), + ('%:T', escapedTmpDir), + ]) + + # "%^:[STpst]" are unescaped paths without colons. if kIsWindows: substitutions.extend([ - ('%:s', re.sub(r'^(.):', r'\1', sourcepath)), - ('%:S', re.sub(r'^(.):', r'\1', sourcedir)), - ('%:p', re.sub(r'^(.):', r'\1', sourcedir)), - ('%:t', re.sub(r'^(.):', r'\1', tmpBase) + '.tmp'), - ('%:T', re.sub(r'^(.):', r'\1', tmpDir)), + ('%\^:s', re.sub(r'^(.):', r'\1', sourcePath)), + ('%\^:S', re.sub(r'^(.):', r'\1', sourceDir)), + ('%\^:p', re.sub(r'^(.):', r'\1', sourceDir)), + ('%\^:t', re.sub(r'^(.):', r'\1', tmpBase) + '.tmp'), + ('%\^:T', re.sub(r'^(.):', r'\1', tmpDir)), ]) else: substitutions.extend([ - ('%:s', sourcepath), - ('%:S', sourcedir), - ('%:p', sourcedir), - ('%:t', tmpBase + '.tmp'), - ('%:T', tmpDir), + ('%\^:s', sourcePath), + ('%\^:S', sourceDir), + ('%\^:p', sourceDir), + ('%\^:t', tmpBase + '.tmp'), + ('%\^:T', tmpDir), ]) return substitutions Index: lit/lit/util.py =================================================================== --- lit/lit/util.py +++ lit/lit/util.py @@ -27,6 +27,25 @@ except UnicodeError: return str(bytes) +def escapeChar (win32Escapes): + if win32Escapes: + return '^' + else: + return '\\' + +def escapeSpaces (s): + """ + Escapes spaces in strings. Igores whitespace at the start and end of the + string. + """ + first = len(s) - len(s.lstrip()) + last = len(s.rstrip()) + + escape = escapeChar('win32' == sys.platform) + escapedStr = s[first:last].replace(' ', escape + ' ') + + return s[:first] + escapedStr + s[last:] + def detectCPUs(): """ Detects the number of CPUs on a system. Cribbed from pp. Index: lit/tests/lit.cfg =================================================================== --- lit/tests/lit.cfg +++ lit/tests/lit.cfg @@ -27,12 +27,14 @@ src_root = os.path.join(config.test_source_root, '..') config.environment['PYTHONPATH'] = src_root -config.substitutions.append(('%{src_root}', src_root)) -config.substitutions.append(('%{inputs}', os.path.join( - src_root, 'tests', 'Inputs'))) + +# escaped versions +config.substitutions.append(('%{src_root}', lit.util.escapeSpaces(src_root))) +config.substitutions.append(('%{inputs}', lit.util.escapeSpaces(os.path.join( + src_root, 'tests', 'Inputs')))) config.substitutions.append(('%{lit}', "%%{python} %s" % ( - os.path.join(src_root, 'lit.py'),))) -config.substitutions.append(('%{python}', sys.executable)) + lit.util.escapeSpaces(os.path.join(src_root, 'lit.py')),))) +config.substitutions.append(('%{python}', lit.util.escapeSpaces(sys.executable))) # Enable coverage.py reporting, assuming the coverage module has been installed # and sitecustomize.py in the virtualenv has been modified appropriately. Index: lit/tests/unit/ShUtil.py =================================================================== --- lit/tests/unit/ShUtil.py +++ lit/tests/unit/ShUtil.py @@ -37,6 +37,8 @@ ["", ""]) self.assertEqual(self.lex(""" a\\ b """, win32Escapes = True), ['a\\', 'b']) + self.assertEqual(self.lex(""" a^ b """, win32Escapes = True), + ['a b']) class TestShParse(unittest.TestCase): def parse(self, str): Index: modules/AddLLVM.cmake =================================================================== --- modules/AddLLVM.cmake +++ modules/AddLLVM.cmake @@ -95,7 +95,7 @@ LINK_FLAGS " -Wl,-M,${CMAKE_CURRENT_BINARY_DIR}/${native_export_file}") else() set_property(TARGET ${target_name} APPEND_STRING PROPERTY - LINK_FLAGS " -Wl,--version-script,${CMAKE_CURRENT_BINARY_DIR}/${native_export_file}") + LINK_FLAGS " -Wl,--version-script,\"${CMAKE_CURRENT_BINARY_DIR}/${native_export_file}\"") endif() else() set(native_export_file "${target_name}.def") @@ -1429,7 +1429,7 @@ elseif(${CMAKE_SYSTEM_NAME} STREQUAL "Linux" AND NOT LLVM_LINKER_IS_GOLD) # $ORIGIN is not interpreted at link time by ld.bfd set_property(TARGET ${name} APPEND_STRING PROPERTY - LINK_FLAGS " -Wl,-rpath-link,${LLVM_LIBRARY_OUTPUT_INTDIR} ") + LINK_FLAGS " -Wl,-rpath-link,\"${LLVM_LIBRARY_OUTPUT_INTDIR}\" ") endif() else() return() Index: tools/llvm-profdata/input-dir.test =================================================================== --- tools/llvm-profdata/input-dir.test +++ tools/llvm-profdata/input-dir.test @@ -1,7 +1,7 @@ # Create an input file. RUN: echo "#" > %t.input -RUN: echo "%t.dir1" >> %t.input -RUN: echo "2,%t.dir2" >> %t.input +RUN: echo "%^t.dir1" >> %t.input +RUN: echo "2,%^t.dir2" >> %t.input RUN: mkdir -p %t.dir1 RUN: mkdir -p %t.dir2/subdir Index: tools/llvm-profdata/input-filenames.test =================================================================== --- tools/llvm-profdata/input-filenames.test +++ tools/llvm-profdata/input-filenames.test @@ -1,9 +1,9 @@ # Create an input file. RUN: echo '# comment 1' > %t.input RUN: echo ' # comment 2' >> %t.input -RUN: echo " %t.bar" >> %t.input -RUN: echo " %t.baz" >> %t.input -RUN: echo "2,%t.weighted" >> %t.input +RUN: echo " %^t.bar" >> %t.input +RUN: echo " %^t.baz" >> %t.input +RUN: echo "2,%^t.weighted" >> %t.input RUN: echo ' ' > %t.weighted RUN: echo ' ' > %t.foo Index: tools/llvm-symbolizer/coff-dwarf.test =================================================================== --- tools/llvm-symbolizer/coff-dwarf.test +++ tools/llvm-symbolizer/coff-dwarf.test @@ -1,5 +1,5 @@ RUN: grep '^ADDR:' %s | sed -s 's/ADDR: //' \ -RUN: | llvm-symbolizer --inlining --relative-address -obj="%p/Inputs/coff-dwarf.exe" \ +RUN: | llvm-symbolizer --inlining --relative-address -obj="%^p/Inputs/coff-dwarf.exe" \ RUN: | FileCheck %s This test relies on UnDecorateSymbolName, which is Windows-only. Index: tools/llvm-symbolizer/coff-exports.test =================================================================== --- tools/llvm-symbolizer/coff-exports.test +++ tools/llvm-symbolizer/coff-exports.test @@ -1,5 +1,5 @@ RUN: grep '^ADDR:' %s | sed -s 's/ADDR: //' \ -RUN: | llvm-symbolizer --inlining --relative-address -obj="%p/Inputs/coff-exports.exe" \ +RUN: | llvm-symbolizer --inlining --relative-address -obj="%^p/Inputs/coff-exports.exe" \ RUN: | FileCheck %s This test relies on UnDecorateSymbolName, which is Win32-only. Index: tools/llvm-symbolizer/dsym.test =================================================================== --- tools/llvm-symbolizer/dsym.test +++ tools/llvm-symbolizer/dsym.test @@ -1,5 +1,5 @@ -RUN: echo "%p/Inputs/dsym-test-exe 0x0000000100000f90" > %t.input -RUN: echo "%p/Inputs/dsym-test-exe-second 0x0000000100000f90" >> %t.input +RUN: echo "\"%^p/Inputs/dsym-test-exe\" 0x0000000100000f90" > %t.input +RUN: echo "\"%^p/Inputs/dsym-test-exe-second\" 0x0000000100000f90" >> %t.input RUN: llvm-symbolizer < %t.input | FileCheck %s --check-prefix=CHECK-NOHINT RUN: llvm-symbolizer -dsym-hint=%p/Inputs/dsym-test-exe-differentname.dSYM < %t.input | FileCheck %s --check-prefix=CHECK-HINT Index: tools/sanstats/elf.test =================================================================== --- tools/sanstats/elf.test +++ tools/sanstats/elf.test @@ -3,7 +3,7 @@ # RUN: printf "\x04" > %t.stats -# RUN: printf "%%s" "%t1.o" >> %t.stats +# RUN: printf "%%s" %t1.o >> %t.stats # RUN: printf "\x00" >> %t.stats # RUN: printf "\x01\x00\x00\x00\x01\x00\x00\x00" >> %t.stats # RUN: printf "\x11\x00\x00\x00\x02\x00\x00\x20" >> %t.stats @@ -13,7 +13,7 @@ # RUN: printf "\x21\x00\x00\x00\x06\x00\x00\xa0" >> %t.stats # RUN: printf "\x00\x00\x00\x00\x00\x00\x00\x00" >> %t.stats -# RUN: printf "%%s" "%t2.o" >> %t.stats +# RUN: printf "%%s" %t2.o >> %t.stats # RUN: printf "\x00" >> %t.stats # RUN: printf "\x21\x00\x00\x00\x07\x00\x00\x00" >> %t.stats # RUN: printf "\x11\x00\x00\x00\x08\x00\x00\x20" >> %t.stats