2009-07-17 11:10:31 +02:00
|
|
|
## @file
|
|
|
|
# This file is used to define each component of the build database
|
|
|
|
#
|
2018-03-17 08:25:32 +01:00
|
|
|
# Copyright (c) 2007 - 2018, 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
|
|
|
#
|
|
|
|
|
2018-09-11 00:18:06 +02:00
|
|
|
from collections import OrderedDict, namedtuple
|
2017-12-22 13:46:15 +01:00
|
|
|
from Common.DataType import *
|
2018-09-25 07:20:46 +02:00
|
|
|
import collections
|
|
|
|
import re
|
|
|
|
from collections import OrderedDict
|
2019-05-09 11:19:56 +02:00
|
|
|
from Common.Misc import CopyDict,ArrayIndex
|
2018-11-08 07:03:38 +01:00
|
|
|
import copy
|
2019-05-09 11:19:56 +02:00
|
|
|
import Common.EdkLogger as EdkLogger
|
|
|
|
from Common.BuildToolError import OPTION_VALUE_INVALID
|
2019-09-04 09:53:37 +02:00
|
|
|
from Common.caching import cached_property
|
2018-09-25 07:20:46 +02:00
|
|
|
StructPattern = re.compile(r'[_a-zA-Z][0-9A-Za-z_\[\]]*$')
|
2019-05-09 11:19:56 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
## PcdClassObject
|
|
|
|
#
|
|
|
|
# This Class is used for PcdObject
|
|
|
|
#
|
|
|
|
# @param object: Inherited from object class
|
|
|
|
# @param Name: Input value for Name of Pcd, default is None
|
|
|
|
# @param Guid: Input value for Guid of Pcd, default is None
|
|
|
|
# @param Type: Input value for Type of Pcd, default is None
|
|
|
|
# @param DatumType: Input value for DatumType of Pcd, default is None
|
|
|
|
# @param Value: Input value for Value of Pcd, default is None
|
|
|
|
# @param Token: Input value for Token of Pcd, default is None
|
|
|
|
# @param MaxDatumSize: Input value for MaxDatumSize of Pcd, default is None
|
|
|
|
# @param SkuInfoList: Input value for SkuInfoList of Pcd, default is {}
|
|
|
|
# @param IsOverrided: Input value for IsOverrided of Pcd, default is False
|
2010-09-06 03:58:00 +02:00
|
|
|
# @param GuidValue: Input value for TokenSpaceGuidValue of Pcd, default is None
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
|
|
|
# @var TokenCName: To store value for TokenCName
|
|
|
|
# @var TokenSpaceGuidCName: To store value for TokenSpaceGuidCName
|
|
|
|
# @var Type: To store value for Type
|
|
|
|
# @var DatumType: To store value for DatumType
|
|
|
|
# @var TokenValue: To store value for TokenValue
|
|
|
|
# @var MaxDatumSize: To store value for MaxDatumSize
|
|
|
|
# @var SkuInfoList: To store value for SkuInfoList
|
|
|
|
# @var IsOverrided: To store value for IsOverrided
|
|
|
|
# @var Phase: To store value for Phase, default is "DXE"
|
|
|
|
#
|
|
|
|
class PcdClassObject(object):
|
2018-09-25 07:20:46 +02:00
|
|
|
def __init__(self, Name = None, Guid = None, Type = None, DatumType = None, Value = None, Token = None, MaxDatumSize = None, SkuInfoList = None, IsOverrided = False, GuidValue = None, validateranges = None, validlists = None, expressions = None, IsDsc = False, UserDefinedDefaultStoresFlag = False):
|
2009-07-17 11:10:31 +02:00
|
|
|
self.TokenCName = Name
|
|
|
|
self.TokenSpaceGuidCName = Guid
|
|
|
|
self.TokenSpaceGuidValue = GuidValue
|
|
|
|
self.Type = Type
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
self._DatumType = DatumType
|
2009-07-17 11:10:31 +02:00
|
|
|
self.DefaultValue = Value
|
|
|
|
self.TokenValue = Token
|
|
|
|
self.MaxDatumSize = MaxDatumSize
|
2018-03-17 08:25:32 +01:00
|
|
|
self.MaxSizeUserSet = None
|
2018-09-25 07:20:46 +02:00
|
|
|
self.SkuInfoList = SkuInfoList if SkuInfoList is not None else OrderedDict()
|
2009-07-17 11:10:31 +02:00
|
|
|
self.Phase = "DXE"
|
|
|
|
self.Pending = False
|
2010-09-06 03:58:00 +02:00
|
|
|
self.IsOverrided = IsOverrided
|
2014-08-26 04:52:24 +02:00
|
|
|
self.IsFromBinaryInf = False
|
|
|
|
self.IsFromDsc = False
|
2018-09-25 07:20:46 +02:00
|
|
|
self.validateranges = validateranges if validateranges is not None else []
|
|
|
|
self.validlists = validlists if validlists is not None else []
|
|
|
|
self.expressions = expressions if expressions is not None else []
|
2017-10-09 15:15:04 +02:00
|
|
|
self.DscDefaultValue = None
|
2018-09-04 08:13:18 +02:00
|
|
|
self.DscRawValue = {}
|
2019-05-09 11:19:56 +02:00
|
|
|
self.DscRawValueInfo = {}
|
2017-10-09 15:15:04 +02:00
|
|
|
if IsDsc:
|
|
|
|
self.DscDefaultValue = Value
|
2018-03-08 06:56:21 +01:00
|
|
|
self.PcdValueFromComm = ""
|
2018-06-22 11:14:13 +02:00
|
|
|
self.PcdValueFromFdf = ""
|
2020-11-04 04:01:39 +01:00
|
|
|
self.PcdValueFromComponents = {} #{ModuleGuid:value, file_path,lineNo}
|
2018-09-25 04:55:30 +02:00
|
|
|
self.CustomAttribute = {}
|
2018-09-04 08:59:39 +02:00
|
|
|
self.UserDefinedDefaultStoresFlag = UserDefinedDefaultStoresFlag
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
self._Capacity = None
|
|
|
|
|
|
|
|
@property
|
|
|
|
def Capacity(self):
|
2019-05-09 11:19:56 +02:00
|
|
|
if self._Capacity is None:
|
|
|
|
self._Capacity = []
|
|
|
|
dimension = ArrayIndex.findall(self._DatumType)
|
|
|
|
for item in dimension:
|
|
|
|
maxsize = item.lstrip("[").rstrip("]").strip()
|
|
|
|
if not maxsize:
|
|
|
|
maxsize = "-1"
|
|
|
|
maxsize = str(int(maxsize,16)) if maxsize.startswith(("0x","0X")) else maxsize
|
|
|
|
self._Capacity.append(maxsize)
|
|
|
|
if hasattr(self, "SkuOverrideValues"):
|
|
|
|
for sku in self.SkuOverrideValues:
|
|
|
|
for defaultstore in self.SkuOverrideValues[sku]:
|
|
|
|
fields = self.SkuOverrideValues[sku][defaultstore]
|
|
|
|
for demesionattr in fields:
|
|
|
|
fieldinfo = fields[demesionattr]
|
|
|
|
deme = ArrayIndex.findall(demesionattr)
|
|
|
|
for i in range(len(deme)):
|
|
|
|
if int(deme[i].lstrip("[").rstrip("]").strip()) >= int(self._Capacity[i]):
|
|
|
|
if self._Capacity[i] != "-1":
|
|
|
|
firstfieldinfo = list(fieldinfo.values())[0]
|
|
|
|
EdkLogger.error('Build', OPTION_VALUE_INVALID, "For Pcd %s, Array Index exceed the Array size. From %s Line %s \n " %
|
|
|
|
(".".join((self.TokenSpaceGuidCName, self.TokenCName)), firstfieldinfo[1],firstfieldinfo[2] ))
|
|
|
|
if hasattr(self,"DefaultValues"):
|
|
|
|
for demesionattr in self.DefaultValues:
|
|
|
|
fieldinfo = self.DefaultValues[demesionattr]
|
|
|
|
deme = ArrayIndex.findall(demesionattr)
|
|
|
|
for i in range(len(deme)):
|
|
|
|
if int(deme[i].lstrip("[").rstrip("]").strip()) >= int(self._Capacity[i]):
|
|
|
|
if self._Capacity[i] != "-1":
|
|
|
|
firstfieldinfo = list(fieldinfo.values())[0]
|
|
|
|
EdkLogger.error('Build', OPTION_VALUE_INVALID, "For Pcd %s, Array Index exceed the Array size. From %s Line %s \n " %
|
|
|
|
(".".join((self.TokenSpaceGuidCName, self.TokenCName)), firstfieldinfo[1],firstfieldinfo[2] ))
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
return self._Capacity
|
2019-05-09 11:19:56 +02:00
|
|
|
|
|
|
|
def PcdArraySize(self):
|
|
|
|
if self.Capacity[-1] == "-1":
|
|
|
|
return -1
|
|
|
|
size = 1
|
|
|
|
for de in self.Capacity:
|
|
|
|
size = size * int(de)
|
|
|
|
return size
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
@property
|
|
|
|
def DatumType(self):
|
|
|
|
return self._DatumType
|
|
|
|
|
|
|
|
@DatumType.setter
|
|
|
|
def DatumType(self,DataType):
|
|
|
|
self._DatumType = DataType
|
|
|
|
self._Capacity = None
|
|
|
|
|
|
|
|
@property
|
|
|
|
def BaseDatumType(self):
|
|
|
|
if self.IsArray():
|
|
|
|
return self._DatumType[:self._DatumType.index("[")]
|
|
|
|
else:
|
|
|
|
return self._DatumType
|
|
|
|
def IsArray(self):
|
|
|
|
return True if len(self.Capacity) else False
|
|
|
|
|
|
|
|
def IsAggregateDatumType(self):
|
|
|
|
if self.DatumType in [TAB_UINT8, TAB_UINT16, TAB_UINT32, TAB_UINT64, TAB_VOID, "BOOLEAN"]:
|
|
|
|
return False
|
|
|
|
if self.IsArray() or StructPattern.match(self.DatumType):
|
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
|
|
def IsSimpleTypeArray(self):
|
|
|
|
if self.IsArray() and self.BaseDatumType in [TAB_UINT8, TAB_UINT16, TAB_UINT32, TAB_UINT64, "BOOLEAN"]:
|
|
|
|
return True
|
|
|
|
return False
|
2018-01-25 08:42:25 +01:00
|
|
|
|
2018-09-03 03:05:53 +02:00
|
|
|
@staticmethod
|
|
|
|
def GetPcdMaxSizeWorker(PcdString, MaxSize):
|
|
|
|
if PcdString.startswith("{") and PcdString.endswith("}"):
|
|
|
|
return max([len(PcdString.split(",")),MaxSize])
|
|
|
|
|
|
|
|
if PcdString.startswith("\"") or PcdString.startswith("\'"):
|
|
|
|
return max([len(PcdString)-2+1,MaxSize])
|
|
|
|
|
|
|
|
if PcdString.startswith("L\""):
|
|
|
|
return max([2*(len(PcdString)-3+1),MaxSize])
|
|
|
|
|
|
|
|
return max([len(PcdString),MaxSize])
|
|
|
|
|
2018-04-28 00:32:32 +02:00
|
|
|
## Get the maximum number of bytes
|
|
|
|
def GetPcdMaxSize(self):
|
|
|
|
if self.DatumType in TAB_PCD_NUMERIC_TYPES:
|
|
|
|
return MAX_SIZE_TYPE[self.DatumType]
|
|
|
|
|
2018-06-25 12:31:33 +02:00
|
|
|
MaxSize = int(self.MaxDatumSize, 10) if self.MaxDatumSize else 0
|
2018-06-22 11:14:13 +02:00
|
|
|
if self.PcdValueFromFdf:
|
2018-09-03 03:05:53 +02:00
|
|
|
MaxSize = self.GetPcdMaxSizeWorker(self.PcdValueFromFdf,MaxSize)
|
2018-04-28 00:32:32 +02:00
|
|
|
if self.PcdValueFromComm:
|
2018-09-03 03:05:53 +02:00
|
|
|
MaxSize = self.GetPcdMaxSizeWorker(self.PcdValueFromComm,MaxSize)
|
|
|
|
if hasattr(self, "DefaultValueFromDec"):
|
|
|
|
MaxSize = self.GetPcdMaxSizeWorker(self.DefaultValueFromDec,MaxSize)
|
2018-04-28 00:32:32 +02:00
|
|
|
return MaxSize
|
|
|
|
|
|
|
|
## Get the number of bytes
|
|
|
|
def GetPcdSize(self):
|
|
|
|
if self.DatumType in TAB_PCD_NUMERIC_TYPES:
|
|
|
|
return MAX_SIZE_TYPE[self.DatumType]
|
|
|
|
if not self.DefaultValue:
|
|
|
|
return 1
|
|
|
|
elif self.DefaultValue[0] == 'L':
|
|
|
|
return (len(self.DefaultValue) - 2) * 2
|
|
|
|
elif self.DefaultValue[0] == '{':
|
|
|
|
return len(self.DefaultValue.split(','))
|
|
|
|
else:
|
|
|
|
return len(self.DefaultValue) - 1
|
|
|
|
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
## Convert the class to a string
|
|
|
|
#
|
|
|
|
# Convert each member of the class to string
|
2019-02-06 08:44:39 +01:00
|
|
|
# Organize to a single line format string
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
|
|
|
# @retval Rtn Formatted String
|
|
|
|
#
|
|
|
|
def __str__(self):
|
|
|
|
Rtn = '\tTokenCName=' + str(self.TokenCName) + ', ' + \
|
|
|
|
'TokenSpaceGuidCName=' + str(self.TokenSpaceGuidCName) + ', ' + \
|
|
|
|
'Type=' + str(self.Type) + ', ' + \
|
|
|
|
'DatumType=' + str(self.DatumType) + ', ' + \
|
|
|
|
'DefaultValue=' + str(self.DefaultValue) + ', ' + \
|
|
|
|
'TokenValue=' + str(self.TokenValue) + ', ' + \
|
|
|
|
'MaxDatumSize=' + str(self.MaxDatumSize) + ', '
|
|
|
|
for Item in self.SkuInfoList.values():
|
|
|
|
Rtn = Rtn + 'SkuId=' + Item.SkuId + ', ' + 'SkuIdName=' + Item.SkuIdName
|
2010-09-06 03:58:00 +02:00
|
|
|
Rtn = Rtn + ', IsOverrided=' + str(self.IsOverrided)
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
return Rtn
|
|
|
|
|
|
|
|
## Override __eq__ function
|
|
|
|
#
|
|
|
|
# Check whether pcds are the same
|
|
|
|
#
|
|
|
|
# @retval False The two pcds are different
|
|
|
|
# @retval True The two pcds are the same
|
|
|
|
#
|
|
|
|
def __eq__(self, Other):
|
|
|
|
return Other and self.TokenCName == Other.TokenCName and self.TokenSpaceGuidCName == Other.TokenSpaceGuidCName
|
|
|
|
|
|
|
|
## Override __hash__ function
|
|
|
|
#
|
|
|
|
# Use (TokenCName, TokenSpaceGuidCName) as key in hash table
|
|
|
|
#
|
|
|
|
# @retval truple() Key for hash table
|
|
|
|
#
|
|
|
|
def __hash__(self):
|
|
|
|
return hash((self.TokenCName, self.TokenSpaceGuidCName))
|
|
|
|
|
2019-09-04 09:53:37 +02:00
|
|
|
@cached_property
|
|
|
|
def _fullname(self):
|
|
|
|
return ".".join((self.TokenSpaceGuidCName,self.TokenCName))
|
|
|
|
|
|
|
|
def __lt__(self,pcd):
|
|
|
|
return self._fullname < pcd._fullname
|
|
|
|
def __gt__(self,pcd):
|
|
|
|
return self._fullname > pcd._fullname
|
|
|
|
|
2018-11-08 07:03:38 +01:00
|
|
|
def sharedcopy(self,new_pcd):
|
|
|
|
new_pcd.TokenCName = self.TokenCName
|
|
|
|
new_pcd.TokenSpaceGuidCName = self.TokenSpaceGuidCName
|
|
|
|
new_pcd.TokenSpaceGuidValue = self.TokenSpaceGuidValue
|
|
|
|
new_pcd.Type = self.Type
|
|
|
|
new_pcd.DatumType = self.DatumType
|
|
|
|
new_pcd.DefaultValue = self.DefaultValue
|
|
|
|
new_pcd.TokenValue = self.TokenValue
|
|
|
|
new_pcd.MaxDatumSize = self.MaxDatumSize
|
2019-02-16 15:51:51 +01:00
|
|
|
new_pcd.MaxSizeUserSet = self.MaxSizeUserSet
|
2018-11-08 07:03:38 +01:00
|
|
|
|
|
|
|
new_pcd.Phase = self.Phase
|
|
|
|
new_pcd.Pending = self.Pending
|
|
|
|
new_pcd.IsOverrided = self.IsOverrided
|
|
|
|
new_pcd.IsFromBinaryInf = self.IsFromBinaryInf
|
|
|
|
new_pcd.IsFromDsc = self.IsFromDsc
|
|
|
|
new_pcd.PcdValueFromComm = self.PcdValueFromComm
|
|
|
|
new_pcd.PcdValueFromFdf = self.PcdValueFromFdf
|
|
|
|
new_pcd.UserDefinedDefaultStoresFlag = self.UserDefinedDefaultStoresFlag
|
|
|
|
new_pcd.DscRawValue = self.DscRawValue
|
2019-05-09 11:19:56 +02:00
|
|
|
new_pcd.DscRawValueInfo = self.DscRawValueInfo
|
2018-11-08 07:03:38 +01:00
|
|
|
new_pcd.CustomAttribute = self.CustomAttribute
|
|
|
|
new_pcd.validateranges = [item for item in self.validateranges]
|
|
|
|
new_pcd.validlists = [item for item in self.validlists]
|
|
|
|
new_pcd.expressions = [item for item in self.expressions]
|
|
|
|
new_pcd.SkuInfoList = {key: copy.deepcopy(skuobj) for key,skuobj in self.SkuInfoList.items()}
|
|
|
|
return new_pcd
|
|
|
|
|
|
|
|
def __deepcopy__(self,memo):
|
|
|
|
new_pcd = PcdClassObject()
|
|
|
|
self.sharedcopy(new_pcd)
|
|
|
|
return new_pcd
|
|
|
|
|
2017-11-24 07:30:11 +01:00
|
|
|
class StructurePcd(PcdClassObject):
|
2018-01-25 08:42:25 +01:00
|
|
|
def __init__(self, StructuredPcdIncludeFile=None, Packages=None, Name=None, Guid=None, Type=None, DatumType=None, Value=None, Token=None, MaxDatumSize=None, SkuInfoList=None, IsOverrided=False, GuidValue=None, validateranges=None, validlists=None, expressions=None,default_store = TAB_DEFAULT_STORES_DEFAULT):
|
2018-04-28 00:32:30 +02:00
|
|
|
if SkuInfoList is None:
|
|
|
|
SkuInfoList = {}
|
|
|
|
if validateranges is None:
|
|
|
|
validateranges = []
|
|
|
|
if validlists is None:
|
|
|
|
validlists = []
|
|
|
|
if expressions is None:
|
|
|
|
expressions = []
|
|
|
|
if Packages is None:
|
|
|
|
Packages = []
|
2018-10-15 02:27:53 +02:00
|
|
|
super(StructurePcd, self).__init__(Name, Guid, Type, DatumType, Value, Token, MaxDatumSize, SkuInfoList, IsOverrided, GuidValue, validateranges, validlists, expressions)
|
2018-01-29 07:09:36 +01:00
|
|
|
self.StructuredPcdIncludeFile = [] if StructuredPcdIncludeFile is None else StructuredPcdIncludeFile
|
2017-11-24 07:30:11 +01:00
|
|
|
self.PackageDecs = Packages
|
2017-12-22 13:46:15 +01:00
|
|
|
self.DefaultStoreName = [default_store]
|
2018-09-11 00:18:06 +02:00
|
|
|
self.DefaultValues = OrderedDict()
|
2017-11-24 07:30:11 +01:00
|
|
|
self.PcdMode = None
|
2018-09-11 00:18:06 +02:00
|
|
|
self.SkuOverrideValues = OrderedDict()
|
2017-12-22 13:07:54 +01:00
|
|
|
self.StructName = None
|
2018-01-23 04:03:05 +01:00
|
|
|
self.PcdDefineLineNo = 0
|
|
|
|
self.PkgPath = ""
|
2018-02-28 06:59:18 +01:00
|
|
|
self.DefaultValueFromDec = ""
|
2019-05-09 11:19:56 +02:00
|
|
|
self.DefaultValueFromDecInfo = None
|
2018-04-28 00:32:31 +02:00
|
|
|
self.ValueChain = set()
|
2018-09-11 00:18:06 +02:00
|
|
|
self.PcdFieldValueFromComm = OrderedDict()
|
|
|
|
self.PcdFieldValueFromFdf = OrderedDict()
|
2019-02-03 15:47:54 +01:00
|
|
|
self.DefaultFromDSC=None
|
2020-11-04 04:01:39 +01:00
|
|
|
self.PcdFiledValueFromDscComponent = OrderedDict()
|
2017-11-24 07:30:11 +01:00
|
|
|
def __repr__(self):
|
|
|
|
return self.TypeName
|
|
|
|
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
def AddDefaultValue (self, FieldName, Value, FileName="", LineNo=0,DimensionAttr ="-1"):
|
|
|
|
if DimensionAttr not in self.DefaultValues:
|
|
|
|
self.DefaultValues[DimensionAttr] = collections.OrderedDict()
|
|
|
|
if FieldName in self.DefaultValues[DimensionAttr]:
|
|
|
|
del self.DefaultValues[DimensionAttr][FieldName]
|
|
|
|
self.DefaultValues[DimensionAttr][FieldName] = [Value.strip(), FileName, LineNo]
|
|
|
|
return self.DefaultValues[DimensionAttr][FieldName]
|
2017-11-24 07:30:11 +01:00
|
|
|
|
2019-05-09 11:19:56 +02:00
|
|
|
def SetDecDefaultValue(self, DefaultValue,decpath=None,lineno=None):
|
2018-02-28 06:59:18 +01:00
|
|
|
self.DefaultValueFromDec = DefaultValue
|
2019-05-09 11:19:56 +02:00
|
|
|
self.DefaultValueFromDecInfo = (decpath,lineno)
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
def AddOverrideValue (self, FieldName, Value, SkuName, DefaultStoreName, FileName="", LineNo=0, DimensionAttr = '-1'):
|
2017-11-24 07:30:11 +01:00
|
|
|
if SkuName not in self.SkuOverrideValues:
|
2018-09-11 00:18:06 +02:00
|
|
|
self.SkuOverrideValues[SkuName] = OrderedDict()
|
2017-12-22 13:46:15 +01:00
|
|
|
if DefaultStoreName not in self.SkuOverrideValues[SkuName]:
|
2018-09-11 00:18:06 +02:00
|
|
|
self.SkuOverrideValues[SkuName][DefaultStoreName] = OrderedDict()
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
if DimensionAttr not in self.SkuOverrideValues[SkuName][DefaultStoreName]:
|
|
|
|
self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr] = collections.OrderedDict()
|
|
|
|
if FieldName in self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr]:
|
2018-12-09 14:44:32 +01:00
|
|
|
del self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr][FieldName]
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr][FieldName] = [Value.strip(), FileName, LineNo]
|
|
|
|
return self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr][FieldName]
|
2017-11-24 07:30:11 +01:00
|
|
|
|
2020-11-04 04:01:39 +01:00
|
|
|
def AddComponentOverrideValue(self,FieldName, Value, ModuleGuid, FileName="", LineNo=0, DimensionAttr = '-1'):
|
|
|
|
self.PcdFiledValueFromDscComponent.setdefault(ModuleGuid, OrderedDict())
|
|
|
|
self.PcdFiledValueFromDscComponent[ModuleGuid].setdefault(DimensionAttr,OrderedDict())
|
|
|
|
self.PcdFiledValueFromDscComponent[ModuleGuid][DimensionAttr][FieldName] = [Value.strip(), FileName, LineNo]
|
|
|
|
return self.PcdFiledValueFromDscComponent[ModuleGuid][DimensionAttr][FieldName]
|
|
|
|
|
2017-11-24 07:30:11 +01:00
|
|
|
def SetPcdMode (self, PcdMode):
|
|
|
|
self.PcdMode = PcdMode
|
|
|
|
|
|
|
|
def copy(self, PcdObject):
|
|
|
|
self.TokenCName = PcdObject.TokenCName if PcdObject.TokenCName else self.TokenCName
|
|
|
|
self.TokenSpaceGuidCName = PcdObject.TokenSpaceGuidCName if PcdObject.TokenSpaceGuidCName else PcdObject.TokenSpaceGuidCName
|
|
|
|
self.TokenSpaceGuidValue = PcdObject.TokenSpaceGuidValue if PcdObject.TokenSpaceGuidValue else self.TokenSpaceGuidValue
|
|
|
|
self.Type = PcdObject.Type if PcdObject.Type else self.Type
|
BaseTools: Enable Pcd Array support.
https://bugzilla.tianocore.org/show_bug.cgi?id=1292
This patch is going to enable Array data type for PCD.
1. Support Pcd ARRAY as Structure PCD type
including basic datatype array and structure array.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{0x0}|TEST[10]|0x00010080
gStructuredPcdPkgTokenSpaceGuid.PcdTest2|{0x0}|UINT8[10]|0x00010081
2. Support C CODE style value initialization in DEC/DSC.
For example:
gStructuredPcdPkgTokenSpaceGuid.PcdTest|{CODE({
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
{0, {0, 0, 0, 0, 0, 0, 0}},
})}
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Bob Feng <bob.c.feng@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
2018-11-07 10:18:34 +01:00
|
|
|
self._DatumType = PcdObject.DatumType if PcdObject.DatumType else self.DatumType
|
2017-11-24 07:30:11 +01:00
|
|
|
self.DefaultValue = PcdObject.DefaultValue if PcdObject.DefaultValue else self.DefaultValue
|
|
|
|
self.TokenValue = PcdObject.TokenValue if PcdObject.TokenValue else self.TokenValue
|
|
|
|
self.MaxDatumSize = PcdObject.MaxDatumSize if PcdObject.MaxDatumSize else self.MaxDatumSize
|
|
|
|
self.SkuInfoList = PcdObject.SkuInfoList if PcdObject.SkuInfoList else self.SkuInfoList
|
|
|
|
self.Phase = PcdObject.Phase if PcdObject.Phase else self.Phase
|
|
|
|
self.Pending = PcdObject.Pending if PcdObject.Pending else self.Pending
|
|
|
|
self.IsOverrided = PcdObject.IsOverrided if PcdObject.IsOverrided else self.IsOverrided
|
|
|
|
self.IsFromBinaryInf = PcdObject.IsFromBinaryInf if PcdObject.IsFromBinaryInf else self.IsFromBinaryInf
|
|
|
|
self.IsFromDsc = PcdObject.IsFromDsc if PcdObject.IsFromDsc else self.IsFromDsc
|
|
|
|
self.validateranges = PcdObject.validateranges if PcdObject.validateranges else self.validateranges
|
|
|
|
self.validlists = PcdObject.validlists if PcdObject.validlists else self.validlists
|
|
|
|
self.expressions = PcdObject.expressions if PcdObject.expressions else self.expressions
|
2018-02-28 06:59:21 +01:00
|
|
|
self.DscRawValue = PcdObject.DscRawValue if PcdObject.DscRawValue else self.DscRawValue
|
2019-05-09 11:19:56 +02:00
|
|
|
self.DscRawValueInfo = PcdObject.DscRawValueInfo if PcdObject.DscRawValueInfo else self.DscRawValueInfo
|
2018-03-08 06:56:21 +01:00
|
|
|
self.PcdValueFromComm = PcdObject.PcdValueFromComm if PcdObject.PcdValueFromComm else self.PcdValueFromComm
|
2018-06-22 11:14:13 +02:00
|
|
|
self.PcdValueFromFdf = PcdObject.PcdValueFromFdf if PcdObject.PcdValueFromFdf else self.PcdValueFromFdf
|
2018-09-25 04:55:30 +02:00
|
|
|
self.CustomAttribute = PcdObject.CustomAttribute if PcdObject.CustomAttribute else self.CustomAttribute
|
2018-09-04 08:59:39 +02:00
|
|
|
self.UserDefinedDefaultStoresFlag = PcdObject.UserDefinedDefaultStoresFlag if PcdObject.UserDefinedDefaultStoresFlag else self.UserDefinedDefaultStoresFlag
|
2018-06-25 12:31:35 +02:00
|
|
|
if isinstance(PcdObject, StructurePcd):
|
2017-11-24 07:30:11 +01:00
|
|
|
self.StructuredPcdIncludeFile = PcdObject.StructuredPcdIncludeFile if PcdObject.StructuredPcdIncludeFile else self.StructuredPcdIncludeFile
|
|
|
|
self.PackageDecs = PcdObject.PackageDecs if PcdObject.PackageDecs else self.PackageDecs
|
|
|
|
self.DefaultValues = PcdObject.DefaultValues if PcdObject.DefaultValues else self.DefaultValues
|
|
|
|
self.PcdMode = PcdObject.PcdMode if PcdObject.PcdMode else self.PcdMode
|
2018-02-28 06:59:18 +01:00
|
|
|
self.DefaultValueFromDec = PcdObject.DefaultValueFromDec if PcdObject.DefaultValueFromDec else self.DefaultValueFromDec
|
2019-05-09 11:19:56 +02:00
|
|
|
self.DefaultValueFromDecInfo = PcdObject.DefaultValueFromDecInfo if PcdObject.DefaultValueFromDecInfo else self.DefaultValueFromDecInfo
|
2017-12-01 15:00:07 +01:00
|
|
|
self.SkuOverrideValues = PcdObject.SkuOverrideValues if PcdObject.SkuOverrideValues else self.SkuOverrideValues
|
2017-12-22 13:07:54 +01:00
|
|
|
self.StructName = PcdObject.DatumType if PcdObject.DatumType else self.StructName
|
2018-01-23 04:03:05 +01:00
|
|
|
self.PcdDefineLineNo = PcdObject.PcdDefineLineNo if PcdObject.PcdDefineLineNo else self.PcdDefineLineNo
|
|
|
|
self.PkgPath = PcdObject.PkgPath if PcdObject.PkgPath else self.PkgPath
|
2018-02-28 06:59:21 +01:00
|
|
|
self.ValueChain = PcdObject.ValueChain if PcdObject.ValueChain else self.ValueChain
|
2018-03-02 11:11:13 +01:00
|
|
|
self.PcdFieldValueFromComm = PcdObject.PcdFieldValueFromComm if PcdObject.PcdFieldValueFromComm else self.PcdFieldValueFromComm
|
2018-06-22 11:14:13 +02:00
|
|
|
self.PcdFieldValueFromFdf = PcdObject.PcdFieldValueFromFdf if PcdObject.PcdFieldValueFromFdf else self.PcdFieldValueFromFdf
|
2020-11-04 04:01:39 +01:00
|
|
|
self.PcdFiledValueFromDscComponent = PcdObject.PcdFiledValueFromDscComponent if PcdObject.PcdFiledValueFromDscComponent else self.PcdFiledValueFromDscComponent
|
2017-11-24 07:30:11 +01:00
|
|
|
|
2018-11-08 07:03:38 +01:00
|
|
|
def __deepcopy__(self,memo):
|
|
|
|
new_pcd = StructurePcd()
|
|
|
|
self.sharedcopy(new_pcd)
|
|
|
|
|
|
|
|
new_pcd.DefaultValueFromDec = self.DefaultValueFromDec
|
2019-05-09 11:19:56 +02:00
|
|
|
new_pcd.DefaultValueFromDecInfo = self.DefaultValueFromDecInfo
|
2018-11-08 07:03:38 +01:00
|
|
|
new_pcd.PcdMode = self.PcdMode
|
|
|
|
new_pcd.StructName = self.DatumType
|
|
|
|
new_pcd.PcdDefineLineNo = self.PcdDefineLineNo
|
|
|
|
new_pcd.PkgPath = self.PkgPath
|
|
|
|
new_pcd.StructuredPcdIncludeFile = [item for item in self.StructuredPcdIncludeFile]
|
|
|
|
new_pcd.PackageDecs = [item for item in self.PackageDecs]
|
|
|
|
new_pcd.DefaultValues = CopyDict(self.DefaultValues)
|
|
|
|
new_pcd.DefaultFromDSC=CopyDict(self.DefaultFromDSC)
|
|
|
|
new_pcd.SkuOverrideValues = CopyDict(self.SkuOverrideValues)
|
|
|
|
new_pcd.PcdFieldValueFromComm = CopyDict(self.PcdFieldValueFromComm)
|
|
|
|
new_pcd.PcdFieldValueFromFdf = CopyDict(self.PcdFieldValueFromFdf)
|
2020-11-04 04:01:39 +01:00
|
|
|
new_pcd.PcdFiledValueFromDscComponent = CopyDict(self.PcdFiledValueFromDscComponent)
|
2018-11-08 07:03:38 +01:00
|
|
|
new_pcd.ValueChain = {item for item in self.ValueChain}
|
|
|
|
return new_pcd
|
|
|
|
|
2018-11-30 02:36:07 +01:00
|
|
|
LibraryClassObject = namedtuple('LibraryClassObject', ['LibraryClass','SupModList'])
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## ModuleBuildClassObject
|
|
|
|
#
|
|
|
|
# This Class defines ModuleBuildClass
|
|
|
|
#
|
|
|
|
# @param object: Inherited from object class
|
|
|
|
#
|
|
|
|
# @var MetaFile: To store value for module meta file path
|
|
|
|
# @var BaseName: To store value for BaseName
|
|
|
|
# @var ModuleType: To store value for ModuleType
|
|
|
|
# @var Guid: To store value for Guid
|
|
|
|
# @var Version: To store value for Version
|
|
|
|
# @var PcdIsDriver: To store value for PcdIsDriver
|
|
|
|
# @var BinaryModule: To store value for BinaryModule
|
|
|
|
# @var CustomMakefile: To store value for CustomMakefile
|
|
|
|
# @var Specification: To store value for Specification
|
|
|
|
# @var Shadow To store value for Shadow
|
|
|
|
# @var LibraryClass: To store value for LibraryClass, it is a list structure as
|
|
|
|
# [ LibraryClassObject, ...]
|
|
|
|
# @var ModuleEntryPointList: To store value for ModuleEntryPointList
|
|
|
|
# @var ModuleUnloadImageList: To store value for ModuleUnloadImageList
|
|
|
|
# @var ConstructorList: To store value for ConstructorList
|
|
|
|
# @var DestructorList: To store value for DestructorList
|
|
|
|
# @var Binaries: To store value for Binaries, it is a list structure as
|
|
|
|
# [ ModuleBinaryClassObject, ...]
|
|
|
|
# @var Sources: To store value for Sources, it is a list structure as
|
|
|
|
# [ ModuleSourceFilesClassObject, ... ]
|
|
|
|
# @var LibraryClasses: To store value for LibraryClasses, it is a set structure as
|
|
|
|
# { [LibraryClassName, ModuleType] : LibraryClassInfFile }
|
|
|
|
# @var Protocols: To store value for Protocols, it is a list structure as
|
|
|
|
# [ ProtocolName, ... ]
|
|
|
|
# @var Ppis: To store value for Ppis, it is a list structure as
|
|
|
|
# [ PpiName, ... ]
|
|
|
|
# @var Guids: To store value for Guids, it is a list structure as
|
|
|
|
# [ GuidName, ... ]
|
|
|
|
# @var Includes: To store value for Includes, it is a list structure as
|
|
|
|
# [ IncludePath, ... ]
|
|
|
|
# @var Packages: To store value for Packages, it is a list structure as
|
|
|
|
# [ DecFileName, ... ]
|
|
|
|
# @var Pcds: To store value for Pcds, it is a set structure as
|
|
|
|
# { [(PcdCName, PcdGuidCName)] : PcdClassObject}
|
|
|
|
# @var BuildOptions: To store value for BuildOptions, it is a set structure as
|
|
|
|
# { [BuildOptionKey] : BuildOptionValue}
|
|
|
|
# @var Depex: To store value for Depex
|
|
|
|
#
|
|
|
|
class ModuleBuildClassObject(object):
|
|
|
|
def __init__(self):
|
|
|
|
self.AutoGenVersion = 0
|
|
|
|
self.MetaFile = ''
|
|
|
|
self.BaseName = ''
|
|
|
|
self.ModuleType = ''
|
|
|
|
self.Guid = ''
|
|
|
|
self.Version = ''
|
|
|
|
self.PcdIsDriver = ''
|
|
|
|
self.BinaryModule = ''
|
|
|
|
self.Shadow = ''
|
|
|
|
self.CustomMakefile = {}
|
|
|
|
self.Specification = {}
|
|
|
|
self.LibraryClass = []
|
|
|
|
self.ModuleEntryPointList = []
|
|
|
|
self.ModuleUnloadImageList = []
|
|
|
|
self.ConstructorList = []
|
|
|
|
self.DestructorList = []
|
|
|
|
|
|
|
|
self.Binaries = []
|
|
|
|
self.Sources = []
|
2018-09-11 00:18:06 +02:00
|
|
|
self.LibraryClasses = OrderedDict()
|
2009-07-17 11:10:31 +02:00
|
|
|
self.Libraries = []
|
|
|
|
self.Protocols = []
|
|
|
|
self.Ppis = []
|
|
|
|
self.Guids = []
|
|
|
|
self.Includes = []
|
|
|
|
self.Packages = []
|
|
|
|
self.Pcds = {}
|
|
|
|
self.BuildOptions = {}
|
|
|
|
self.Depex = {}
|
2020-11-04 04:01:39 +01:00
|
|
|
self.StrPcdSet = []
|
|
|
|
self.StrPcdOverallValue = {}
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## Convert the class to a string
|
|
|
|
#
|
|
|
|
# Convert member MetaFile of the class to a string
|
|
|
|
#
|
|
|
|
# @retval string Formatted String
|
|
|
|
#
|
|
|
|
def __str__(self):
|
|
|
|
return str(self.MetaFile)
|
|
|
|
|
|
|
|
## Override __eq__ function
|
|
|
|
#
|
|
|
|
# Check whether ModuleBuildClassObjects are the same
|
|
|
|
#
|
|
|
|
# @retval False The two ModuleBuildClassObjects are different
|
|
|
|
# @retval True The two ModuleBuildClassObjects are the same
|
|
|
|
#
|
|
|
|
def __eq__(self, Other):
|
|
|
|
return self.MetaFile == Other
|
|
|
|
|
|
|
|
## Override __hash__ function
|
|
|
|
#
|
|
|
|
# Use MetaFile as key in hash table
|
|
|
|
#
|
|
|
|
# @retval string Key for hash table
|
|
|
|
#
|
|
|
|
def __hash__(self):
|
|
|
|
return hash(self.MetaFile)
|
|
|
|
|
|
|
|
## PackageBuildClassObject
|
|
|
|
#
|
|
|
|
# This Class defines PackageBuildClass
|
|
|
|
#
|
|
|
|
# @param object: Inherited from object class
|
|
|
|
#
|
|
|
|
# @var MetaFile: To store value for package meta file path
|
|
|
|
# @var PackageName: To store value for PackageName
|
|
|
|
# @var Guid: To store value for Guid
|
|
|
|
# @var Version: To store value for Version
|
|
|
|
# @var Protocols: To store value for Protocols, it is a set structure as
|
|
|
|
# { [ProtocolName] : Protocol Guid, ... }
|
|
|
|
# @var Ppis: To store value for Ppis, it is a set structure as
|
|
|
|
# { [PpiName] : Ppi Guid, ... }
|
|
|
|
# @var Guids: To store value for Guids, it is a set structure as
|
|
|
|
# { [GuidName] : Guid, ... }
|
|
|
|
# @var Includes: To store value for Includes, it is a list structure as
|
|
|
|
# [ IncludePath, ... ]
|
|
|
|
# @var LibraryClasses: To store value for LibraryClasses, it is a set structure as
|
|
|
|
# { [LibraryClassName] : LibraryClassInfFile }
|
|
|
|
# @var Pcds: To store value for Pcds, it is a set structure as
|
|
|
|
# { [(PcdCName, PcdGuidCName)] : PcdClassObject}
|
|
|
|
#
|
|
|
|
class PackageBuildClassObject(object):
|
|
|
|
def __init__(self):
|
|
|
|
self.MetaFile = ''
|
|
|
|
self.PackageName = ''
|
|
|
|
self.Guid = ''
|
|
|
|
self.Version = ''
|
|
|
|
|
|
|
|
self.Protocols = {}
|
|
|
|
self.Ppis = {}
|
|
|
|
self.Guids = {}
|
|
|
|
self.Includes = []
|
|
|
|
self.LibraryClasses = {}
|
|
|
|
self.Pcds = {}
|
|
|
|
|
|
|
|
## Convert the class to a string
|
|
|
|
#
|
|
|
|
# Convert member MetaFile of the class to a string
|
|
|
|
#
|
|
|
|
# @retval string Formatted String
|
|
|
|
#
|
|
|
|
def __str__(self):
|
|
|
|
return str(self.MetaFile)
|
|
|
|
|
|
|
|
## Override __eq__ function
|
|
|
|
#
|
|
|
|
# Check whether PackageBuildClassObjects are the same
|
|
|
|
#
|
|
|
|
# @retval False The two PackageBuildClassObjects are different
|
|
|
|
# @retval True The two PackageBuildClassObjects are the same
|
|
|
|
#
|
|
|
|
def __eq__(self, Other):
|
|
|
|
return self.MetaFile == Other
|
|
|
|
|
|
|
|
## Override __hash__ function
|
|
|
|
#
|
|
|
|
# Use MetaFile as key in hash table
|
|
|
|
#
|
|
|
|
# @retval string Key for hash table
|
|
|
|
#
|
|
|
|
def __hash__(self):
|
|
|
|
return hash(self.MetaFile)
|
|
|
|
|
|
|
|
## PlatformBuildClassObject
|
|
|
|
#
|
|
|
|
# This Class defines PlatformBuildClass
|
|
|
|
#
|
|
|
|
# @param object: Inherited from object class
|
|
|
|
#
|
|
|
|
# @var MetaFile: To store value for platform meta-file path
|
|
|
|
# @var PlatformName: To store value for PlatformName
|
|
|
|
# @var Guid: To store value for Guid
|
|
|
|
# @var Version: To store value for Version
|
|
|
|
# @var DscSpecification: To store value for DscSpecification
|
|
|
|
# @var OutputDirectory: To store value for OutputDirectory
|
|
|
|
# @var FlashDefinition: To store value for FlashDefinition
|
|
|
|
# @var BuildNumber: To store value for BuildNumber
|
|
|
|
# @var MakefileName: To store value for MakefileName
|
|
|
|
# @var SkuIds: To store value for SkuIds, it is a set structure as
|
|
|
|
# { 'SkuName' : SkuId, '!include' : includefilename, ...}
|
|
|
|
# @var Modules: To store value for Modules, it is a list structure as
|
|
|
|
# [ InfFileName, ... ]
|
|
|
|
# @var Libraries: To store value for Libraries, it is a list structure as
|
|
|
|
# [ InfFileName, ... ]
|
|
|
|
# @var LibraryClasses: To store value for LibraryClasses, it is a set structure as
|
|
|
|
# { (LibraryClassName, ModuleType) : LibraryClassInfFile }
|
|
|
|
# @var Pcds: To store value for Pcds, it is a set structure as
|
|
|
|
# { [(PcdCName, PcdGuidCName)] : PcdClassObject }
|
|
|
|
# @var BuildOptions: To store value for BuildOptions, it is a set structure as
|
|
|
|
# { [BuildOptionKey] : BuildOptionValue }
|
|
|
|
#
|
|
|
|
class PlatformBuildClassObject(object):
|
|
|
|
def __init__(self):
|
|
|
|
self.MetaFile = ''
|
|
|
|
self.PlatformName = ''
|
|
|
|
self.Guid = ''
|
|
|
|
self.Version = ''
|
|
|
|
self.DscSpecification = ''
|
|
|
|
self.OutputDirectory = ''
|
|
|
|
self.FlashDefinition = ''
|
|
|
|
self.BuildNumber = ''
|
|
|
|
self.MakefileName = ''
|
|
|
|
|
|
|
|
self.SkuIds = {}
|
|
|
|
self.Modules = []
|
|
|
|
self.LibraryInstances = []
|
|
|
|
self.LibraryClasses = {}
|
|
|
|
self.Libraries = {}
|
|
|
|
self.Pcds = {}
|
|
|
|
self.BuildOptions = {}
|
|
|
|
|
|
|
|
## Convert the class to a string
|
|
|
|
#
|
|
|
|
# Convert member MetaFile of the class to a string
|
|
|
|
#
|
|
|
|
# @retval string Formatted String
|
|
|
|
#
|
|
|
|
def __str__(self):
|
|
|
|
return str(self.MetaFile)
|
|
|
|
|
|
|
|
## Override __eq__ function
|
|
|
|
#
|
|
|
|
# Check whether PlatformBuildClassObjects are the same
|
|
|
|
#
|
|
|
|
# @retval False The two PlatformBuildClassObjects are different
|
|
|
|
# @retval True The two PlatformBuildClassObjects are the same
|
|
|
|
#
|
|
|
|
def __eq__(self, Other):
|
|
|
|
return self.MetaFile == Other
|
|
|
|
|
|
|
|
## Override __hash__ function
|
|
|
|
#
|
|
|
|
# Use MetaFile as key in hash table
|
|
|
|
#
|
|
|
|
# @retval string Key for hash table
|
|
|
|
#
|
|
|
|
def __hash__(self):
|
|
|
|
return hash(self.MetaFile)
|