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