2009-07-17 11:10:31 +02:00
|
|
|
## @file
|
|
|
|
# This file is used to define each component of Target.txt file
|
|
|
|
#
|
2014-08-15 05:06:48 +02:00
|
|
|
# Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:03:11 +02:00
|
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
|
|
|
|
|
|
|
##
|
|
|
|
# Import Modules
|
|
|
|
#
|
2018-10-15 02:27:53 +02:00
|
|
|
from __future__ import print_function
|
|
|
|
from __future__ import absolute_import
|
2020-01-10 09:29:45 +01:00
|
|
|
|
2019-07-22 08:23:40 +02:00
|
|
|
import Common.GlobalData as GlobalData
|
2014-08-15 05:06:48 +02:00
|
|
|
import Common.LongFilePathOs as os
|
2018-07-13 12:18:40 +02:00
|
|
|
from . import EdkLogger
|
|
|
|
from . import DataType
|
|
|
|
from .BuildToolError import *
|
2019-07-22 08:23:40 +02:00
|
|
|
|
2014-08-15 05:06:48 +02:00
|
|
|
from Common.LongFilePathSupport import OpenLongFilePath as open
|
2019-07-22 08:23:40 +02:00
|
|
|
from Common.MultipleWorkspace import MultipleWorkspace as mws
|
2009-07-17 11:10:31 +02:00
|
|
|
|
2014-08-28 15:53:34 +02:00
|
|
|
gDefaultTargetTxtFile = "target.txt"
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## TargetTxtClassObject
|
|
|
|
#
|
|
|
|
# This class defined content used in file target.txt
|
|
|
|
#
|
|
|
|
# @param object: Inherited from object class
|
|
|
|
# @param Filename: Input value for full path of target.txt
|
|
|
|
#
|
|
|
|
# @var TargetTxtDictionary: To store keys and values defined in target.txt
|
|
|
|
#
|
|
|
|
class TargetTxtClassObject(object):
|
|
|
|
def __init__(self, Filename = None):
|
|
|
|
self.TargetTxtDictionary = {
|
|
|
|
DataType.TAB_TAT_DEFINES_ACTIVE_PLATFORM : '',
|
|
|
|
DataType.TAB_TAT_DEFINES_ACTIVE_MODULE : '',
|
|
|
|
DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF : '',
|
|
|
|
DataType.TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER : '',
|
|
|
|
DataType.TAB_TAT_DEFINES_TARGET : [],
|
|
|
|
DataType.TAB_TAT_DEFINES_TOOL_CHAIN_TAG : [],
|
|
|
|
DataType.TAB_TAT_DEFINES_TARGET_ARCH : [],
|
|
|
|
DataType.TAB_TAT_DEFINES_BUILD_RULE_CONF : '',
|
|
|
|
}
|
2014-08-28 15:53:34 +02:00
|
|
|
self.ConfDirectoryPath = ""
|
2018-03-26 22:25:43 +02:00
|
|
|
if Filename is not None:
|
2009-07-17 11:10:31 +02:00
|
|
|
self.LoadTargetTxtFile(Filename)
|
|
|
|
|
|
|
|
## LoadTargetTxtFile
|
|
|
|
#
|
|
|
|
# Load target.txt file and parse it, return a set structure to store keys and values
|
|
|
|
#
|
|
|
|
# @param Filename: Input value for full path of target.txt
|
|
|
|
#
|
|
|
|
# @retval set() A set structure to store keys and values
|
|
|
|
# @retval 1 Error happenes in parsing
|
|
|
|
#
|
|
|
|
def LoadTargetTxtFile(self, Filename):
|
|
|
|
if os.path.exists(Filename) and os.path.isfile(Filename):
|
|
|
|
return self.ConvertTextFileToDict(Filename, '#', '=')
|
|
|
|
else:
|
|
|
|
EdkLogger.error("Target.txt Parser", FILE_NOT_FOUND, ExtraData=Filename)
|
|
|
|
return 1
|
|
|
|
|
|
|
|
## ConvertTextFileToDict
|
|
|
|
#
|
|
|
|
# Convert a text file to a dictionary of (name:value) pairs.
|
|
|
|
# The data is saved to self.TargetTxtDictionary
|
|
|
|
#
|
|
|
|
# @param FileName: Text filename
|
|
|
|
# @param CommentCharacter: Comment char, be used to ignore comment content
|
|
|
|
# @param KeySplitCharacter: Key split char, between key name and key value. Key1 = Value1, '=' is the key split char
|
|
|
|
#
|
|
|
|
# @retval 0 Convert successfully
|
|
|
|
# @retval 1 Open file failed
|
|
|
|
#
|
|
|
|
def ConvertTextFileToDict(self, FileName, CommentCharacter, KeySplitCharacter):
|
|
|
|
F = None
|
|
|
|
try:
|
2014-08-28 15:53:34 +02:00
|
|
|
F = open(FileName, 'r')
|
|
|
|
self.ConfDirectoryPath = os.path.dirname(FileName)
|
2009-07-17 11:10:31 +02:00
|
|
|
except:
|
|
|
|
EdkLogger.error("build", FILE_OPEN_FAILURE, ExtraData=FileName)
|
2018-03-26 22:25:43 +02:00
|
|
|
if F is not None:
|
2009-07-17 11:10:31 +02:00
|
|
|
F.close()
|
|
|
|
|
|
|
|
for Line in F:
|
|
|
|
Line = Line.strip()
|
|
|
|
if Line.startswith(CommentCharacter) or Line == '':
|
|
|
|
continue
|
|
|
|
|
|
|
|
LineList = Line.split(KeySplitCharacter, 1)
|
|
|
|
Key = LineList[0].strip()
|
|
|
|
if len(LineList) == 2:
|
|
|
|
Value = LineList[1].strip()
|
|
|
|
else:
|
|
|
|
Value = ""
|
|
|
|
|
|
|
|
if Key in [DataType.TAB_TAT_DEFINES_ACTIVE_PLATFORM, DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF, \
|
|
|
|
DataType.TAB_TAT_DEFINES_ACTIVE_MODULE, DataType.TAB_TAT_DEFINES_BUILD_RULE_CONF]:
|
|
|
|
self.TargetTxtDictionary[Key] = Value.replace('\\', '/')
|
2014-08-28 15:53:34 +02:00
|
|
|
if Key == DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF and self.TargetTxtDictionary[Key]:
|
|
|
|
if self.TargetTxtDictionary[Key].startswith("Conf/"):
|
|
|
|
Tools_Def = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())
|
|
|
|
if not os.path.exists(Tools_Def) or not os.path.isfile(Tools_Def):
|
|
|
|
# If Conf/Conf does not exist, try just the Conf/ directory
|
|
|
|
Tools_Def = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].replace("Conf/", "", 1).strip())
|
|
|
|
else:
|
|
|
|
# The File pointed to by TOOL_CHAIN_CONF is not in a Conf/ directory
|
|
|
|
Tools_Def = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())
|
|
|
|
self.TargetTxtDictionary[Key] = Tools_Def
|
|
|
|
if Key == DataType.TAB_TAT_DEFINES_BUILD_RULE_CONF and self.TargetTxtDictionary[Key]:
|
|
|
|
if self.TargetTxtDictionary[Key].startswith("Conf/"):
|
|
|
|
Build_Rule = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())
|
|
|
|
if not os.path.exists(Build_Rule) or not os.path.isfile(Build_Rule):
|
|
|
|
# If Conf/Conf does not exist, try just the Conf/ directory
|
|
|
|
Build_Rule = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].replace("Conf/", "", 1).strip())
|
|
|
|
else:
|
|
|
|
# The File pointed to by BUILD_RULE_CONF is not in a Conf/ directory
|
|
|
|
Build_Rule = os.path.join(self.ConfDirectoryPath, self.TargetTxtDictionary[Key].strip())
|
|
|
|
self.TargetTxtDictionary[Key] = Build_Rule
|
2009-07-17 11:10:31 +02:00
|
|
|
elif Key in [DataType.TAB_TAT_DEFINES_TARGET, DataType.TAB_TAT_DEFINES_TARGET_ARCH, \
|
|
|
|
DataType.TAB_TAT_DEFINES_TOOL_CHAIN_TAG]:
|
|
|
|
self.TargetTxtDictionary[Key] = Value.split()
|
|
|
|
elif Key == DataType.TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER:
|
|
|
|
try:
|
|
|
|
V = int(Value, 0)
|
|
|
|
except:
|
|
|
|
EdkLogger.error("build", FORMAT_INVALID, "Invalid number of [%s]: %s." % (Key, Value),
|
|
|
|
File=FileName)
|
|
|
|
self.TargetTxtDictionary[Key] = Value
|
|
|
|
#elif Key not in GlobalData.gGlobalDefines:
|
|
|
|
# GlobalData.gGlobalDefines[Key] = Value
|
|
|
|
|
|
|
|
F.close()
|
|
|
|
return 0
|
|
|
|
|
|
|
|
## TargetTxtDict
|
|
|
|
#
|
2014-08-28 15:53:34 +02:00
|
|
|
# Load target.txt in input Conf dir
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
2014-08-28 15:53:34 +02:00
|
|
|
# @param ConfDir: Conf dir
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
|
|
|
# @retval Target An instance of TargetTxtClassObject() with loaded target.txt
|
|
|
|
#
|
2020-01-10 09:29:45 +01:00
|
|
|
|
|
|
|
class TargetTxtDict():
|
|
|
|
|
|
|
|
def __new__(cls, *args, **kw):
|
|
|
|
if not hasattr(cls, '_instance'):
|
|
|
|
orig = super(TargetTxtDict, cls)
|
|
|
|
cls._instance = orig.__new__(cls, *args, **kw)
|
|
|
|
return cls._instance
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
if not hasattr(self, 'Target'):
|
|
|
|
self.TxtTarget = None
|
|
|
|
|
|
|
|
@property
|
|
|
|
def Target(self):
|
|
|
|
if not self.TxtTarget:
|
|
|
|
self._GetTarget()
|
|
|
|
return self.TxtTarget
|
|
|
|
|
|
|
|
def _GetTarget(self):
|
|
|
|
Target = TargetTxtClassObject()
|
|
|
|
ConfDirectory = GlobalData.gCmdConfDir
|
|
|
|
if ConfDirectory:
|
|
|
|
# Get alternate Conf location, if it is absolute, then just use the absolute directory name
|
|
|
|
ConfDirectoryPath = os.path.normpath(ConfDirectory)
|
|
|
|
|
|
|
|
if not os.path.isabs(ConfDirectoryPath):
|
|
|
|
# Since alternate directory name is not absolute, the alternate directory is located within the WORKSPACE
|
|
|
|
# This also handles someone specifying the Conf directory in the workspace. Using --conf=Conf
|
|
|
|
ConfDirectoryPath = mws.join(os.environ["WORKSPACE"], ConfDirectoryPath)
|
2019-07-22 08:23:40 +02:00
|
|
|
else:
|
2020-01-10 09:29:45 +01:00
|
|
|
if "CONF_PATH" in os.environ:
|
|
|
|
ConfDirectoryPath = os.path.normcase(os.path.normpath(os.environ["CONF_PATH"]))
|
|
|
|
else:
|
|
|
|
# Get standard WORKSPACE/Conf use the absolute path to the WORKSPACE/Conf
|
|
|
|
ConfDirectoryPath = mws.join(os.environ["WORKSPACE"], 'Conf')
|
|
|
|
GlobalData.gConfDirectory = ConfDirectoryPath
|
|
|
|
targettxt = os.path.normpath(os.path.join(ConfDirectoryPath, gDefaultTargetTxtFile))
|
|
|
|
if os.path.exists(targettxt):
|
|
|
|
Target.LoadTargetTxtFile(targettxt)
|
|
|
|
self.TxtTarget = Target
|
2019-04-13 10:02:02 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# This acts like the main() function for the script, unless it is 'import'ed into another
|
|
|
|
# script.
|
|
|
|
#
|
|
|
|
if __name__ == '__main__':
|
|
|
|
pass
|
|
|
|
Target = TargetTxtDict(os.getenv("WORKSPACE"))
|
2018-06-25 12:31:26 +02:00
|
|
|
print(Target.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER])
|
|
|
|
print(Target.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_TARGET])
|
|
|
|
print(Target.TargetTxtDictionary)
|