## @file\r
# This file is used to define each component of tools_def.txt file\r
#\r
-# Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR>\r
+# Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>\r
# This program and the accompanying materials\r
# are licensed and made available under the terms and conditions of the BSD License\r
# which accompanies this distribution. The full text of the license may be found at\r
import re\r
import EdkLogger\r
\r
-from Dictionary import *\r
from BuildToolError import *\r
from TargetTxtClassObject import *\r
from Common.LongFilePathSupport import OpenLongFilePath as open\r
from Common.Misc import PathClass\r
-from Common.String import NormPath\r
+from Common.StringUtils import NormPath\r
import Common.GlobalData as GlobalData\r
from Common import GlobalData\r
from Common.MultipleWorkspace import MultipleWorkspace as mws\r
+from DataType import TAB_TOD_DEFINES_TARGET, TAB_TOD_DEFINES_TOOL_CHAIN_TAG,\\r
+ TAB_TOD_DEFINES_TARGET_ARCH, TAB_TOD_DEFINES_COMMAND_TYPE\\r
+ , TAB_TOD_DEFINES_FAMILY, TAB_TOD_DEFINES_BUILDRULEFAMILY\r
+\r
\r
##\r
# Static variables used for pattern\r
for Env in os.environ:\r
self.MacroDictionary["ENV(%s)" % Env] = os.environ[Env]\r
\r
- if FileName != None:\r
+ if FileName is not None:\r
self.LoadToolDefFile(FileName)\r
\r
## LoadToolDefFile\r
\r
KeyList = [TAB_TOD_DEFINES_TARGET, TAB_TOD_DEFINES_TOOL_CHAIN_TAG, TAB_TOD_DEFINES_TARGET_ARCH, TAB_TOD_DEFINES_COMMAND_TYPE]\r
for Index in range(3, -1, -1):\r
- for Key in dict(self.ToolsDefTxtDictionary):\r
+ # make a copy of the keys to enumerate over to prevent issues when\r
+ # adding/removing items from the original dict.\r
+ for Key in list(self.ToolsDefTxtDictionary.keys()):\r
List = Key.split('_')\r
if List[Index] == '*':\r
for String in self.ToolsDefTxtDatabase[KeyList[Index]]:\r
NewKey = '%s_%s_%s_%s_%s' % tuple(List)\r
if NewKey not in self.ToolsDefTxtDictionary:\r
self.ToolsDefTxtDictionary[NewKey] = self.ToolsDefTxtDictionary[Key]\r
- continue\r
del self.ToolsDefTxtDictionary[Key]\r
elif List[Index] not in self.ToolsDefTxtDatabase[KeyList[Index]]:\r
del self.ToolsDefTxtDictionary[Key]\r
if ErrorCode != 0:\r
EdkLogger.error("tools_def.txt parser", FILE_NOT_FOUND, ExtraData=IncFile)\r
\r
- if type(IncFileTmp) is PathClass:\r
+ if isinstance(IncFileTmp, PathClass):\r
IncFile = IncFileTmp.Path\r
else:\r
IncFile = IncFileTmp\r
# @retval Value: The string which has been replaced with real value\r
#\r
def ExpandMacros(self, Value):\r
+ # os.environ contains all environment variables uppercase on Windows which cause the key in the self.MacroDictionary is uppercase, but Ref may not\r
EnvReference = gEnvRefPattern.findall(Value)\r
for Ref in EnvReference:\r
- if Ref not in self.MacroDictionary:\r
+ if Ref not in self.MacroDictionary and Ref.upper() not in self.MacroDictionary:\r
Value = Value.replace(Ref, "")\r
else:\r
- Value = Value.replace(Ref, self.MacroDictionary[Ref])\r
- \r
-\r
+ if Ref in self.MacroDictionary:\r
+ Value = Value.replace(Ref, self.MacroDictionary[Ref])\r
+ else:\r
+ Value = Value.replace(Ref, self.MacroDictionary[Ref.upper()])\r
MacroReference = gMacroRefPattern.findall(Value)\r
for Ref in MacroReference:\r
if Ref not in self.MacroDictionary:\r