mirror of https://github.com/acidanthera/audk.git
BaseTools: add error check for Macro usage in the INF file
Use of MACRO statements in the EDK II INF files is limited to local usage only; global or external macros are not permitted. This patch add the check for not defined macros. Cc: Liming Gao <liming.gao@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Yonghong Zhu <yonghong.zhu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
parent
ed1a2d42d5
commit
dc4c770763
|
@ -1,7 +1,7 @@
|
||||||
## @file
|
## @file
|
||||||
# This file is used to parse meta files
|
# This file is used to parse meta files
|
||||||
#
|
#
|
||||||
# Copyright (c) 2008 - 2016, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2008 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
# (C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<BR>
|
# (C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<BR>
|
||||||
# This program and the accompanying materials
|
# This program and the accompanying materials
|
||||||
# are licensed and made available under the terms and conditions of the BSD License
|
# are licensed and made available under the terms and conditions of the BSD License
|
||||||
|
@ -351,6 +351,13 @@ class MetaFileParser(object):
|
||||||
|
|
||||||
self._ValueList = [ReplaceMacro(Value, self._Macros) for Value in self._ValueList]
|
self._ValueList = [ReplaceMacro(Value, self._Macros) for Value in self._ValueList]
|
||||||
Name, Value = self._ValueList[1], self._ValueList[2]
|
Name, Value = self._ValueList[1], self._ValueList[2]
|
||||||
|
MacroUsed = GlobalData.gMacroRefPattern.findall(Value)
|
||||||
|
if len(MacroUsed) != 0:
|
||||||
|
for Macro in MacroUsed:
|
||||||
|
if Macro in GlobalData.gGlobalDefines:
|
||||||
|
EdkLogger.error("Parser", FORMAT_INVALID, "Global macro %s is not permitted." % (Macro), ExtraData=self._CurrentLine, File=self.MetaFile, Line=self._LineIndex + 1)
|
||||||
|
else:
|
||||||
|
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 re.match(r'0[xX][\da-f-A-F]{5,8}', Value):
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
## @file
|
## @file
|
||||||
# This file is used to create a database used by build tool
|
# This file is used to create a database used by build tool
|
||||||
#
|
#
|
||||||
# Copyright (c) 2008 - 2016, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2008 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
# (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
|
# (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
|
||||||
# This program and the accompanying materials
|
# This program and the accompanying materials
|
||||||
# are licensed and made available under the terms and conditions of the BSD License
|
# are licensed and made available under the terms and conditions of the BSD License
|
||||||
|
@ -1830,6 +1830,8 @@ class InfBuildData(ModuleBuildClassObject):
|
||||||
if self.AutoGenVersion < 0x00010005:
|
if self.AutoGenVersion < 0x00010005:
|
||||||
self.__Macros.update(GlobalData.gEdkGlobal)
|
self.__Macros.update(GlobalData.gEdkGlobal)
|
||||||
self.__Macros.update(GlobalData.gGlobalDefines)
|
self.__Macros.update(GlobalData.gGlobalDefines)
|
||||||
|
else:
|
||||||
|
self.__Macros.update(self.Defines)
|
||||||
return self.__Macros
|
return self.__Macros
|
||||||
|
|
||||||
## Get architecture
|
## Get architecture
|
||||||
|
|
Loading…
Reference in New Issue