]> git.proxmox.com Git - mirror_edk2.git/blobdiff - BaseTools/Source/Python/Workspace/BuildClassObject.py
BaseTools: Replace BSD License with BSD+Patent License
[mirror_edk2.git] / BaseTools / Source / Python / Workspace / BuildClassObject.py
index 57ba73c49848cb62e1ea5110af1eb2d5afa53b64..33d88c6921b38edc776a8c7dea333c7db1fe1687 100644 (file)
@@ -2,13 +2,7 @@
 # This file is used to define each component of the build database\r
 #\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
-# http://opensource.org/licenses/bsd-license.php\r
-#\r
-# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
-# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+# SPDX-License-Identifier: BSD-2-Clause-Patent\r
 #\r
 \r
 from collections import OrderedDict, namedtuple\r
@@ -16,8 +10,10 @@ from Common.DataType import *
 import collections\r
 import re\r
 from collections import OrderedDict\r
+from Common.Misc import CopyDict\r
+import copy\r
 StructPattern = re.compile(r'[_a-zA-Z][0-9A-Za-z_\[\]]*$')\r
-ArrayIndex = re.compile("\[\s*\d{0,1}\s*\]")\r
+ArrayIndex = re.compile("\[\s*[0-9a-fA-FxX]*\s*\]")\r
 ## PcdClassObject\r
 #\r
 # This Class is used for PcdObject\r
@@ -50,7 +46,7 @@ class PcdClassObject(object):
         self.TokenSpaceGuidCName = Guid\r
         self.TokenSpaceGuidValue = GuidValue\r
         self.Type = Type\r
-        self.DatumType = DatumType\r
+        self._DatumType = DatumType\r
         self.DefaultValue = Value\r
         self.TokenValue = Token\r
         self.MaxDatumSize = MaxDatumSize\r
@@ -70,7 +66,65 @@ class PcdClassObject(object):
             self.DscDefaultValue = Value\r
         self.PcdValueFromComm = ""\r
         self.PcdValueFromFdf = ""\r
+        self.CustomAttribute = {}\r
         self.UserDefinedDefaultStoresFlag = UserDefinedDefaultStoresFlag\r
+        self._Capacity = None\r
+\r
+    @property\r
+    def Capacity(self):\r
+        self._Capacity = []\r
+        dimension = ArrayIndex.findall(self._DatumType)\r
+        for item in dimension:\r
+            maxsize = item.lstrip("[").rstrip("]").strip()\r
+            if not maxsize:\r
+                maxsize = "-1"\r
+            maxsize = str(int(maxsize,16)) if maxsize.startswith(("0x","0X")) else maxsize\r
+            self._Capacity.append(maxsize)\r
+        if hasattr(self, "SkuOverrideValues"):\r
+            for sku in self.SkuOverrideValues:\r
+                for defaultstore in self.SkuOverrideValues[sku]:\r
+                    fields = self.SkuOverrideValues[sku][defaultstore]\r
+                    for demesionattr in fields:\r
+                        deme = ArrayIndex.findall(demesionattr)\r
+                        for i in range(len(deme)-1):\r
+                            if int(deme[i].lstrip("[").rstrip("]").strip()) > int(self._Capacity[i]):\r
+                                print ("error")\r
+        if hasattr(self,"DefaultValues"):\r
+            for demesionattr in self.DefaultValues:\r
+                deme = ArrayIndex.findall(demesionattr)\r
+                for i in range(len(deme)-1):\r
+                    if int(deme[i].lstrip("[").rstrip("]").strip()) > int(self._Capacity[i]):\r
+                        print ("error")\r
+        return self._Capacity\r
+    @property\r
+    def DatumType(self):\r
+        return self._DatumType\r
+\r
+    @DatumType.setter\r
+    def DatumType(self,DataType):\r
+        self._DatumType = DataType\r
+        self._Capacity = None\r
+\r
+    @property\r
+    def BaseDatumType(self):\r
+        if self.IsArray():\r
+            return self._DatumType[:self._DatumType.index("[")]\r
+        else:\r
+            return self._DatumType\r
+    def IsArray(self):\r
+        return True if len(self.Capacity) else False\r
+\r
+    def IsAggregateDatumType(self):\r
+        if self.DatumType in [TAB_UINT8, TAB_UINT16, TAB_UINT32, TAB_UINT64, TAB_VOID, "BOOLEAN"]:\r
+            return False\r
+        if self.IsArray() or StructPattern.match(self.DatumType):\r
+            return True\r
+        return False\r
+\r
+    def IsSimpleTypeArray(self):\r
+        if self.IsArray() and self.BaseDatumType in [TAB_UINT8, TAB_UINT16, TAB_UINT32, TAB_UINT64, "BOOLEAN"]:\r
+            return True\r
+        return False\r
 \r
     @staticmethod\r
     def GetPcdMaxSizeWorker(PcdString, MaxSize):\r
