1##===- Makefile --------------------------------------------*- Makefile -*-===## 2# 3# The LLVM Compiler Infrastructure 4# 5# This file is distributed under the University of Illinois Open Source 6# License. See LICENSE.TXT for details. 7# 8##===----------------------------------------------------------------------===## 9 10# If CLANG_LEVEL is not set, then we are the top-level Makefile. Otherwise, we 11# are being included from a subdirectory makefile. 12 13ifndef CLANG_LEVEL 14 15IS_TOP_LEVEL := 1 16CLANG_LEVEL := . 17DIRS := utils/TableGen include lib tools runtime docs unittests 18 19PARALLEL_DIRS := 20 21ifeq ($(BUILD_EXAMPLES),1) 22 PARALLEL_DIRS += examples 23endif 24endif 25 26ifeq ($(BUILD_EXAMPLES),1) 27 ENABLE_CLANG_EXAMPLES := 1 28else 29 ENABLE_CLANG_EXAMPLES := 0 30endif 31 32ifeq ($(MAKECMDGOALS),libs-only) 33 DIRS := $(filter-out tools docs, $(DIRS)) 34 OPTIONAL_DIRS := 35endif 36ifeq ($(BUILD_CLANG_ONLY),YES) 37 DIRS := $(filter-out docs unittests, $(DIRS)) 38 OPTIONAL_DIRS := 39endif 40 41### 42# Common Makefile code, shared by all Clang Makefiles. 43 44# Set LLVM source root level. 45LEVEL := $(CLANG_LEVEL)/../.. 46 47# Include LLVM common makefile. 48include $(LEVEL)/Makefile.common 49 50ifneq ($(ENABLE_DOCS),1) 51 DIRS := $(filter-out docs, $(DIRS)) 52endif 53 54# Set common Clang build flags. 55CPP.Flags += -I$(PROJ_SRC_DIR)/$(CLANG_LEVEL)/include -I$(PROJ_OBJ_DIR)/$(CLANG_LEVEL)/include 56ifdef CLANG_VENDOR 57CPP.Flags += -DCLANG_VENDOR='"$(CLANG_VENDOR) "' 58endif 59ifdef CLANG_REPOSITORY_STRING 60CPP.Flags += -DCLANG_REPOSITORY_STRING='"$(CLANG_REPOSITORY_STRING)"' 61endif 62 63# Disable -fstrict-aliasing. Darwin disables it by default (and LLVM doesn't 64# work with it enabled with GCC), Clang/llvm-gcc don't support it yet, and newer 65# GCC's have false positive warnings with it on Linux (which prove a pain to 66# fix). For example: 67# http://gcc.gnu.org/PR41874 68# http://gcc.gnu.org/PR41838 69# 70# We don't need to do this if the host compiler is clang. 71ifneq ($(CXX_COMPILER), "clang") 72CXX.Flags += -fno-strict-aliasing 73endif 74 75 76# Set up Clang's tblgen. 77ifndef CLANG_TBLGEN 78 ifeq ($(LLVM_CROSS_COMPILING),1) 79 CLANG_TBLGEN := $(BuildLLVMToolDir)/clang-tblgen$(BUILD_EXEEXT) 80 else 81 CLANG_TBLGEN := $(LLVMToolDir)/clang-tblgen$(EXEEXT) 82 endif 83endif 84ClangTableGen = $(CLANG_TBLGEN) $(TableGen.Flags) 85 86### 87# Clang Top Level specific stuff. 88 89ifeq ($(IS_TOP_LEVEL),1) 90 91ifneq ($(PROJ_SRC_ROOT),$(PROJ_OBJ_ROOT)) 92$(RecursiveTargets):: 93 $(Verb) for dir in test unittests; do \ 94 if [ -f $(PROJ_SRC_DIR)/$${dir}/Makefile ] && [ ! -f $${dir}/Makefile ]; then \ 95 $(MKDIR) $${dir}; \ 96 $(CP) $(PROJ_SRC_DIR)/$${dir}/Makefile $${dir}/Makefile; \ 97 fi \ 98 done 99endif 100 101test:: 102 @ $(MAKE) -C test 103 104report:: 105 @ $(MAKE) -C test report 106 107clean:: 108 @ $(MAKE) -C test clean 109 110libs-only: all 111 112tags:: 113 $(Verb) etags `find . -type f -name '*.h' -or -name '*.cpp' | \ 114 grep -v /lib/Headers | grep -v /test/` 115 116cscope.files: 117 find tools lib include -name '*.cpp' \ 118 -or -name '*.def' \ 119 -or -name '*.td' \ 120 -or -name '*.h' > cscope.files 121 122.PHONY: test report clean cscope.files 123 124endif 125