Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "tools/gn/visual_studio_writer.h" | 5 #include "tools/gn/visual_studio_writer.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <iterator> | 8 #include <iterator> |
| 9 #include <map> | 9 #include <map> |
| 10 #include <memory> | 10 #include <memory> |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 30 #include "tools/gn/variables.h" | 30 #include "tools/gn/variables.h" |
| 31 #include "tools/gn/visual_studio_utils.h" | 31 #include "tools/gn/visual_studio_utils.h" |
| 32 #include "tools/gn/xml_element_writer.h" | 32 #include "tools/gn/xml_element_writer.h" |
| 33 | 33 |
| 34 #if defined(OS_WIN) | 34 #if defined(OS_WIN) |
| 35 #include "base/win/registry.h" | 35 #include "base/win/registry.h" |
| 36 #endif | 36 #endif |
| 37 | 37 |
| 38 namespace { | 38 namespace { |
| 39 | 39 |
| 40 std::string EscapeString(const std::string& value) { | |
| 41 std::string result; | |
| 42 if (value.find_first_of("<>&\"\t\r\n") != std::string::npos) { | |
|
brettw
2017/04/07 18:16:43
I'd delete this check and always do the loop below
kylix_rd
2017/04/07 19:18:53
Done.
| |
| 43 for (std::string::const_iterator it = value.cbegin(); | |
|
brettw
2017/04/07 18:16:43
I would have used a range-based for loop here whic
kylix_rd
2017/04/07 19:18:53
Yes, that's better.
Done.
| |
| 44 it != value.cend(); | |
| 45 ++it) { | |
| 46 switch (*it) { | |
| 47 case '\n': result += " "; break; | |
|
brucedawson
2017/04/05 18:51:39
Do you have references for the \n, \r, and \t sequ
kylix_rd
2017/04/05 18:55:02
I based it off the code in libxml here: https://cs
| |
| 48 case '\r': result += " "; break; | |
| 49 case '\t': result += "	"; break; | |
| 50 case '"': result += """; break; | |
| 51 case '<': result += "<"; break; | |
| 52 case '>': result += ">"; break; | |
| 53 case '&': result += "&"; break; | |
| 54 default: | |
| 55 result += *it; | |
| 56 } | |
| 57 } | |
| 58 } else | |
|
brettw
2017/04/07 18:16:43
Google style says all arms in an if statement shou
| |
| 59 result = value; | |
| 60 return result; | |
| 61 } | |
| 62 | |
| 40 struct SemicolonSeparatedWriter { | 63 struct SemicolonSeparatedWriter { |
| 41 void operator()(const std::string& value, std::ostream& out) const { | 64 void operator()(const std::string& value, std::ostream& out) const { |
| 42 out << value + ';'; | 65 out << EscapeString(value) + ';'; |
| 43 } | 66 } |
| 44 }; | 67 }; |
| 45 | 68 |
| 46 struct IncludeDirWriter { | 69 struct IncludeDirWriter { |
| 47 explicit IncludeDirWriter(PathOutput& path_output) | 70 explicit IncludeDirWriter(PathOutput& path_output) |
| 48 : path_output_(path_output) {} | 71 : path_output_(path_output) {} |
| 49 ~IncludeDirWriter() = default; | 72 ~IncludeDirWriter() = default; |
| 50 | 73 |
| 51 void operator()(const SourceDir& dir, std::ostream& out) const { | 74 void operator()(const SourceDir& dir, std::ostream& out) const { |
| 52 path_output_.WriteDir(out, dir, PathOutput::DIR_NO_LAST_SLASH); | 75 path_output_.WriteDir(out, dir, PathOutput::DIR_NO_LAST_SLASH); |
| (...skipping 814 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 867 } | 890 } |
| 868 } | 891 } |
| 869 | 892 |
| 870 std::string VisualStudioWriter::GetNinjaTarget(const Target* target) { | 893 std::string VisualStudioWriter::GetNinjaTarget(const Target* target) { |
| 871 std::ostringstream ninja_target_out; | 894 std::ostringstream ninja_target_out; |
| 872 DCHECK(!target->dependency_output_file().value().empty()); | 895 DCHECK(!target->dependency_output_file().value().empty()); |
| 873 ninja_path_output_.WriteFile(ninja_target_out, | 896 ninja_path_output_.WriteFile(ninja_target_out, |
| 874 target->dependency_output_file()); | 897 target->dependency_output_file()); |
| 875 return ninja_target_out.str(); | 898 return ninja_target_out.str(); |
| 876 } | 899 } |
| OLD | NEW |