# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
#\r
\r
+from __future__ import print_function\r
import Common.LongFilePathOs as os\r
import sys\r
import traceback\r
self.Arg = args[0]\r
self.FileName = os.path.normpath(os.path.join(self.WorkSpace, 'Conf', 'target.txt'))\r
if os.path.isfile(self.FileName) == False:\r
- print "%s does not exist." % self.FileName\r
+ print("%s does not exist." % self.FileName)\r
sys.exit(1)\r
self.TargetTxtDictionary = {\r
TAB_TAT_DEFINES_ACTIVE_PLATFORM : None,\r
def ConvertTextFileToDict(self, FileName, CommentCharacter, KeySplitCharacter):\r
"""Convert a text file to a dictionary of (name:value) pairs."""\r
try:\r
- f = open(FileName,'r')\r
+ f = open(FileName, 'r')\r
for Line in f:\r
if Line.startswith(CommentCharacter) or Line.strip() == '':\r
continue\r
- LineList = Line.split(KeySplitCharacter,1)\r
+ LineList = Line.split(KeySplitCharacter, 1)\r
if len(LineList) >= 2:\r
Key = LineList[0].strip()\r
if Key.startswith(CommentCharacter) == False and Key in self.TargetTxtDictionary:\r
def Print(self):\r
errMsg = ''\r
for Key in self.TargetTxtDictionary:\r
- if type(self.TargetTxtDictionary[Key]) == type([]):\r
- print "%-30s = %s" % (Key, ''.join(elem + ' ' for elem in self.TargetTxtDictionary[Key]))\r
+ if isinstance(self.TargetTxtDictionary[Key], type([])):\r
+ print("%-30s = %s" % (Key, ''.join(elem + ' ' for elem in self.TargetTxtDictionary[Key])))\r
elif self.TargetTxtDictionary[Key] is None:\r
errMsg += " Missing %s configuration information, please use TargetTool to set value!" % Key + os.linesep \r
else:\r
- print "%-30s = %s" % (Key, self.TargetTxtDictionary[Key])\r
+ print("%-30s = %s" % (Key, self.TargetTxtDictionary[Key]))\r
\r
if errMsg != '':\r
- print os.linesep + 'Warning:' + os.linesep + errMsg\r
+ print(os.linesep + 'Warning:' + os.linesep + errMsg)\r
\r
def RWFile(self, CommentCharacter, KeySplitCharacter, Num):\r
try:\r
if Line.startswith(CommentCharacter) or Line.strip() == '':\r
fw.write(Line)\r
else:\r
- LineList = Line.split(KeySplitCharacter,1)\r
+ LineList = Line.split(KeySplitCharacter, 1)\r
if len(LineList) >= 2:\r
Key = LineList[0].strip()\r
if Key.startswith(CommentCharacter) == False and Key in self.TargetTxtDictionary:\r
if Key not in existKeys:\r
existKeys.append(Key)\r
else:\r
- print "Warning: Found duplicate key item in original configuration files!"\r
+ print("Warning: Found duplicate key item in original configuration files!")\r
\r
if Num == 0:\r
Line = "%-30s = \n" % Key\r
fw.write(Line)\r
for key in self.TargetTxtDictionary:\r
if key not in existKeys:\r
- print "Warning: %s does not exist in original configuration file" % key\r
+ print("Warning: %s does not exist in original configuration file" % key)\r
Line = GetConfigureKeyValue(self, key)\r
if Line is None:\r
Line = "%-30s = " % key\r
parser.error("Option %s only allows one instance in command line!" % option)\r
\r
def MyOptionParser():\r
- parser = OptionParser(version=__version__,prog="TargetTool.exe",usage=__usage__,description=__copyright__)\r
- parser.add_option("-a", "--arch", action="append", type="choice", choices=['IA32','X64','IPF','EBC', 'ARM', 'AARCH64','0'], dest="TARGET_ARCH",\r
+ parser = OptionParser(version=__version__, prog="TargetTool.exe", usage=__usage__, description=__copyright__)\r
+ parser.add_option("-a", "--arch", action="append", type="choice", choices=['IA32', 'X64', 'IPF', 'EBC', 'ARM', 'AARCH64', '0'], dest="TARGET_ARCH",\r
help="ARCHS is one of list: IA32, X64, IPF, ARM, AARCH64 or EBC, which replaces target.txt's TARGET_ARCH definition. To specify more archs, please repeat this option. 0 will clear this setting in target.txt and can't combine with other value.")\r
parser.add_option("-p", "--platform", action="callback", type="string", dest="DSCFILE", callback=SingleCheckCallback,\r
help="Specify a DSC file, which replace target.txt's ACTIVE_PLATFORM definition. 0 will clear this setting in target.txt and can't combine with other value.")\r
parser.add_option("-c", "--tooldef", action="callback", type="string", dest="TOOL_DEFINITION_FILE", callback=SingleCheckCallback,\r
help="Specify the WORKSPACE relative path of tool_def.txt file, which replace target.txt's TOOL_CHAIN_CONF definition. 0 will clear this setting in target.txt and can't combine with other value.")\r
- parser.add_option("-t", "--target", action="append", type="choice", choices=['DEBUG','RELEASE','0'], dest="TARGET",\r
+ parser.add_option("-t", "--target", action="append", type="choice", choices=['DEBUG', 'RELEASE', '0'], dest="TARGET",\r
help="TARGET is one of list: DEBUG, RELEASE, which replaces target.txt's TARGET definition. To specify more TARGET, please repeat this option. 0 will clear this setting in target.txt and can't combine with other value.")\r
parser.add_option("-n", "--tagname", action="callback", type="string", dest="TOOL_CHAIN_TAG", callback=SingleCheckCallback,\r
help="Specify the Tool Chain Tagname, which replaces target.txt's TOOL_CHAIN_TAG definition. 0 will clear this setting in target.txt and can't combine with other value.")\r
EdkLogger.Initialize()\r
EdkLogger.SetLevel(EdkLogger.QUIET)\r
if os.getenv('WORKSPACE') is None:\r
- print "ERROR: WORKSPACE should be specified or edksetup script should be executed before run TargetTool"\r
+ print("ERROR: WORKSPACE should be specified or edksetup script should be executed before run TargetTool")\r
sys.exit(1)\r
\r
(opt, args) = MyOptionParser()\r
if len(args) != 1 or (args[0].lower() != 'print' and args[0].lower() != 'clean' and args[0].lower() != 'set'):\r
- print "The number of args isn't 1 or the value of args is invalid."\r
+ print("The number of args isn't 1 or the value of args is invalid.")\r
sys.exit(1)\r
if opt.NUM is not None and opt.NUM < 1:\r
- print "The MAX_CONCURRENT_THREAD_NUMBER must be larger than 0."\r
+ print("The MAX_CONCURRENT_THREAD_NUMBER must be larger than 0.")\r
sys.exit(1)\r
if opt.TARGET is not None and len(opt.TARGET) > 1:\r
for elem in opt.TARGET:\r
if elem == '0':\r
- print "0 will clear the TARGET setting in target.txt and can't combine with other value."\r
+ print("0 will clear the TARGET setting in target.txt and can't combine with other value.")\r
sys.exit(1)\r
if opt.TARGET_ARCH is not None and len(opt.TARGET_ARCH) > 1:\r
for elem in opt.TARGET_ARCH:\r
if elem == '0':\r
- print "0 will clear the TARGET_ARCH setting in target.txt and can't combine with other value."\r
+ print("0 will clear the TARGET_ARCH setting in target.txt and can't combine with other value.")\r
sys.exit(1)\r
\r
try:\r
FileHandle.RWFile('#', '=', 0)\r
else:\r
FileHandle.RWFile('#', '=', 1)\r
- except Exception, e:\r
+ except Exception as e:\r
last_type, last_value, last_tb = sys.exc_info()\r
traceback.print_exception(last_type, last_value, last_tb)\r
\r