瀏覽代碼

Xcode: Invert quoting logic to whitelist of characters

Our explicit list of characters that require quoting does not account
for non-ascii characters (e.g. UTF-8) that also need quoting.  Invert
the logic to quote a string unless it contains exclusively a set of
characters we whitelist.
Gregor Jasny 10 年之前
父節點
當前提交
2eee2943cc
共有 1 個文件被更改,包括 5 次插入1 次删除
  1. 5 1
      Source/cmXCodeObject.cxx

+ 5 - 1
Source/cmXCodeObject.cxx

@@ -243,7 +243,11 @@ void cmXCodeObject::PrintString(std::ostream& os,std::string String)
   bool needQuote =
   bool needQuote =
     (String.empty() ||
     (String.empty() ||
      String.find("//") != String.npos ||
      String.find("//") != String.npos ||
-     String.find_first_of(" <>+-*=@[](){},~") != String.npos);
+     String.find_first_not_of(
+       "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
+       "abcdefghijklmnopqrstuvwxyz"
+       "0123456789"
+       "$_./") != String.npos);
   const char* quote = needQuote? "\"" : "";
   const char* quote = needQuote? "\"" : "";
 
 
   // Print the string, quoted and escaped as necessary.
   // Print the string, quoted and escaped as necessary.