1afed099bd2e759efd4bb63fdc525d3445f94cc13Daniel DunbarCLANG_LEVEL := ../../..
2a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarBUILT_SOURCES = \
3a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	DiagnosticAnalysisKinds.inc DiagnosticASTKinds.inc \
4a5ef44ff5d93a3be6ca67782828157a71894cf0cDmitri Gribenko	DiagnosticCommentKinds.inc \
5a393e9eedcc28b25f521a4feceb3b56e3d0d360fDouglas Gregor	DiagnosticCommonKinds.inc DiagnosticDriverKinds.inc \
6a393e9eedcc28b25f521a4feceb3b56e3d0d360fDouglas Gregor	DiagnosticFrontendKinds.inc DiagnosticLexKinds.inc \
78469c313879bb3deb4af2d501c73e32add4b8e40Chris Lattner	DiagnosticParseKinds.inc DiagnosticSemaKinds.inc \
866aff4a3b0e127b523260c9720544a3e4be9a14fChandler Carruth	DiagnosticSerializationKinds.inc \
97d2b8c1fcc2b707be78b09930a7767477822462fDouglas Gregor	DiagnosticIndexName.inc DiagnosticGroups.inc AttrList.inc arm_neon.inc \
10a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	Version.inc
11a393e9eedcc28b25f521a4feceb3b56e3d0d360fDouglas Gregor
128ee50eaf015e3857c04d0ed229f8165faee5544dChris LattnerTABLEGEN_INC_FILES_COMMON = 1
13a393e9eedcc28b25f521a4feceb3b56e3d0d360fDouglas Gregor
14afed099bd2e759efd4bb63fdc525d3445f94cc13Daniel Dunbarinclude $(CLANG_LEVEL)/Makefile
158ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner
161144c218f5d74f2270ebcd5ddd82dc472790eaefDaniel DunbarINPUT_TDS = $(wildcard $(PROJ_SRC_DIR)/Diagnostic*.td)
171144c218f5d74f2270ebcd5ddd82dc472790eaefDaniel Dunbar
18c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbar# Compute the Clang version from the LLVM version, unless specified explicitly.
19c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbarifndef CLANG_VERSION
20c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel DunbarCLANG_VERSION := $(subst svn,,$(LLVMVersion))
21461ed44afac0aa56810e9f870d51692ee4ab235bBill WendlingCLANG_VERSION := $(subst rc,,$(CLANG_VERSION))
22c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbarendif
23c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbar
24a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_COMPONENTS := $(subst ., ,$(CLANG_VERSION))
25a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_MAJOR := $(word 1,$(CLANG_VERSION_COMPONENTS))
26a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_MINOR := $(word 2,$(CLANG_VERSION_COMPONENTS))
27a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_PATCHLEVEL := $(word 3,$(CLANG_VERSION_COMPONENTS))
28a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbarifeq ($(CLANG_VERSION_PATCHLEVEL),)
29a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_HAS_VERSION_PATCHLEVEL := 0
30a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbarelse
31a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_HAS_VERSION_PATCHLEVEL := 1
32a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbarendif
33a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar
34e052bda1f3f8b857fa02abeef7b97f66308225fdArgyrios Kyrtzidis$(ObjDir)/Diagnostic%Kinds.inc.tmp : Diagnostic.td $(INPUT_TDS) $(CLANG_TBLGEN) $(ObjDir)/.dir
358ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner	$(Echo) "Building Clang $(patsubst Diagnostic%Kinds.inc.tmp,%,$(@F)) diagnostic tables with tblgen"
366ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-diags-defs -clang-component=$(patsubst Diagnostic%Kinds.inc.tmp,%,$(@F)) -o $(call SYSPATH, $@) $<
378ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner
386ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/DiagnosticIndexName.inc.tmp : Diagnostic.td $(INPUT_TDS) $(CLANG_TBLGEN) $(ObjDir)/.dir
397d2b8c1fcc2b707be78b09930a7767477822462fDouglas Gregor	$(Echo) "Building Clang diagnostic name index with tblgen"
406ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-diags-index-name -o $(call SYSPATH, $@) $<
417d2b8c1fcc2b707be78b09930a7767477822462fDouglas Gregor
426ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/DiagnosticGroups.inc.tmp : Diagnostic.td DiagnosticGroups.td $(INPUT_TDS) $(CLANG_TBLGEN) $(ObjDir)/.dir
438469c313879bb3deb4af2d501c73e32add4b8e40Chris Lattner	$(Echo) "Building Clang diagnostic groups with tblgen"
446ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-diag-groups -o $(call SYSPATH, $@) $<
458ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner
466ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/AttrList.inc.tmp : Attr.td $(CLANG_TBLGEN) $(ObjDir)/.dir
47387475d0c18aaeb022108de9d33b6c9fb7998843Sean Hunt	$(Echo) "Building Clang attribute list with tblgen"
486ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-attr-list -o $(call SYSPATH, $@) \
49387475d0c18aaeb022108de9d33b6c9fb7998843Sean Hunt	  -I $(PROJ_SRC_DIR)/../.. $<
50a23326b5c244a03bf61ebb86db60a777ea26f926Nate Begeman
516ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/arm_neon.inc.tmp : arm_neon.td $(CLANG_TBLGEN) $(ObjDir)/.dir
52a23326b5c244a03bf61ebb86db60a777ea26f926Nate Begeman	$(Echo) "Building Clang arm_neon.inc with tblgen"
536ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-arm-neon-sema -o $(call SYSPATH, $@) $<
54a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar
55c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbar$(ObjDir)/Version.inc.tmp : Version.inc.in Makefile $(LLVM_OBJ_ROOT)/Makefile.config $(ObjDir)/.dir
56a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	$(Echo) "Updating Clang version info."
57a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	$(Verb)sed -e "s#@CLANG_VERSION@#$(CLANG_VERSION)#g" \
58a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_VERSION_MAJOR@#$(CLANG_VERSION_MAJOR)#g" \
59a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_VERSION_MINOR@#$(CLANG_VERSION_MINOR)#g" \
60a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_VERSION_PATCHLEVEL@#$(CLANG_VERSION_PATCHLEVEL)#g" \
61a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_HAS_VERSION_PATCHLEVEL@#$(CLANG_HAS_VERSION_PATCHLEVEL)#g" \
62a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           $< > $@
63