2 # GNU/Linux makefile for 'VfrCompile' module build.
4 # Copyright (c) 2008 - 2018, Intel Corporation. All rights reserved.<BR>
5 # SPDX-License-Identifier: BSD-2-Clause-Patent
14 TOOL_INCLUDE = -I Pccts/h
16 #OBJECTS = VfrSyntax.o VfrServices.o DLGLexer.o EfiVfrParser.o ATokenBuffer.o DLexerBase.o AParser.o
17 OBJECTS = AParser.o DLexerBase.o ATokenBuffer.o EfiVfrParser.o VfrLexer.o VfrSyntax.o \
18 VfrFormPkg.o VfrError.o VfrUtilityLib.o VfrCompiler.o
20 VFR_CPPFLAGS = -Wno-deprecated-register -DPCCTS_USE_NAMESPACE_STD $(BUILD_CPPFLAGS)
22 VFR_CPPFLAGS = -DPCCTS_USE_NAMESPACE_STD $(BUILD_CPPFLAGS)
24 # keep BUILD_OPTFLAGS last
25 VFR_CXXFLAGS = $(BUILD_OPTFLAGS)
27 # keep EXTRA_LDFLAGS last
28 VFR_LFLAGS = $(EXTRA_LDFLAGS)
32 EXTRA_CLEAN_OBJECTS = EfiVfrParser.cpp EfiVfrParser.h VfrParser.dlg VfrTokens.h VfrLexer.cpp VfrLexer.h VfrSyntax.cpp tokens.h
36 include $(MAKEROOT)/Makefiles/header.makefile
38 APPLICATION = $(MAKEROOT)/bin/$(APPNAME)
41 all: $(MAKEROOT)/bin $(APPLICATION)
43 $(APPLICATION): $(OBJECTS)
44 $(LINKER) -o $(APPLICATION) $(VFR_LFLAGS) $(OBJECTS) -L$(MAKEROOT)/libs $(LIBS)
46 VfrCompiler.o: ../Include/Common/BuildVersion.h
48 include $(MAKEROOT)/Makefiles/footer.makefile
50 VfrSyntax.cpp EfiVfrParser.cpp EfiVfrParser.h VfrParser.dlg VfrTokens.h: Pccts/antlr/antlr VfrSyntax.g
51 Pccts/antlr/antlr -CC -e3 -ck 3 -k 2 -fl VfrParser.dlg -ft VfrTokens.h -o . VfrSyntax.g
53 VfrLexer.cpp VfrLexer.h: Pccts/dlg/dlg VfrParser.dlg
54 Pccts/dlg/dlg -C2 -i -CC -cl VfrLexer -o . VfrParser.dlg
57 BIN_DIR='.' $(MAKE) -C Pccts/antlr
60 BIN_DIR='.' $(MAKE) -C Pccts/dlg
62 ATokenBuffer.o: Pccts/h/ATokenBuffer.cpp
63 $(BUILD_CXX) -c $(VFR_CPPFLAGS) $(INC) $(VFR_CXXFLAGS) $? -o $@
65 DLexerBase.o: Pccts/h/DLexerBase.cpp
66 $(BUILD_CXX) -c $(VFR_CPPFLAGS) $(INC) $(VFR_CXXFLAGS) $? -o $@
68 AParser.o: Pccts/h/AParser.cpp
69 $(BUILD_CXX) -c $(VFR_CPPFLAGS) $(INC) $(VFR_CXXFLAGS) $? -o $@
71 VfrSyntax.o: VfrSyntax.cpp
72 $(BUILD_CXX) -c $(VFR_CPPFLAGS) $(INC) $(VFR_CXXFLAGS) $? -o $@
77 BIN_DIR='.' $(MAKE) -C Pccts/antlr clean
78 BIN_DIR='.' $(MAKE) -C Pccts/dlg clean
79 rm -f $(EXTRA_CLEAN_OBJECTS)