mirror of https://github.com/acidanthera/audk.git
BaseTools: Workspace - refactor RegEx to minimize multiple compiling
Cc: Liming Gao <liming.gao@intel.com> Cc: Yonghong Zhu <yonghong.zhu@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Jaben Carsey <jaben.carsey@intel.com> Reviewed-by: Yonghong Zhu <yonghong.zhu@intel.com>
This commit is contained in:
parent
ef42ef7e6d
commit
3e4faa268e
|
@ -89,6 +89,8 @@ MAKEROOT ?= $(EDK_TOOLS_PATH)/Source/C
|
||||||
LIBS = -lCommon
|
LIBS = -lCommon
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
variablePattern = re.compile(r'[\t\s]*0[xX][a-fA-F0-9]+$')
|
||||||
|
|
||||||
## regular expressions for finding decimal and hex numbers
|
## regular expressions for finding decimal and hex numbers
|
||||||
Pattern = re.compile('^[1-9]\d*|0$')
|
Pattern = re.compile('^[1-9]\d*|0$')
|
||||||
HexPattern = re.compile(r'0[xX][0-9a-fA-F]+$')
|
HexPattern = re.compile(r'0[xX][0-9a-fA-F]+$')
|
||||||
|
@ -2415,7 +2417,7 @@ class DscBuildData(PlatformBuildClassObject):
|
||||||
if VariableOffset.isdigit():
|
if VariableOffset.isdigit():
|
||||||
if int(VariableOffset, 10) > 0xFFFF:
|
if int(VariableOffset, 10) > 0xFFFF:
|
||||||
ExceedMax = True
|
ExceedMax = True
|
||||||
elif re.match(r'[\t\s]*0[xX][a-fA-F0-9]+$', VariableOffset):
|
elif variablePattern.match(VariableOffset):
|
||||||
if int(VariableOffset, 16) > 0xFFFF:
|
if int(VariableOffset, 16) > 0xFFFF:
|
||||||
ExceedMax = True
|
ExceedMax = True
|
||||||
# For Offset written in "A.B"
|
# For Offset written in "A.B"
|
||||||
|
|
|
@ -35,6 +35,10 @@ from Common.LongFilePathSupport import OpenLongFilePath as open
|
||||||
from MetaFileTable import MetaFileStorage
|
from MetaFileTable import MetaFileStorage
|
||||||
from MetaFileCommentParser import CheckInfComment
|
from MetaFileCommentParser import CheckInfComment
|
||||||
|
|
||||||
|
## RegEx for finding file versions
|
||||||
|
hexVersionPattern = re.compile(r'0[xX][\da-f-A-F]{5,8}')
|
||||||
|
decVersionPattern = re.compile(r'\d+\.\d+')
|
||||||
|
|
||||||
## A decorator used to parse macro definition
|
## A decorator used to parse macro definition
|
||||||
def ParseMacro(Parser):
|
def ParseMacro(Parser):
|
||||||
def MacroParser(self):
|
def MacroParser(self):
|
||||||
|
@ -366,9 +370,9 @@ class MetaFileParser(object):
|
||||||
EdkLogger.error("Parser", FORMAT_INVALID, "%s not defined" % (Macro), ExtraData=self._CurrentLine, File=self.MetaFile, Line=self._LineIndex + 1)
|
EdkLogger.error("Parser", FORMAT_INVALID, "%s not defined" % (Macro), ExtraData=self._CurrentLine, File=self.MetaFile, Line=self._LineIndex + 1)
|
||||||
# Sometimes, we need to make differences between EDK and EDK2 modules
|
# Sometimes, we need to make differences between EDK and EDK2 modules
|
||||||
if Name == 'INF_VERSION':
|
if Name == 'INF_VERSION':
|
||||||
if re.match(r'0[xX][\da-f-A-F]{5,8}', Value):
|
if hexVersionPattern.match(Value):
|
||||||
self._Version = int(Value, 0)
|
self._Version = int(Value, 0)
|
||||||
elif re.match(r'\d+\.\d+', Value):
|
elif decVersionPattern.match(Value):
|
||||||
ValueList = Value.split('.')
|
ValueList = Value.split('.')
|
||||||
Major = '%04o' % int(ValueList[0], 0)
|
Major = '%04o' % int(ValueList[0], 0)
|
||||||
Minor = '%04o' % int(ValueList[1], 0)
|
Minor = '%04o' % int(ValueList[1], 0)
|
||||||
|
|
Loading…
Reference in New Issue