summaryrefslogtreecommitdiffstats
path: root/src/graph.cc
diff options
context:
space:
mode:
authorNicholas Hutchinson <nshutchinson@gmail.com>2013-11-30 22:33:02 (GMT)
committerNicholas Hutchinson <nshutchinson@gmail.com>2014-01-06 19:30:28 (GMT)
commit664edba804ddd5363299f2af5183109bdc9715b1 (patch)
treec50e267ade56530904676f103905d4a8a2ba3ba0 /src/graph.cc
parent2517b75781decd49bc82f05f8336c509f7b2c62e (diff)
downloadNinja-664edba804ddd5363299f2af5183109bdc9715b1.zip
Ninja-664edba804ddd5363299f2af5183109bdc9715b1.tar.gz
Ninja-664edba804ddd5363299f2af5183109bdc9715b1.tar.bz2
More robust escaping of $in, $out paths
In summary: don’t escape if the path doesn’t contain problematic characters, otherwise: - Shell: enclose string in single quotes, escape embedded single quotes with the magic quote-backslash-quote sequence - Win32: Escape double quotes by doubling the number of consecutive backslashes that precede them (if any) and adding one more. Finally, double the number of trailing backslashes, and enclose the whole thing in double quotes.
Diffstat (limited to 'src/graph.cc')
-rw-r--r--src/graph.cc15
1 files changed, 6 insertions, 9 deletions
diff --git a/src/graph.cc b/src/graph.cc
index 9801a7b..65f9244 100644
--- a/src/graph.cc
+++ b/src/graph.cc
@@ -250,16 +250,13 @@ string EdgeEnv::MakePathList(vector<Node*>::iterator begin,
char sep) {
string result;
for (vector<Node*>::iterator i = begin; i != end; ++i) {
- if (!result.empty())
- result.push_back(sep);
+ if (!result.empty()) result.push_back(sep);
const string& path = (*i)->path();
- if (path.find(" ") != string::npos) {
- result.append("\"");
- result.append(path);
- result.append("\"");
- } else {
- result.append(path);
- }
+#if _WIN32
+ GetWin32EscapedString(path, &result);
+#else
+ GetShellEscapedString(path, &result);
+#endif
}
return result;
}