BaseTools: Fix old python2 idioms
Based on "futurize -f lib2to3.fixes.fix_idioms"
* Change some type comparisons to isinstance() calls:
    type(x) == T -> isinstance(x, T)
    type(x) is T -> isinstance(x, T)
    type(x) != T -> not isinstance(x, T)
    type(x) is not T -> not isinstance(x, T)
* Change "while 1:" into "while True:".
* Change both
    v = list(EXPR)
    v.sort()
    foo(v)
and the more general
    v = EXPR
    v.sort()
    foo(v)
into
    v = sorted(EXPR)
    foo(v)
Contributed-under: TianoCore Contribution Agreement 1.1
Cc: Yonghong Zhu <yonghong.zhu@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Signed-off-by: Gary Lin <glin@suse.com>
Reviewed-by: Yonghong Zhu <yonghong.zhu@intel.com>
			
			
This commit is contained in:
		| @@ -78,10 +78,10 @@ def ParseMacro(Parser): | ||||
|             # | ||||
|             # First judge whether this DEFINE is in conditional directive statements or not. | ||||
|             # | ||||
|             if type(self) == DscParser and self._InDirective > -1: | ||||
|             if isinstance(self, DscParser) and self._InDirective > -1: | ||||
|                 pass | ||||
|             else: | ||||
|                 if type(self) == DecParser: | ||||
|                 if isinstance(self, DecParser): | ||||
|                     if MODEL_META_DATA_HEADER in self._SectionType: | ||||
|                         self._FileLocalMacros[Name] = Value | ||||
|                     else: | ||||
| @@ -92,7 +92,7 @@ def ParseMacro(Parser): | ||||
|                     self._ConstructSectionMacroDict(Name, Value) | ||||
|  | ||||
|         # EDK_GLOBAL defined macros | ||||
|         elif type(self) != DscParser: | ||||
|         elif not isinstance(self, DscParser): | ||||
|             EdkLogger.error('Parser', FORMAT_INVALID, "EDK_GLOBAL can only be used in .dsc file", | ||||
|                             ExtraData=self._CurrentLine, File=self.MetaFile, Line=self._LineIndex + 1) | ||||
|         elif self._SectionType != MODEL_META_DATA_HEADER: | ||||
| @@ -233,7 +233,7 @@ class MetaFileParser(object): | ||||
|     #   DataInfo = [data_type, scope1(arch), scope2(platform/moduletype)] | ||||
|     # | ||||
|     def __getitem__(self, DataInfo): | ||||
|         if type(DataInfo) != type(()): | ||||
|         if not isinstance(DataInfo, type(())): | ||||
|             DataInfo = (DataInfo,) | ||||
|  | ||||
|         # Parse the file first, if necessary | ||||
| @@ -275,7 +275,7 @@ class MetaFileParser(object): | ||||
|         TokenList = GetSplitValueList(self._CurrentLine, TAB_VALUE_SPLIT) | ||||
|         self._ValueList[0:len(TokenList)] = TokenList | ||||
|         # Don't do macro replacement for dsc file at this point | ||||
|         if type(self) != DscParser: | ||||
|         if not isinstance(self, DscParser): | ||||
|             Macros = self._Macros | ||||
|             self._ValueList = [ReplaceMacro(Value, Macros) for Value in self._ValueList] | ||||
|  | ||||
| @@ -382,7 +382,7 @@ class MetaFileParser(object): | ||||
|                 EdkLogger.error('Parser', FORMAT_INVALID, "Invalid version number", | ||||
|                                 ExtraData=self._CurrentLine, File=self.MetaFile, Line=self._LineIndex + 1) | ||||
|  | ||||
|         if type(self) == InfParser and self._Version < 0x00010005: | ||||
|         if isinstance(self, InfParser) and self._Version < 0x00010005: | ||||
|             # EDK module allows using defines as macros | ||||
|             self._FileLocalMacros[Name] = Value | ||||
|         self._Defines[Name] = Value | ||||
| @@ -398,7 +398,7 @@ class MetaFileParser(object): | ||||
|             self._ValueList[1] = TokenList2[1]              # keys | ||||
|         else: | ||||
|             self._ValueList[1] = TokenList[0] | ||||
|         if len(TokenList) == 2 and type(self) != DscParser: # value | ||||
|         if len(TokenList) == 2 and not isinstance(self, DscParser): # value | ||||
|             self._ValueList[2] = ReplaceMacro(TokenList[1], self._Macros) | ||||
|  | ||||
|         if self._ValueList[1].count('_') != 4: | ||||
| @@ -426,7 +426,7 @@ class MetaFileParser(object): | ||||
|         # DecParser SectionType is a list, will contain more than one item only in Pcd Section | ||||
|         # As Pcd section macro usage is not alllowed, so here it is safe | ||||
|         # | ||||
|         if type(self) == DecParser: | ||||
|         if isinstance(self, DecParser): | ||||
|             SectionDictKey = self._SectionType[0], ScopeKey | ||||
|         else: | ||||
|             SectionDictKey = self._SectionType, ScopeKey | ||||
| @@ -443,7 +443,7 @@ class MetaFileParser(object): | ||||
|         SpeSpeMacroDict = {} | ||||
|  | ||||
|         ActiveSectionType = self._SectionType | ||||
|         if type(self) == DecParser: | ||||
|         if isinstance(self, DecParser): | ||||
|             ActiveSectionType = self._SectionType[0] | ||||
|  | ||||
|         for (SectionType, Scope) in self._SectionsMacroDict: | ||||
| @@ -1252,7 +1252,7 @@ class DscParser(MetaFileParser): | ||||
|             Macros.update(self._Symbols) | ||||
|         if GlobalData.BuildOptionPcd: | ||||
|             for Item in GlobalData.BuildOptionPcd: | ||||
|                 if type(Item) is tuple: | ||||
|                 if isinstance(Item, tuple): | ||||
|                     continue | ||||
|                 PcdName, TmpValue = Item.split("=") | ||||
|                 TmpValue = BuildOptionValue(TmpValue, self._GuidDict) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user