@@ -116,7 +170,7 @@ class PcdClassObject(object):
     ## Convert the class to a string\r
     #\r
     #  Convert each member of the class to string\r
-    #  Organize to a signle line format string\r
+    #  Organize to a single line format string\r
     #\r
     #  @retval Rtn Formatted String\r
     #\r
@@ -153,6 +207,38 @@ class PcdClassObject(object):
     def __hash__(self):\r
         return hash((self.TokenCName, self.TokenSpaceGuidCName))\r
 \r
+    def sharedcopy(self,new_pcd):\r
+        new_pcd.TokenCName = self.TokenCName\r
+        new_pcd.TokenSpaceGuidCName = self.TokenSpaceGuidCName\r
+        new_pcd.TokenSpaceGuidValue = self.TokenSpaceGuidValue\r
+        new_pcd.Type = self.Type\r
+        new_pcd.DatumType = self.DatumType\r
+        new_pcd.DefaultValue = self.DefaultValue\r
+        new_pcd.TokenValue = self.TokenValue\r
+        new_pcd.MaxDatumSize = self.MaxDatumSize\r
+        new_pcd.MaxSizeUserSet = self.MaxSizeUserSet\r
+\r
+        new_pcd.Phase = self.Phase\r
+        new_pcd.Pending = self.Pending\r
+        new_pcd.IsOverrided = self.IsOverrided\r
+        new_pcd.IsFromBinaryInf = self.IsFromBinaryInf\r
+        new_pcd.IsFromDsc = self.IsFromDsc\r
+        new_pcd.PcdValueFromComm = self.PcdValueFromComm\r
+        new_pcd.PcdValueFromFdf = self.PcdValueFromFdf\r
+        new_pcd.UserDefinedDefaultStoresFlag = self.UserDefinedDefaultStoresFlag\r
+        new_pcd.DscRawValue = self.DscRawValue\r
+        new_pcd.CustomAttribute = self.CustomAttribute\r
+        new_pcd.validateranges = [item for item in self.validateranges]\r
+        new_pcd.validlists = [item for item in self.validlists]\r
+        new_pcd.expressions = [item for item in self.expressions]\r
+        new_pcd.SkuInfoList = {key: copy.deepcopy(skuobj) for key,skuobj in self.SkuInfoList.items()}\r
+        return new_pcd\r
+\r
+    def __deepcopy__(self,memo):\r
+        new_pcd = PcdClassObject()\r
+        self.sharedcopy(new_pcd)\r
+        return new_pcd\r
+\r
 class StructurePcd(PcdClassObject):\r
     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):\r
         if SkuInfoList is None:\r
@@ -179,26 +265,31 @@ class StructurePcd(PcdClassObject):
         self.ValueChain = set()\r
         self.PcdFieldValueFromComm = OrderedDict()\r
         self.PcdFieldValueFromFdf = OrderedDict()\r
+        self.DefaultFromDSC=None\r
     def __repr__(self):\r
         return self.TypeName\r
 \r
