]> git.proxmox.com Git - mirror_edk2.git/commitdiff
BaseTools: Modify class OrderedListDict
authorFeng, YunhuaX <yunhuax.feng@intel.com>
Wed, 8 Aug 2018 06:55:35 +0000 (14:55 +0800)
committerYonghong Zhu <yonghong.zhu@intel.com>
Thu, 23 Aug 2018 07:01:27 +0000 (15:01 +0800)
class OrderedListDict(OrderedDict, defaultdict) will
encounter multiple bases have instance lay-out
conflict error on python3

Cc: Liming Gao <liming.gao@intel.com>
Cc: Yonghong Zhu <yonghong.zhu@intel.com>
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Yunhua Feng <yunhuax.feng@intel.com>
Reviewed-by: Yonghong Zhu <yonghong.zhu@intel.com>
BaseTools/Source/Python/Workspace/WorkspaceCommon.py

index d987bbf441eab71c149a88b5d7f4658c7d8cc52a..8d8a3e278987ee64f5fe0d3eb5ee32709730d0d4 100644 (file)
@@ -21,11 +21,15 @@ from Common.BuildToolError import RESOURCE_NOT_AVAILABLE
 from Common.BuildToolError import OPTION_MISSING\r
 from Common.BuildToolError import BUILD_ERROR\r
 \r
-class OrderedListDict(OrderedDict, defaultdict):\r
+class OrderedListDict(OrderedDict):\r
     def __init__(self, *args, **kwargs):\r
         super(OrderedListDict, self).__init__(*args, **kwargs)\r
         self.default_factory = list\r
 \r
+    def __missing__(self, key):\r
+        self[key] = Value = self.default_factory()\r
+        return Value\r
+\r
 ## Get all packages from platform for specified arch, target and toolchain\r
 #\r
 #  @param Platform: DscBuildData instance\r