https://bugzilla.tianocore.org/show_bug.cgi?id=1373 Replace BSD 2-Clause License with BSD+Patent License. This change is based on the following emails: https://lists.01.org/pipermail/edk2-devel/2019-February/036260.html https://lists.01.org/pipermail/edk2-devel/2018-October/030385.html RFCs with detailed process for the license change: V3: https://lists.01.org/pipermail/edk2-devel/2019-March/038116.html V2: https://lists.01.org/pipermail/edk2-devel/2019-March/037669.html V1: https://lists.01.org/pipermail/edk2-devel/2019-March/037500.html Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Bob Feng <bob.c.feng@intel.com>
		
			
				
	
	
		
			99 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
## @file
 | 
						|
# This file contained the parser for [Depex] sections in INF file
 | 
						|
#
 | 
						|
# Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
 | 
						|
#
 | 
						|
# SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
#
 | 
						|
'''
 | 
						|
InfDepexSectionParser
 | 
						|
'''
 | 
						|
##
 | 
						|
# Import Modules
 | 
						|
#
 | 
						|
import re
 | 
						|
import Logger.Log as Logger
 | 
						|
from Logger import StringTable as ST
 | 
						|
from Logger.ToolError import FORMAT_INVALID
 | 
						|
from Parser.InfParserMisc import InfExpandMacro
 | 
						|
from Library import DataType as DT
 | 
						|
from Library.Misc import GetSplitValueList
 | 
						|
from Parser.InfParserMisc import InfParserSectionRoot
 | 
						|
 | 
						|
class InfDepexSectionParser(InfParserSectionRoot):
 | 
						|
    ## InfDepexParser
 | 
						|
    #
 | 
						|
    # For now, only separate Depex String and comments.
 | 
						|
    # Have two types of section header.
 | 
						|
    # 1. [Depex.Arch.ModuleType, ...]
 | 
						|
    # 2. [Depex.Arch|FFE, ...]
 | 
						|
    #
 | 
						|
    def InfDepexParser(self, SectionString, InfSectionObject, FileName):
 | 
						|
        DepexContent = []
 | 
						|
        DepexComment = []
 | 
						|
        ValueList    = []
 | 
						|
        #
 | 
						|
        # Parse section content
 | 
						|
        #
 | 
						|
        for Line in SectionString:
 | 
						|
            LineContent = Line[0]
 | 
						|
            LineNo      = Line[1]
 | 
						|
 | 
						|
            #
 | 
						|
            # Found comment
 | 
						|
            #
 | 
						|
            if LineContent.strip().startswith(DT.TAB_COMMENT_SPLIT):
 | 
						|
                DepexComment.append((LineContent, LineNo))
 | 
						|
                continue
 | 
						|
            #
 | 
						|
            # Replace with [Defines] section Macro
 | 
						|
            #
 | 
						|
            LineContent = InfExpandMacro(LineContent,
 | 
						|
                                         (FileName, LineContent, Line[1]),
 | 
						|
                                         self.FileLocalMacros,
 | 
						|
                                         None, True)
 | 
						|
 | 
						|
            CommentCount = LineContent.find(DT.TAB_COMMENT_SPLIT)
 | 
						|
 | 
						|
            if CommentCount > -1:
 | 
						|
                DepexComment.append((LineContent[CommentCount:], LineNo))
 | 
						|
                LineContent = LineContent[:CommentCount-1]
 | 
						|
 | 
						|
 | 
						|
            CommentCount = -1
 | 
						|
            DepexContent.append((LineContent, LineNo))
 | 
						|
 | 
						|
            TokenList = GetSplitValueList(LineContent, DT.TAB_COMMENT_SPLIT)
 | 
						|
            ValueList[0:len(TokenList)] = TokenList
 | 
						|
 | 
						|
        #
 | 
						|
        # Current section archs
 | 
						|
        #
 | 
						|
        KeyList = []
 | 
						|
        LastItem = ''
 | 
						|
        for Item in self.LastSectionHeaderContent:
 | 
						|
            LastItem = Item
 | 
						|
            if (Item[1], Item[2], Item[3]) not in KeyList:
 | 
						|
                KeyList.append((Item[1], Item[2], Item[3]))
 | 
						|
 | 
						|
        NewCommentList = []
 | 
						|
        FormatCommentLn = -1
 | 
						|
        ReFormatComment = re.compile(r"""#(?:\s*)\[(.*?)\](?:.*)""", re.DOTALL)
 | 
						|
        for CommentItem in DepexComment:
 | 
						|
            CommentContent = CommentItem[0]
 | 
						|
            if ReFormatComment.match(CommentContent) is not None:
 | 
						|
                FormatCommentLn = CommentItem[1] + 1
 | 
						|
                continue
 | 
						|
 | 
						|
            if CommentItem[1] != FormatCommentLn:
 | 
						|
                NewCommentList.append(CommentContent)
 | 
						|
            else:
 | 
						|
                FormatCommentLn = CommentItem[1] + 1
 | 
						|
 | 
						|
        if not InfSectionObject.SetDepex(DepexContent, KeyList = KeyList, CommentList = NewCommentList):
 | 
						|
            Logger.Error('InfParser',
 | 
						|
                         FORMAT_INVALID,
 | 
						|
                         ST.ERR_INF_PARSER_MODULE_SECTION_TYPE_ERROR%("[Depex]"),
 | 
						|
                         File=FileName,
 | 
						|
                         Line=LastItem[3])
 |