-    def AddDefaultValue (self, FieldName, Value, FileName="", LineNo=0):\r
-        if FieldName in self.DefaultValues:\r
-            del self.DefaultValues[FieldName]\r
-        self.DefaultValues[FieldName] = [Value.strip(), FileName, LineNo]\r
-        return self.DefaultValues[FieldName]\r
+    def AddDefaultValue (self, FieldName, Value, FileName="", LineNo=0,DimensionAttr ="-1"):\r
+        if DimensionAttr not in self.DefaultValues:\r
+            self.DefaultValues[DimensionAttr] = collections.OrderedDict()\r
+        if FieldName in self.DefaultValues[DimensionAttr]:\r
+            del self.DefaultValues[DimensionAttr][FieldName]\r
+        self.DefaultValues[DimensionAttr][FieldName] = [Value.strip(), FileName, LineNo]\r
+        return self.DefaultValues[DimensionAttr][FieldName]\r
 \r
     def SetDecDefaultValue(self, DefaultValue):\r
         self.DefaultValueFromDec = DefaultValue\r
-    def AddOverrideValue (self, FieldName, Value, SkuName, DefaultStoreName, FileName="", LineNo=0):\r
+    def AddOverrideValue (self, FieldName, Value, SkuName, DefaultStoreName, FileName="", LineNo=0, DimensionAttr = '-1'):\r
         if SkuName not in self.SkuOverrideValues:\r
             self.SkuOverrideValues[SkuName] = OrderedDict()\r
         if DefaultStoreName not in self.SkuOverrideValues[SkuName]:\r
             self.SkuOverrideValues[SkuName][DefaultStoreName] = OrderedDict()\r
-        if FieldName in self.SkuOverrideValues[SkuName][DefaultStoreName]:\r
-            del self.SkuOverrideValues[SkuName][DefaultStoreName][FieldName]\r
-        self.SkuOverrideValues[SkuName][DefaultStoreName][FieldName] = [Value.strip(), FileName, LineNo]\r
-        return self.SkuOverrideValues[SkuName][DefaultStoreName][FieldName]\r
+        if DimensionAttr not in self.SkuOverrideValues[SkuName][DefaultStoreName]:\r
+            self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr] = collections.OrderedDict()\r
+        if FieldName in self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr]:\r
+            del self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr][FieldName]\r
+        self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr][FieldName] = [Value.strip(), FileName, LineNo]\r
+        return self.SkuOverrideValues[SkuName][DefaultStoreName][DimensionAttr][FieldName]\r
 \r
     def SetPcdMode (self, PcdMode):\r
         self.PcdMode = PcdMode\r
@@ -208,7 +299,7 @@ class StructurePcd(PcdClassObject):
         self.TokenSpaceGuidCName = PcdObject.TokenSpaceGuidCName if PcdObject.TokenSpaceGuidCName else PcdObject.TokenSpaceGuidCName\r
         self.TokenSpaceGuidValue = PcdObject.TokenSpaceGuidValue if PcdObject.TokenSpaceGuidValue else self.TokenSpaceGuidValue\r
         self.Type = PcdObject.Type if PcdObject.Type else self.Type\r
-        self.DatumType = PcdObject.DatumType if PcdObject.DatumType else self.DatumType\r
+        self._DatumType = PcdObject.DatumType if PcdObject.DatumType else self.DatumType\r
         self.DefaultValue = PcdObject.DefaultValue if  PcdObject.DefaultValue else self.DefaultValue\r
         self.TokenValue = PcdObject.TokenValue if PcdObject.TokenValue else self.TokenValue\r
         self.MaxDatumSize = PcdObject.MaxDatumSize if PcdObject.MaxDatumSize else self.MaxDatumSize\r
@@ -224,13 +315,13 @@ class StructurePcd(PcdClassObject):
         self.DscRawValue = PcdObject.DscRawValue if PcdObject.DscRawValue else self.DscRawValue\r
         self.PcdValueFromComm = PcdObject.PcdValueFromComm if PcdObject.PcdValueFromComm else self.PcdValueFromComm\r
         self.PcdValueFromFdf = PcdObject.PcdValueFromFdf if PcdObject.PcdValueFromFdf else self.PcdValueFromFdf\r
