Reviewed-by: Liming Gao <[email protected]>

>-----Original Message-----
>From: Feng, Bob C
>Sent: Tuesday, December 26, 2017 11:34 AM
>To: [email protected]
>Cc: Feng, Bob C <[email protected]>; Gao, Liming <[email protected]>
>Subject: [Patch] BaseTools: Fix building FatPkg failed issue
>
>Using property instead of vairable for DecPcds.
>
>Contributed-under: TianoCore Contribution Agreement 1.1
>Signed-off-by: Bob Feng <[email protected]>
>CC: Liming Gao <[email protected]>
>---
> BaseTools/Source/Python/Workspace/DscBuildData.py | 18
>++++++++++++++++--
> 1 file changed, 16 insertions(+), 2 deletions(-)
>
>diff --git a/BaseTools/Source/Python/Workspace/DscBuildData.py
>b/BaseTools/Source/Python/Workspace/DscBuildData.py
>index b60c0fdf3..dcc70e8ba 100644
>--- a/BaseTools/Source/Python/Workspace/DscBuildData.py
>+++ b/BaseTools/Source/Python/Workspace/DscBuildData.py
>@@ -1010,11 +1010,11 @@ class DscBuildData(PlatformBuildClassObject):
>             else:
>                 EdkLogger.error('build', PARSER_ERROR,
>                             "Pcd (%s.%s) defined in DSC is not declared in 
> DEC files. Arch:
>['%s']" % (str_pcd[0], str_pcd[1], self._Arch),
>                             File=self.MetaFile,Line = 
> StrPcdSet[str_pcd][0][5])
>         # Add the Structure PCD that only defined in DEC, don't have override 
> in
>DSC file
>-        for Pcd in self._DecPcds:
>+        for Pcd in self.DecPcds:
>             if type (self._DecPcds[Pcd]) is StructurePcd:
>                 if Pcd not in S_pcd_set:
>                     str_pcd_obj_str = StructurePcd()
>                     str_pcd_obj_str.copy(self._DecPcds[Pcd])
>                     str_pcd_obj = Pcds.get(Pcd, None)
>@@ -1987,11 +1987,25 @@ class DscBuildData(PlatformBuildClassObject):
>     #
>     def AddPcd(self, Name, Guid, Value):
>         if (Name, Guid) not in self.Pcds:
>             self.Pcds[Name, Guid] = PcdClassObject(Name, Guid, '', '', '', 
> '', '', {},
>False, None)
>         self.Pcds[Name, Guid].DefaultValue = Value
>-
>+    @property
>+    def DecPcds(self):
>+        if self._DecPcds == None:
>+            FdfInfList = []
>+            if GlobalData.gFdfParser:
>+                FdfInfList = GlobalData.gFdfParser.Profile.InfList
>+            PkgSet = set()
>+            for Inf in FdfInfList:
>+                ModuleFile = PathClass(NormPath(Inf), GlobalData.gWorkspace,
>Arch=self._Arch)
>+                if ModuleFile in self._Modules:
>+                    continue
>+                ModuleData = self._Bdb[ModuleFile, self._Arch, self._Target,
>self._Toolchain]
>+                PkgSet.update(ModuleData.Packages)
>+            self._DecPcds = GetDeclaredPcd(self, self._Bdb, self._Arch,
>self._Target, self._Toolchain,PkgSet)
>+        return self._DecPcds
>     _Macros = property(_GetMacros)
>     Arch = property(_GetArch, _SetArch)
>     Platform = property(_GetPlatformName)
>     PlatformName = property(_GetPlatformName)
>     Guid = property(_GetFileGuid)
>--
>2.14.3.windows.1

_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.01.org/mailman/listinfo/edk2-devel

Reply via email to