Home | History | Annotate | Download | only in clang
      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 
     13 ifndef CLANG_LEVEL
     14 
     15 IS_TOP_LEVEL := 1
     16 CLANG_LEVEL := .
     17 DIRS := utils/TableGen include lib tools runtime docs unittests
     18 
     19 PARALLEL_DIRS :=
     20 
     21 ifeq ($(BUILD_EXAMPLES),1)
     22   PARALLEL_DIRS += examples
     23 endif
     24 endif
     25 
     26 ifeq ($(BUILD_EXAMPLES),1)
     27   ENABLE_CLANG_EXAMPLES := 1
     28 else
     29   ENABLE_CLANG_EXAMPLES := 0
     30 endif
     31 
     32 ifeq ($(MAKECMDGOALS),libs-only)
     33   DIRS := $(filter-out tools docs, $(DIRS))
     34   OPTIONAL_DIRS :=
     35 endif
     36 ifeq ($(BUILD_CLANG_ONLY),YES)
     37   DIRS := $(filter-out docs unittests, $(DIRS))
     38   OPTIONAL_DIRS :=
     39 endif
     40 
     41 ###
     42 # Common Makefile code, shared by all Clang Makefiles.
     43 
     44 # Set LLVM source root level.
     45 LEVEL := $(CLANG_LEVEL)/../..
     46 
     47 # Include LLVM common makefile.
     48 include $(LEVEL)/Makefile.common
     49 
     50 ifneq ($(ENABLE_DOCS),1)
     51   DIRS := $(filter-out docs, $(DIRS))
     52 endif
     53 
     54 # Set common Clang build flags.
     55 CPP.Flags += -I$(PROJ_SRC_DIR)/$(CLANG_LEVEL)/include -I$(PROJ_OBJ_DIR)/$(CLANG_LEVEL)/include
     56 ifdef CLANG_VENDOR
     57 CPP.Flags += -DCLANG_VENDOR='"$(CLANG_VENDOR) "'
     58 endif
     59 ifdef CLANG_REPOSITORY_STRING
     60 CPP.Flags += -DCLANG_REPOSITORY_STRING='"$(CLANG_REPOSITORY_STRING)"'
     61 endif
     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 can revisit this when LLVM/Clang support it.
     71 CXX.Flags += -fno-strict-aliasing
     72 
     73 # Set up Clang's tblgen.
     74 ifndef CLANG_TBLGEN
     75   ifeq ($(LLVM_CROSS_COMPILING),1)
     76     CLANG_TBLGEN := $(BuildLLVMToolDir)/clang-tblgen$(BUILD_EXEEXT)
     77   else
     78     CLANG_TBLGEN := $(LLVMToolDir)/clang-tblgen$(EXEEXT)
     79   endif
     80 endif
     81 ClangTableGen = $(CLANG_TBLGEN) $(TableGen.Flags)
     82 
     83 ###
     84 # Clang Top Level specific stuff.
     85 
     86 ifeq ($(IS_TOP_LEVEL),1)
     87 
     88 ifneq ($(PROJ_SRC_ROOT),$(PROJ_OBJ_ROOT))
     89 $(RecursiveTargets)::
     90 	$(Verb) for dir in test unittests; do \
     91 	  if [ -f $(PROJ_SRC_DIR)/$${dir}/Makefile ] && [ ! -f $${dir}/Makefile ]; then \
     92 	    $(MKDIR) $${dir}; \
     93 	    $(CP) $(PROJ_SRC_DIR)/$${dir}/Makefile $${dir}/Makefile; \
     94 	  fi \
     95 	done
     96 endif
     97 
     98 test::
     99 	@ $(MAKE) -C test
    100 
    101 report::
    102 	@ $(MAKE) -C test report
    103 
    104 clean::
    105 	@ $(MAKE) -C test clean
    106 
    107 libs-only: all
    108 
    109 tags::
    110 	$(Verb) etags `find . -type f -name '*.h' -or -name '*.cpp' | \
    111 	  grep -v /lib/Headers | grep -v /test/`
    112 
    113 cscope.files:
    114 	find tools lib include -name '*.cpp' \
    115 	                    -or -name '*.def' \
    116 	                    -or -name '*.td' \
    117 	                    -or -name '*.h' > cscope.files
    118 
    119 .PHONY: test report clean cscope.files
    120 
    121 endif
    122