From 9c5564e060b019d154b07fca3513443039266145 Mon Sep 17 00:00:00 2001 From: Deepanshu Gupta Date: Tue, 15 Jul 2014 17:22:00 -0700 Subject: Fix incremental builds for SDK. Atree used to output files without escaping the filenames. This resulted in breaks for incremental builds when filenames contained '$' symbol. The change fixes this by escaping the filename properly. Change-Id: I957787b1b3536c64ba6fcb5b4bb5fc60e8b04452 --- tools/atree/atree.cpp | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) (limited to 'tools/atree') diff --git a/tools/atree/atree.cpp b/tools/atree/atree.cpp index 2ba284f..b134e01 100644 --- a/tools/atree/atree.cpp +++ b/tools/atree/atree.cpp @@ -90,6 +90,26 @@ debug_printf(const char* format, ...) } } +// Escape the filename so that it can be added to the makefile properly. +static string +escape_filename(const string name) +{ + ostringstream new_name; + for (string::const_iterator iter = name.begin(); iter != name.end(); ++iter) + { + switch (*iter) + { + case '$': + new_name << "$$"; + break; + default: + new_name << *iter; + break; + } + } + return new_name.str(); +} + int main(int argc, char* const* argv) { @@ -324,7 +344,8 @@ main(int argc, char* const* argv) for (vector::iterator it=files.begin(); it!=files.end(); it++) { if (!it->sourceIsDir) { - fprintf(f, "%s \\\n", it->sourcePath.c_str()); + fprintf(f, "%s \\\n", + escape_filename(it->sourcePath).c_str()); } } fprintf(f, "\n"); -- cgit v1.1