+        self.CustomAttribute = PcdObject.CustomAttribute if PcdObject.CustomAttribute else self.CustomAttribute\r
         self.UserDefinedDefaultStoresFlag = PcdObject.UserDefinedDefaultStoresFlag if PcdObject.UserDefinedDefaultStoresFlag else self.UserDefinedDefaultStoresFlag\r
         if isinstance(PcdObject, StructurePcd):\r
             self.StructuredPcdIncludeFile = PcdObject.StructuredPcdIncludeFile if PcdObject.StructuredPcdIncludeFile else self.StructuredPcdIncludeFile\r
             self.PackageDecs = PcdObject.PackageDecs if PcdObject.PackageDecs else self.PackageDecs\r
             self.DefaultValues = PcdObject.DefaultValues if PcdObject.DefaultValues else self.DefaultValues\r
             self.PcdMode = PcdObject.PcdMode if PcdObject.PcdMode else self.PcdMode\r
-            self.DefaultFromDSC=None\r
             self.DefaultValueFromDec = PcdObject.DefaultValueFromDec if PcdObject.DefaultValueFromDec else self.DefaultValueFromDec\r
             self.SkuOverrideValues = PcdObject.SkuOverrideValues if PcdObject.SkuOverrideValues else self.SkuOverrideValues\r
             self.StructName = PcdObject.DatumType if PcdObject.DatumType else self.StructName\r
@@ -240,7 +331,26 @@ class StructurePcd(PcdClassObject):
             self.PcdFieldValueFromComm = PcdObject.PcdFieldValueFromComm if PcdObject.PcdFieldValueFromComm else self.PcdFieldValueFromComm\r
             self.PcdFieldValueFromFdf = PcdObject.PcdFieldValueFromFdf if PcdObject.PcdFieldValueFromFdf else self.PcdFieldValueFromFdf\r
 \r
-LibraryClassObject = namedtuple('LibraryClassObject', ['LibraryClass','SupModList'], verbose=False)\r
+    def __deepcopy__(self,memo):\r
+        new_pcd = StructurePcd()\r
+        self.sharedcopy(new_pcd)\r
+\r
+        new_pcd.DefaultValueFromDec = self.DefaultValueFromDec\r
+        new_pcd.PcdMode = self.PcdMode\r
+        new_pcd.StructName = self.DatumType\r
+        new_pcd.PcdDefineLineNo = self.PcdDefineLineNo\r
+        new_pcd.PkgPath = self.PkgPath\r
+        new_pcd.StructuredPcdIncludeFile = [item for item in self.StructuredPcdIncludeFile]\r
+        new_pcd.PackageDecs = [item for item in self.PackageDecs]\r
+        new_pcd.DefaultValues = CopyDict(self.DefaultValues)\r
+        new_pcd.DefaultFromDSC=CopyDict(self.DefaultFromDSC)\r
+        new_pcd.SkuOverrideValues = CopyDict(self.SkuOverrideValues)\r
+        new_pcd.PcdFieldValueFromComm = CopyDict(self.PcdFieldValueFromComm)\r
+        new_pcd.PcdFieldValueFromFdf = CopyDict(self.PcdFieldValueFromFdf)\r
+        new_pcd.ValueChain = {item for item in self.ValueChain}\r
+        return new_pcd\r
+\r
+LibraryClassObject = namedtuple('LibraryClassObject', ['LibraryClass','SupModList'])\r
 \r
 ## ModuleBuildClassObject\r
 #\r
@@ -297,7 +407,6 @@ class ModuleBuildClassObject(object):
         self.PcdIsDriver             = ''\r
         self.BinaryModule            = ''\r
         self.Shadow                  = ''\r
-        self.SourceOverridePath      = ''\r
         self.CustomMakefile          = {}\r
         self.Specification           = {}\r
         self.LibraryClass            = []\r