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 \
9651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines	AttrHasAttributeImpl.inc \
107d2b8c1fcc2b707be78b09930a7767477822462fDouglas Gregor	DiagnosticIndexName.inc DiagnosticGroups.inc AttrList.inc arm_neon.inc \
11a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	Version.inc
12a393e9eedcc28b25f521a4feceb3b56e3d0d360fDouglas Gregor
138ee50eaf015e3857c04d0ed229f8165faee5544dChris LattnerTABLEGEN_INC_FILES_COMMON = 1
14a393e9eedcc28b25f521a4feceb3b56e3d0d360fDouglas Gregor
15afed099bd2e759efd4bb63fdc525d3445f94cc13Daniel Dunbarinclude $(CLANG_LEVEL)/Makefile
168ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner
171144c218f5d74f2270ebcd5ddd82dc472790eaefDaniel DunbarINPUT_TDS = $(wildcard $(PROJ_SRC_DIR)/Diagnostic*.td)
181144c218f5d74f2270ebcd5ddd82dc472790eaefDaniel Dunbar
19c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbar# Compute the Clang version from the LLVM version, unless specified explicitly.
20c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbarifndef CLANG_VERSION
21c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel DunbarCLANG_VERSION := $(subst svn,,$(LLVMVersion))
22461ed44afac0aa56810e9f870d51692ee4ab235bBill WendlingCLANG_VERSION := $(subst rc,,$(CLANG_VERSION))
23c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbarendif
24c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbar
25a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_COMPONENTS := $(subst ., ,$(CLANG_VERSION))
26a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_MAJOR := $(word 1,$(CLANG_VERSION_COMPONENTS))
27a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_MINOR := $(word 2,$(CLANG_VERSION_COMPONENTS))
28a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_VERSION_PATCHLEVEL := $(word 3,$(CLANG_VERSION_COMPONENTS))
29a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbarifeq ($(CLANG_VERSION_PATCHLEVEL),)
30a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_HAS_VERSION_PATCHLEVEL := 0
31a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbarelse
32a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel DunbarCLANG_HAS_VERSION_PATCHLEVEL := 1
33a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbarendif
34a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar
35e052bda1f3f8b857fa02abeef7b97f66308225fdArgyrios Kyrtzidis$(ObjDir)/Diagnostic%Kinds.inc.tmp : Diagnostic.td $(INPUT_TDS) $(CLANG_TBLGEN) $(ObjDir)/.dir
368ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner	$(Echo) "Building Clang $(patsubst Diagnostic%Kinds.inc.tmp,%,$(@F)) diagnostic tables with tblgen"
376ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-diags-defs -clang-component=$(patsubst Diagnostic%Kinds.inc.tmp,%,$(@F)) -o $(call SYSPATH, $@) $<
388ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner
396ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/DiagnosticIndexName.inc.tmp : Diagnostic.td $(INPUT_TDS) $(CLANG_TBLGEN) $(ObjDir)/.dir
407d2b8c1fcc2b707be78b09930a7767477822462fDouglas Gregor	$(Echo) "Building Clang diagnostic name index with tblgen"
416ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-diags-index-name -o $(call SYSPATH, $@) $<
427d2b8c1fcc2b707be78b09930a7767477822462fDouglas Gregor
436ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/DiagnosticGroups.inc.tmp : Diagnostic.td DiagnosticGroups.td $(INPUT_TDS) $(CLANG_TBLGEN) $(ObjDir)/.dir
448469c313879bb3deb4af2d501c73e32add4b8e40Chris Lattner	$(Echo) "Building Clang diagnostic groups with tblgen"
456ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-diag-groups -o $(call SYSPATH, $@) $<
468ee50eaf015e3857c04d0ed229f8165faee5544dChris Lattner
476ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/AttrList.inc.tmp : Attr.td $(CLANG_TBLGEN) $(ObjDir)/.dir
48387475d0c18aaeb022108de9d33b6c9fb7998843Sean Hunt	$(Echo) "Building Clang attribute list with tblgen"
496ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne	$(Verb) $(ClangTableGen) -gen-clang-attr-list -o $(call SYSPATH, $@) \
50387475d0c18aaeb022108de9d33b6c9fb7998843Sean Hunt	  -I $(PROJ_SRC_DIR)/../.. $<
51a23326b5c244a03bf61ebb86db60a777ea26f926Nate Begeman
52651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines$(ObjDir)/AttrHasAttributeImpl.inc.tmp : Attr.td $(CLANG_TBLGEN) \
53651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines                                  $(ObjDir)/.dir
54651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines	$(Echo) "Building Clang __has_attribute implementation with tblgen"
55651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines	$(Verb) $(ClangTableGen) -gen-clang-attr-has-attribute-impl -o $(call SYSPATH, $@) \
56651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines		-I $(PROJ_SRC_DIR)/../../ $<
57651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines
586ee5b9384533d5b3f8c18b578fccd3935e1b892fPeter Collingbourne$(ObjDir)/arm_neon.inc.tmp : arm_neon.td $(CLANG_TBLGEN) $(ObjDir)/.dir
59a23326b5c244a03bf61ebb86db60a777ea26f926Nate Begeman	$(Echo) "Building Clang arm_neon.inc with tblgen"
60651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines	$(Verb) $(ClangTableGen) -gen-arm-neon-sema -o $(call SYSPATH, $@) \
61651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines	  -I $(PROJ_SRC_DIR)/../.. $<
62a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar
63c4b8e923a18ba56ecd76de5dfd7edf7f307123e3Daniel Dunbar$(ObjDir)/Version.inc.tmp : Version.inc.in Makefile $(LLVM_OBJ_ROOT)/Makefile.config $(ObjDir)/.dir
64a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	$(Echo) "Updating Clang version info."
65a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	$(Verb)sed -e "s#@CLANG_VERSION@#$(CLANG_VERSION)#g" \
66a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_VERSION_MAJOR@#$(CLANG_VERSION_MAJOR)#g" \
67a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_VERSION_MINOR@#$(CLANG_VERSION_MINOR)#g" \
68a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_VERSION_PATCHLEVEL@#$(CLANG_VERSION_PATCHLEVEL)#g" \
69a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           -e "s#@CLANG_HAS_VERSION_PATCHLEVEL@#$(CLANG_HAS_VERSION_PATCHLEVEL)#g" \
70a510767963e6bf04f0bc15de057f6bafa0aedab5Daniel Dunbar	           $< > $@
71