\r
def AnalyzePcdExpression(Setting):\r
Setting = Setting.strip()\r
- # There might be escaped quote in a string: \", \\\"\r
- Data = Setting.replace('\\\\', '//').replace('\\\"', '\\\'')\r
+ # There might be escaped quote in a string: \", \\\" , \', \\\'\r
+ Data = Setting\r
# There might be '|' in string and in ( ... | ... ), replace it with '-'\r
NewStr = ''\r
- InStr = False\r
+ InSingleQuoteStr = False\r
+ InDoubleQuoteStr = False\r
Pair = 0\r
- for ch in Data:\r
- if ch == '"':\r
- InStr = not InStr\r
- elif ch == '(' and not InStr:\r
+ for Index, ch in enumerate(Data):\r
+ if ch == '"' and not InSingleQuoteStr:\r
+ if Data[Index - 1] != '\\':\r
+ InDoubleQuoteStr = not InDoubleQuoteStr\r
+ elif ch == "'" and not InDoubleQuoteStr:\r
+ if Data[Index - 1] != '\\':\r
+ InSingleQuoteStr = not InSingleQuoteStr\r
+ elif ch == '(' and not (InSingleQuoteStr or InDoubleQuoteStr):\r
Pair += 1\r
- elif ch == ')' and not InStr:\r
+ elif ch == ')' and not (InSingleQuoteStr or InDoubleQuoteStr):\r
Pair -= 1\r
\r
- if (Pair > 0 or InStr) and ch == TAB_VALUE_SPLIT:\r
+ if (Pair > 0 or InSingleQuoteStr or InDoubleQuoteStr) and ch == TAB_VALUE_SPLIT:\r
NewStr += '-'\r
else:\r
NewStr += ch\r
return Value, 16\r
if Value.startswith('L"') and Value.endswith('"'):\r
# Unicode String\r
- List = list(Value[2:-1])\r
+ # translate escape character\r
+ Value = Value[1:]\r
+ try:\r
+ Value = eval(Value)\r
+ except:\r
+ Value = Value[1:-1]\r
+ List = list(Value)\r
List.reverse()\r
Value = 0\r
for Char in List:\r
return Value, (len(List) + 1) * 2\r
if Value.startswith('"') and Value.endswith('"'):\r
# ASCII String\r
- List = list(Value[1:-1])\r
+ # translate escape character\r
+ try:\r
+ Value = eval(Value)\r
+ except:\r
+ Value = Value[1:-1]\r
+ List = list(Value)\r
List.reverse()\r
Value = 0\r
for Char in List:\r
return Value, len(List) + 1\r
if Value.startswith("L'") and Value.endswith("'"):\r
# Unicode Character Constant\r
- List = list(Value[2:-1])\r
+ # translate escape character\r
+ Value = Value[1:]\r
+ try:\r
+ Value = eval(Value)\r
+ except:\r
+ Value = Value[1:-1]\r
+ List = list(Value)\r
if len(List) == 0:\r
raise BadExpression('Length %s is %s' % (Value, len(List)))\r
List.reverse()\r
return Value, len(List) * 2\r
if Value.startswith("'") and Value.endswith("'"):\r
# Character constant\r
- List = list(Value[1:-1])\r
+ # translate escape character\r
+ try:\r
+ Value = eval(Value)\r
+ except:\r
+ Value = Value[1:-1]\r
+ List = list(Value)\r
if len(List) == 0:\r
raise BadExpression('Length %s is %s' % (Value, len(List)))\r
List.reverse()\r
GlobalData.gSkuids = (self.SkuIdSet)\r
if 'COMMON' in GlobalData.gSkuids:\r
GlobalData.gSkuids.remove('COMMON')\r
+ if self.SkuUsageType == self.SINGLE:\r
+ if len(GlobalData.gSkuids) != 1:\r
+ if 'DEFAULT' in GlobalData.gSkuids:\r
+ GlobalData.gSkuids.remove('DEFAULT')\r
if GlobalData.gSkuids:\r
GlobalData.gSkuids.sort()\r
\r