mirror of https://github.com/grpc/grpc.git
The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
https://grpc.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1619 lines
51 KiB
1619 lines
51 KiB
%YAML 1.2 |
|
--- | |
|
# GRPC global makefile |
|
# This currently builds C and C++ code. |
|
# This file has been automatically generated from a template file. |
|
# Please look at the templates directory instead. |
|
# This file can be regenerated from the template by running |
|
# tools/buildgen/generate_projects.sh |
|
|
|
# Copyright 2015 gRPC authors. |
|
# |
|
# Licensed under the Apache License, Version 2.0 (the "License"); |
|
# you may not use this file except in compliance with the License. |
|
# You may obtain a copy of the License at |
|
# |
|
# http://www.apache.org/licenses/LICENSE-2.0 |
|
# |
|
# Unless required by applicable law or agreed to in writing, software |
|
# distributed under the License is distributed on an "AS IS" BASIS, |
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
# See the License for the specific language governing permissions and |
|
# limitations under the License. |
|
<%! |
|
import re |
|
import os |
|
|
|
def is_absl_lib(target_name): |
|
return target_name.startswith("absl/"); |
|
|
|
proto_re = re.compile('(.*)\\.proto') |
|
|
|
def proto_to_cc(filename): |
|
m = proto_re.match(filename) |
|
if not m: |
|
return filename |
|
return '$(GENDIR)/' + m.group(1) + '.pb.cc $(GENDIR)/' + m.group(1) + '.grpc.pb.cc' |
|
|
|
sources_that_need_openssl = set() |
|
sources_that_don_t_need_openssl = set() |
|
|
|
# warnings we'd like, but that don't exist in all compilers |
|
PREFERRED_WARNINGS=['extra-semi'] |
|
CHECK_WARNINGS=PREFERRED_WARNINGS + ['no-shift-negative-value', 'no-unused-but-set-variable', 'no-maybe-uninitialized', 'no-unknown-warning-option'] |
|
|
|
def warning_var(fmt, warning): |
|
return fmt % warning.replace('-', '_').replace('+', 'X').upper() |
|
|
|
def neg_warning(warning): |
|
if warning[0:3] == 'no-': |
|
return warning[3:] |
|
else: |
|
return 'no-' + warning |
|
|
|
lang_to_var = { |
|
'c': 'CORE', |
|
'c++': 'CPP', |
|
'csharp': 'CSHARP' |
|
} |
|
%> |
|
<% |
|
# Makefile is only intended for internal needs (building distribution artifacts etc.) |
|
# so we can restrict the number of libraries/targets that are buildable using the Makefile. |
|
# Other targets can be built with cmake or bazel. |
|
# TODO(jtattermusch): Figure out how to avoid the need to list the dependencies explicitly. |
|
# Currently it is necessary because some dependencies are marked as "build: private" in build.yaml |
|
# (which itself is correct, as they are not "public" libraries from our perspective and cmake |
|
# needs to have them marked as such) |
|
filtered_libs = [lib for lib in libs if lib.build in ['all', 'protoc'] or lib.name in ['ares', 'boringssl', 're2', 'upb', 'z']] |
|
filtered_targets = [tgt for tgt in targets if tgt.build in ['all', 'protoc']] |
|
%> |
|
|
|
comma := , |
|
|
|
|
|
# Basic platform detection |
|
HOST_SYSTEM = $(shell uname | cut -f 1 -d_) |
|
SYSTEM ?= $(HOST_SYSTEM) |
|
ifeq ($(SYSTEM),MSYS) |
|
SYSTEM = MINGW32 |
|
endif |
|
ifeq ($(SYSTEM),MINGW64) |
|
SYSTEM = MINGW32 |
|
endif |
|
|
|
|
|
MAKEFILE_PATH := $(abspath $(lastword $(MAKEFILE_LIST))) |
|
ifndef BUILDDIR |
|
BUILDDIR_ABSOLUTE = $(patsubst %/,%,$(dir $(MAKEFILE_PATH))) |
|
else |
|
BUILDDIR_ABSOLUTE = $(abspath $(BUILDDIR)) |
|
endif |
|
|
|
HAS_GCC = $(shell which gcc > /dev/null 2> /dev/null && echo true || echo false) |
|
HAS_CC = $(shell which cc > /dev/null 2> /dev/null && echo true || echo false) |
|
HAS_CLANG = $(shell which clang > /dev/null 2> /dev/null && echo true || echo false) |
|
|
|
ifeq ($(HAS_CC),true) |
|
DEFAULT_CC = cc |
|
DEFAULT_CXX = c++ |
|
else |
|
ifeq ($(HAS_GCC),true) |
|
DEFAULT_CC = gcc |
|
DEFAULT_CXX = g++ |
|
else |
|
ifeq ($(HAS_CLANG),true) |
|
DEFAULT_CC = clang |
|
DEFAULT_CXX = clang++ |
|
else |
|
DEFAULT_CC = no_c_compiler |
|
DEFAULT_CXX = no_c++_compiler |
|
endif |
|
endif |
|
endif |
|
|
|
|
|
BINDIR = $(BUILDDIR_ABSOLUTE)/bins |
|
OBJDIR = $(BUILDDIR_ABSOLUTE)/objs |
|
LIBDIR = $(BUILDDIR_ABSOLUTE)/libs |
|
GENDIR = $(BUILDDIR_ABSOLUTE)/gens |
|
|
|
# Configurations |
|
|
|
% for name, args in configs.iteritems(): |
|
VALID_CONFIG_${name} = 1 |
|
% if args.get('compile_the_world', False): |
|
REQUIRE_CUSTOM_LIBRARIES_${name} = 1 |
|
% endif |
|
% for tool, default in [('CC', 'CC'), ('CXX', 'CXX'), ('LD', 'CC'), ('LDXX', 'CXX')]: |
|
${tool}_${name} = ${args.get(tool, '$(DEFAULT_%s)' % default)} |
|
% endfor |
|
% for arg in ['CFLAGS', 'CXXFLAGS', 'CPPFLAGS', 'LDFLAGS', 'DEFINES']: |
|
% if args.get(arg, None) is not None: |
|
${arg}_${name} = ${args.get(arg)} |
|
% endif |
|
% endfor |
|
|
|
% endfor |
|
|
|
|
|
# General settings. |
|
# You may want to change these depending on your system. |
|
|
|
prefix ?= /usr/local |
|
|
|
PROTOC ?= protoc |
|
DTRACE ?= dtrace |
|
CONFIG ?= opt |
|
# Doing X ?= Y is the same as: |
|
# ifeq ($(origin X), undefined) |
|
# X = Y |
|
# endif |
|
# but some variables, such as CC, CXX, LD or AR, have defaults. |
|
# So instead of using ?= on them, we need to check their origin. |
|
# See: |
|
# https://www.gnu.org/software/make/manual/html_node/Implicit-Variables.html |
|
# https://www.gnu.org/software/make/manual/html_node/Flavors.html#index-_003f_003d |
|
# https://www.gnu.org/software/make/manual/html_node/Origin-Function.html |
|
ifeq ($(origin CC), default) |
|
CC = $(CC_$(CONFIG)) |
|
endif |
|
ifeq ($(origin CXX), default) |
|
CXX = $(CXX_$(CONFIG)) |
|
endif |
|
ifeq ($(origin LD), default) |
|
LD = $(LD_$(CONFIG)) |
|
endif |
|
LDXX ?= $(LDXX_$(CONFIG)) |
|
ARFLAGS ?= rcs |
|
ifeq ($(SYSTEM),Linux) |
|
ifeq ($(origin AR), default) |
|
AR = ar |
|
endif |
|
STRIP ?= strip --strip-unneeded |
|
else |
|
ifeq ($(SYSTEM),Darwin) |
|
ifeq ($(origin AR), default) |
|
AR = libtool |
|
ARFLAGS = -no_warning_for_no_symbols -o |
|
endif |
|
STRIP ?= strip -x |
|
else |
|
ifeq ($(SYSTEM),MINGW32) |
|
ifeq ($(origin AR), default) |
|
AR = ar |
|
endif |
|
STRIP ?= strip --strip-unneeded |
|
else |
|
ifeq ($(origin AR), default) |
|
AR = ar |
|
endif |
|
STRIP ?= strip |
|
endif |
|
endif |
|
endif |
|
INSTALL ?= install |
|
RM ?= rm -f |
|
PKG_CONFIG ?= pkg-config |
|
|
|
ifndef VALID_CONFIG_$(CONFIG) |
|
$(error Invalid CONFIG value '$(CONFIG)') |
|
endif |
|
|
|
ifeq ($(SYSTEM),Linux) |
|
TMPOUT = /dev/null |
|
else |
|
TMPOUT = `mktemp /tmp/test-out-XXXXXX` |
|
endif |
|
|
|
CHECK_NO_CXX14_COMPAT_WORKS_CMD = $(CC) -std=c++11 -Werror -Wno-c++14-compat -o $(TMPOUT) -c test/build/no-c++14-compat.cc |
|
HAS_WORKING_NO_CXX14_COMPAT = $(shell $(CHECK_NO_CXX14_COMPAT_WORKS_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_WORKING_NO_CXX14_COMPAT),true) |
|
W_NO_CXX14_COMPAT=-Wno-c++14-compat |
|
endif |
|
|
|
%for warning in CHECK_WARNINGS: |
|
${warning_var('CHECK_%s_WORKS_CMD', warning)} = $(CC) -std=c99 -Werror -W${warning} -o $(TMPOUT) -c test/build/${warning}.c |
|
${warning_var('HAS_WORKING_%s', warning)} = $(shell $(${warning_var('CHECK_%s_WORKS_CMD', warning)}) 2> /dev/null && echo true || echo false) |
|
ifeq ($(${warning_var('HAS_WORKING_%s', warning)}),true) |
|
${warning_var('W_%s', warning)}=-W${warning} |
|
${warning_var('NO_W_%s', warning)}=-W${neg_warning(warning)} |
|
endif |
|
%endfor |
|
|
|
# The HOST compiler settings are used to compile the protoc plugins. |
|
# In most cases, you won't have to change anything, but if you are |
|
# cross-compiling, you can override these variables from GNU make's |
|
# command line: make CC=cross-gcc HOST_CC=gcc |
|
|
|
HOST_CC ?= $(CC) |
|
HOST_CXX ?= $(CXX) |
|
HOST_LD ?= $(LD) |
|
HOST_LDXX ?= $(LDXX) |
|
|
|
CFLAGS += -std=c99 ${' '.join(warning_var('$(W_%s)', warning) for warning in PREFERRED_WARNINGS)} |
|
CXXFLAGS += -std=c++11 |
|
ifeq ($(SYSTEM),Darwin) |
|
CXXFLAGS += -stdlib=libc++ |
|
LDFLAGS += -framework CoreFoundation |
|
endif |
|
% for arg in ['CFLAGS', 'CXXFLAGS', 'CPPFLAGS', 'COREFLAGS', 'LDFLAGS', 'DEFINES']: |
|
% if defaults.get('global', []).get(arg, None) is not None: |
|
${arg} += ${defaults.get('global').get(arg)} |
|
% endif |
|
% endfor |
|
|
|
CPPFLAGS += $(CPPFLAGS_$(CONFIG)) |
|
CFLAGS += $(CFLAGS_$(CONFIG)) |
|
CXXFLAGS += $(CXXFLAGS_$(CONFIG)) |
|
DEFINES += $(DEFINES_$(CONFIG)) INSTALL_PREFIX=\"$(prefix)\" |
|
LDFLAGS += $(LDFLAGS_$(CONFIG)) |
|
|
|
ifneq ($(SYSTEM),MINGW32) |
|
PIC_CPPFLAGS = -fPIC |
|
CPPFLAGS += -fPIC |
|
LDFLAGS += -fPIC |
|
endif |
|
|
|
INCLUDES = . include $(GENDIR) |
|
LDFLAGS += -Llibs/$(CONFIG) |
|
|
|
ifeq ($(SYSTEM),Darwin) |
|
ifneq ($(wildcard /usr/local/ssl/include),) |
|
INCLUDES += /usr/local/ssl/include |
|
endif |
|
ifneq ($(wildcard /opt/local/include),) |
|
INCLUDES += /opt/local/include |
|
endif |
|
ifneq ($(wildcard /usr/local/include),) |
|
INCLUDES += /usr/local/include |
|
endif |
|
LIBS = m z |
|
ifneq ($(wildcard /usr/local/ssl/lib),) |
|
LDFLAGS += -L/usr/local/ssl/lib |
|
endif |
|
ifneq ($(wildcard /opt/local/lib),) |
|
LDFLAGS += -L/opt/local/lib |
|
endif |
|
ifneq ($(wildcard /usr/local/lib),) |
|
LDFLAGS += -L/usr/local/lib |
|
endif |
|
endif |
|
|
|
ifeq ($(SYSTEM),Linux) |
|
LIBS = dl rt m pthread |
|
LDFLAGS += -pthread |
|
endif |
|
|
|
ifeq ($(SYSTEM),MINGW32) |
|
LIBS = m pthread ws2_32 dbghelp |
|
LDFLAGS += -pthread |
|
endif |
|
|
|
# |
|
# The steps for cross-compiling are as follows: |
|
# First, clone and make install of grpc using the native compilers for the host. |
|
# Also, install protoc (e.g., from a package like apt-get) |
|
# Then clone a fresh grpc for the actual cross-compiled build |
|
# Set the environment variable GRPC_CROSS_COMPILE to true |
|
# Set CC, CXX, LD, LDXX, AR, and STRIP to the cross-compiling binaries |
|
# Also set PROTOBUF_CONFIG_OPTS to indicate cross-compilation to protobuf (e.g., |
|
# PROTOBUF_CONFIG_OPTS="--host=arm-linux --with-protoc=/usr/local/bin/protoc" ) |
|
# Set HAS_PKG_CONFIG=false |
|
# To build tests, go to third_party/gflags and follow its ccmake instructions |
|
# Make sure that you enable building shared libraries and set your prefix to |
|
# something useful like /usr/local/cross |
|
# You will also need to set GRPC_CROSS_LDOPTS and GRPC_CROSS_AROPTS to hold |
|
# additional required arguments for LD and AR (examples below) |
|
# Then you can do a make from the cross-compiling fresh clone! |
|
# |
|
ifeq ($(GRPC_CROSS_COMPILE),true) |
|
LDFLAGS += $(GRPC_CROSS_LDOPTS) # e.g. -L/usr/local/lib -L/usr/local/cross/lib |
|
ARFLAGS += $(GRPC_CROSS_AROPTS) # e.g., rc --target=elf32-little |
|
USE_BUILT_PROTOC = false |
|
endif |
|
|
|
GTEST_LIB = -Ithird_party/googletest/googletest/include -Ithird_party/googletest/googletest third_party/googletest/googletest/src/gtest-all.cc -Ithird_party/googletest/googlemock/include -Ithird_party/googletest/googlemock third_party/googletest/googlemock/src/gmock-all.cc |
|
GTEST_LIB += -lgflags -std=c++11 |
|
ifeq ($(V),1) |
|
E = @: |
|
Q = |
|
else |
|
E = @echo |
|
Q = @ |
|
endif |
|
|
|
CORE_VERSION = ${settings.core_version} |
|
CPP_VERSION = ${settings.cpp_version} |
|
CSHARP_VERSION = ${settings.csharp_version} |
|
|
|
CPPFLAGS_NO_ARCH += $(addprefix -I, $(INCLUDES)) $(addprefix -D, $(DEFINES)) |
|
CPPFLAGS += $(CPPFLAGS_NO_ARCH) $(ARCH_FLAGS) |
|
|
|
LDFLAGS += $(ARCH_FLAGS) |
|
LDLIBS += $(addprefix -l, $(LIBS)) |
|
LDLIBSXX += $(addprefix -l, $(LIBSXX)) |
|
|
|
|
|
% for arg in ['CFLAGS', 'CXXFLAGS', 'CPPFLAGS', 'LDFLAGS', 'DEFINES', 'LDLIBS']: |
|
${arg} += $(EXTRA_${arg}) |
|
% endfor |
|
|
|
HOST_CPPFLAGS += $(CPPFLAGS) |
|
HOST_CFLAGS += $(CFLAGS) |
|
HOST_CXXFLAGS += $(CXXFLAGS) |
|
HOST_LDFLAGS += $(LDFLAGS) |
|
HOST_LDLIBS += $(LDLIBS) |
|
|
|
# These are automatically computed variables. |
|
# There shouldn't be any need to change anything from now on. |
|
|
|
-include cache.mk |
|
|
|
CACHE_MK = |
|
|
|
HAS_PKG_CONFIG ?= $(shell command -v $(PKG_CONFIG) >/dev/null 2>&1 && echo true || echo false) |
|
|
|
ifeq ($(HAS_PKG_CONFIG), true) |
|
CACHE_MK += HAS_PKG_CONFIG = true, |
|
endif |
|
|
|
ifeq ($(SYSTEM),MINGW32) |
|
EXECUTABLE_SUFFIX = .exe |
|
SHARED_EXT_CORE = dll |
|
SHARED_EXT_CPP = dll |
|
SHARED_EXT_CSHARP = dll |
|
SHARED_PREFIX = |
|
SHARED_VERSION_CORE = -${settings.core_version.major} |
|
SHARED_VERSION_CPP = -${settings.cpp_version.major} |
|
SHARED_VERSION_CSHARP = -${settings.csharp_version.major} |
|
else ifeq ($(SYSTEM),Darwin) |
|
EXECUTABLE_SUFFIX = |
|
SHARED_EXT_CORE = dylib |
|
SHARED_EXT_CPP = dylib |
|
SHARED_EXT_CSHARP = dylib |
|
SHARED_PREFIX = lib |
|
SHARED_VERSION_CORE = |
|
SHARED_VERSION_CPP = |
|
SHARED_VERSION_CSHARP = |
|
else |
|
EXECUTABLE_SUFFIX = |
|
SHARED_EXT_CORE = so.$(CORE_VERSION) |
|
SHARED_EXT_CPP = so.$(CPP_VERSION) |
|
SHARED_EXT_CSHARP = so.$(CSHARP_VERSION) |
|
SHARED_PREFIX = lib |
|
SHARED_VERSION_CORE = |
|
SHARED_VERSION_CPP = |
|
SHARED_VERSION_CSHARP = |
|
endif |
|
|
|
ifeq ($(wildcard .git),) |
|
IS_GIT_FOLDER = false |
|
else |
|
IS_GIT_FOLDER = true |
|
endif |
|
|
|
ifeq ($(HAS_PKG_CONFIG),true) |
|
OPENSSL_ALPN_CHECK_CMD = $(PKG_CONFIG) --atleast-version=1.0.2 openssl |
|
ZLIB_CHECK_CMD = $(PKG_CONFIG) --exists zlib |
|
PROTOBUF_CHECK_CMD = $(PKG_CONFIG) --atleast-version=3.12.0 protobuf |
|
CARES_CHECK_CMD = $(PKG_CONFIG) --atleast-version=1.11.0 libcares |
|
else # HAS_PKG_CONFIG |
|
|
|
ifeq ($(SYSTEM),MINGW32) |
|
OPENSSL_LIBS = ssl32 eay32 |
|
else |
|
OPENSSL_LIBS = ssl crypto |
|
endif |
|
|
|
OPENSSL_ALPN_CHECK_CMD = $(CC) $(CPPFLAGS) $(CFLAGS) -o $(TMPOUT) test/build/openssl-alpn.c $(addprefix -l, $(OPENSSL_LIBS)) $(LDFLAGS) |
|
BORINGSSL_COMPILE_CHECK_CMD = $(CC) $(CPPFLAGS) ${defaults.boringssl.CPPFLAGS} $(CFLAGS) ${defaults.boringssl.CFLAGS} -o $(TMPOUT) test/build/boringssl.c $(LDFLAGS) |
|
ZLIB_CHECK_CMD = $(CC) $(CPPFLAGS) $(CFLAGS) -o $(TMPOUT) test/build/zlib.c -lz $(LDFLAGS) |
|
PROTOBUF_CHECK_CMD = $(CXX) $(CPPFLAGS) $(CXXFLAGS) -o $(TMPOUT) test/build/protobuf.cc -lprotobuf $(LDFLAGS) |
|
CARES_CHECK_CMD = $(CXX) $(CPPFLAGS) $(CXXFLAGS) -o $(TMPOUT) test/build/c-ares.c -lcares $(LDFLAGS) |
|
|
|
endif # HAS_PKG_CONFIG |
|
|
|
PERFTOOLS_CHECK_CMD = $(CC) $(CPPFLAGS) $(CFLAGS) -o $(TMPOUT) test/build/perftools.c -lprofiler $(LDFLAGS) |
|
|
|
PROTOC_CHECK_CMD = which protoc > /dev/null |
|
PROTOC_CHECK_VERSION_CMD = protoc --version | grep -q libprotoc.3 |
|
DTRACE_CHECK_CMD = which dtrace > /dev/null |
|
SYSTEMTAP_HEADERS_CHECK_CMD = $(CC) $(CPPFLAGS) $(CFLAGS) -o $(TMPOUT) test/build/systemtap.c $(LDFLAGS) |
|
|
|
ifndef REQUIRE_CUSTOM_LIBRARIES_$(CONFIG) |
|
HAS_SYSTEM_PERFTOOLS ?= $(shell $(PERFTOOLS_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_SYSTEM_PERFTOOLS),true) |
|
DEFINES += GRPC_HAVE_PERFTOOLS |
|
LIBS += profiler |
|
CACHE_MK += HAS_SYSTEM_PERFTOOLS = true, |
|
endif |
|
endif |
|
|
|
HAS_SYSTEM_PROTOBUF_VERIFY = $(shell $(PROTOBUF_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
ifndef REQUIRE_CUSTOM_LIBRARIES_$(CONFIG) |
|
HAS_SYSTEM_OPENSSL_ALPN ?= $(shell $(OPENSSL_ALPN_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_SYSTEM_OPENSSL_ALPN),true) |
|
CACHE_MK += HAS_SYSTEM_OPENSSL_ALPN = true, |
|
endif |
|
HAS_SYSTEM_ZLIB ?= $(shell $(ZLIB_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_SYSTEM_ZLIB),true) |
|
CACHE_MK += HAS_SYSTEM_ZLIB = true, |
|
endif |
|
HAS_SYSTEM_PROTOBUF ?= $(HAS_SYSTEM_PROTOBUF_VERIFY) |
|
ifeq ($(HAS_SYSTEM_PROTOBUF),true) |
|
CACHE_MK += HAS_SYSTEM_PROTOBUF = true, |
|
endif |
|
HAS_SYSTEM_CARES ?= $(shell $(CARES_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_SYSTEM_CARES),true) |
|
CACHE_MK += HAS_SYSTEM_CARES = true, |
|
endif |
|
else |
|
# override system libraries if the config requires a custom compiled library |
|
HAS_SYSTEM_OPENSSL_ALPN = false |
|
HAS_SYSTEM_ZLIB = false |
|
HAS_SYSTEM_PROTOBUF = false |
|
HAS_SYSTEM_CARES = false |
|
endif |
|
|
|
HAS_PROTOC ?= $(shell $(PROTOC_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_PROTOC),true) |
|
CACHE_MK += HAS_PROTOC = true, |
|
HAS_VALID_PROTOC ?= $(shell $(PROTOC_CHECK_VERSION_CMD) 2> /dev/null && echo true || echo false) |
|
ifeq ($(HAS_VALID_PROTOC),true) |
|
CACHE_MK += HAS_VALID_PROTOC = true, |
|
endif |
|
else |
|
HAS_VALID_PROTOC = false |
|
endif |
|
|
|
# Check for Systemtap (https://sourceware.org/systemtap/), first by making sure <sys/sdt.h> is present |
|
# in the system and secondly by checking for the "dtrace" binary (on Linux, this is part of the Systemtap |
|
# distribution. It's part of the base system on BSD/Solaris machines). |
|
ifndef HAS_SYSTEMTAP |
|
HAS_SYSTEMTAP_HEADERS = $(shell $(SYSTEMTAP_HEADERS_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
HAS_DTRACE = $(shell $(DTRACE_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
HAS_SYSTEMTAP = false |
|
ifeq ($(HAS_SYSTEMTAP_HEADERS),true) |
|
ifeq ($(HAS_DTRACE),true) |
|
HAS_SYSTEMTAP = true |
|
endif |
|
endif |
|
endif |
|
|
|
ifeq ($(HAS_SYSTEMTAP),true) |
|
CACHE_MK += HAS_SYSTEMTAP = true, |
|
endif |
|
|
|
# Note that for testing purposes, one can do: |
|
# make HAS_EMBEDDED_OPENSSL_ALPN=false |
|
# to emulate the fact we do not have OpenSSL in the third_party folder. |
|
ifeq ($(wildcard third_party/boringssl-with-bazel/src/include/openssl/ssl.h),) |
|
HAS_EMBEDDED_OPENSSL_ALPN = false |
|
else |
|
CAN_COMPILE_EMBEDDED_OPENSSL ?= $(shell $(BORINGSSL_COMPILE_CHECK_CMD) 2> /dev/null && echo true || echo false) |
|
HAS_EMBEDDED_OPENSSL_ALPN = $(CAN_COMPILE_EMBEDDED_OPENSSL) |
|
endif |
|
|
|
ifeq ($(wildcard third_party/zlib/zlib.h),) |
|
HAS_EMBEDDED_ZLIB = false |
|
else |
|
HAS_EMBEDDED_ZLIB = true |
|
endif |
|
|
|
ifeq ($(wildcard third_party/protobuf/src/google/protobuf/descriptor.pb.h),) |
|
HAS_EMBEDDED_PROTOBUF = false |
|
ifneq ($(HAS_VALID_PROTOC),true) |
|
NO_PROTOC = true |
|
endif |
|
else |
|
HAS_EMBEDDED_PROTOBUF = true |
|
endif |
|
|
|
ifeq ($(wildcard third_party/cares/cares/ares.h),) |
|
HAS_EMBEDDED_CARES = false |
|
else |
|
HAS_EMBEDDED_CARES = true |
|
endif |
|
|
|
PC_REQUIRES_GRPC = |
|
PC_LIBS_GRPC = |
|
|
|
ifeq ($(HAS_SYSTEM_ZLIB),false) |
|
ifeq ($(HAS_EMBEDDED_ZLIB), true) |
|
EMBED_ZLIB ?= true |
|
else |
|
DEP_MISSING += zlib |
|
EMBED_ZLIB ?= broken |
|
endif |
|
else |
|
EMBED_ZLIB ?= false |
|
endif |
|
|
|
ifeq ($(EMBED_ZLIB),true) |
|
ZLIB_DEP = $(LIBDIR)/$(CONFIG)/libz.a |
|
ZLIB_MERGE_LIBS = $(LIBDIR)/$(CONFIG)/libz.a |
|
ZLIB_MERGE_OBJS = $(LIBZ_OBJS) |
|
CPPFLAGS += -Ithird_party/zlib |
|
else |
|
ifeq ($(HAS_PKG_CONFIG),true) |
|
CPPFLAGS += $(shell $(PKG_CONFIG) --cflags zlib) |
|
LDFLAGS += $(shell $(PKG_CONFIG) --libs-only-L zlib) |
|
LIBS += $(patsubst -l%,%,$(shell $(PKG_CONFIG) --libs-only-l zlib)) |
|
PC_REQUIRES_GRPC += zlib |
|
else |
|
PC_LIBS_GRPC += -lz |
|
LIBS += z |
|
endif |
|
endif |
|
|
|
CARES_PKG_CONFIG = false |
|
|
|
ifeq ($(HAS_SYSTEM_CARES),false) |
|
ifeq ($(HAS_EMBEDDED_CARES), true) |
|
EMBED_CARES ?= true |
|
else |
|
DEP_MISSING += cares |
|
EMBED_CARES ?= broken |
|
endif |
|
else |
|
EMBED_CARES ?= false |
|
endif |
|
|
|
ADDRESS_SORTING_DEP = $(LIBDIR)/$(CONFIG)/libaddress_sorting.a |
|
ADDRESS_SORTING_MERGE_OBJS = $(LIBADDRESS_SORTING_OBJS) |
|
ADDRESS_SORTING_MERGE_LIBS = $(LIBDIR)/$(CONFIG)/libaddress_sorting.a |
|
CPPFLAGS := -Ithird_party/address_sorting/include $(CPPFLAGS) |
|
|
|
GRPC_ABSEIL_DEP = $(LIBDIR)/$(CONFIG)/libgrpc_abseil.a |
|
GRPC_ABSEIL_MERGE_LIBS = $(LIBDIR)/$(CONFIG)/libgrpc_abseil.a |
|
|
|
RE2_DEP = $(LIBDIR)/$(CONFIG)/libre2.a |
|
RE2_MERGE_OBJS = $(LIBRE2_OBJS) |
|
RE2_MERGE_LIBS = $(LIBDIR)/$(CONFIG)/libre2.a |
|
|
|
UPB_DEP = $(LIBDIR)/$(CONFIG)/libupb.a |
|
UPB_MERGE_OBJS = $(LIBUPB_OBJS) |
|
UPB_MERGE_LIBS = $(LIBDIR)/$(CONFIG)/libupb.a |
|
|
|
ifeq ($(EMBED_CARES),true) |
|
CARES_DEP = $(LIBDIR)/$(CONFIG)/libares.a |
|
CARES_MERGE_OBJS = $(LIBARES_OBJS) |
|
CARES_MERGE_LIBS = $(LIBDIR)/$(CONFIG)/libares.a |
|
CPPFLAGS := -Ithird_party/cares -Ithird_party/cares/cares $(CPPFLAGS) |
|
else |
|
ifeq ($(HAS_PKG_CONFIG),true) |
|
PC_REQUIRES_GRPC += libcares |
|
CPPFLAGS += $(shell $(PKG_CONFIG) --cflags libcares) |
|
LDFLAGS += $(shell $(PKG_CONFIG) --libs-only-L libcares) |
|
LIBS += $(patsubst -l%,%,$(shell $(PKG_CONFIG) --libs-only-l libcares)) |
|
else |
|
PC_LIBS_GRPC += -lcares |
|
LIBS += cares |
|
endif |
|
endif |
|
|
|
OPENSSL_PKG_CONFIG = false |
|
|
|
PC_REQUIRES_SECURE = |
|
PC_LIBS_SECURE = |
|
|
|
ifeq ($(HAS_SYSTEM_OPENSSL_ALPN),true) |
|
EMBED_OPENSSL ?= false |
|
NO_SECURE ?= false |
|
else # HAS_SYSTEM_OPENSSL_ALPN=false |
|
ifneq ($(HAS_EMBEDDED_OPENSSL_ALPN),false) |
|
EMBED_OPENSSL ?= $(HAS_EMBEDDED_OPENSSL_ALPN) |
|
NO_SECURE ?= false |
|
else # HAS_EMBEDDED_OPENSSL_ALPN=false |
|
NO_SECURE ?= true |
|
endif # HAS_EMBEDDED_OPENSSL_ALPN |
|
endif # HAS_SYSTEM_OPENSSL_ALPN |
|
|
|
OPENSSL_DEP := |
|
OPENSSL_MERGE_LIBS := |
|
ifeq ($(NO_SECURE),false) |
|
ifeq ($(EMBED_OPENSSL),true) |
|
OPENSSL_DEP += $(LIBDIR)/$(CONFIG)/libboringssl.a |
|
OPENSSL_MERGE_LIBS += $(LIBDIR)/$(CONFIG)/libboringssl.a |
|
OPENSSL_MERGE_OBJS += $(LIBBORINGSSL_OBJS) |
|
# need to prefix these to ensure overriding system libraries |
|
CPPFLAGS := -Ithird_party/boringssl-with-bazel/src/include $(CPPFLAGS) |
|
else ifneq ($(EMBED_OPENSSL),false) |
|
OPENSSL_DEP += $(EMBED_OPENSSL)/libssl.a $(EMBED_OPENSSL)/libcrypto.a |
|
OPENSSL_MERGE_LIBS += $(EMBED_OPENSSL)/libssl.a $(EMBED_OPENSSL)/libcrypto.a |
|
OPENSSL_MERGE_OBJS += $(wildcard $(EMBED_OPENSSL)/grpc_obj/*.o) |
|
# need to prefix these to ensure overriding system libraries |
|
CPPFLAGS := -I$(EMBED_OPENSSL)/include $(CPPFLAGS) |
|
else # EMBED_OPENSSL=false |
|
ifeq ($(HAS_PKG_CONFIG),true) |
|
OPENSSL_PKG_CONFIG = true |
|
PC_REQUIRES_SECURE = openssl |
|
CPPFLAGS := $(shell $(PKG_CONFIG) --cflags openssl) $(CPPFLAGS) |
|
LDFLAGS_OPENSSL_PKG_CONFIG = $(shell $(PKG_CONFIG) --libs-only-L openssl) |
|
ifeq ($(SYSTEM),Linux) |
|
ifneq ($(LDFLAGS_OPENSSL_PKG_CONFIG),) |
|
LDFLAGS_OPENSSL_PKG_CONFIG += $(shell $(PKG_CONFIG) --libs-only-L openssl | sed s/L/Wl,-rpath,/) |
|
endif # LDFLAGS_OPENSSL_PKG_CONFIG='' |
|
endif # System=Linux |
|
LDFLAGS := $(LDFLAGS_OPENSSL_PKG_CONFIG) $(LDFLAGS) |
|
else # HAS_PKG_CONFIG=false |
|
LIBS_SECURE = $(OPENSSL_LIBS) |
|
endif # HAS_PKG_CONFIG |
|
ifeq ($(DISABLE_ALPN),true) |
|
CPPFLAGS += -DTSI_OPENSSL_ALPN_SUPPORT=0 |
|
LIBS_SECURE = $(OPENSSL_LIBS) |
|
endif # DISABLE_ALPN |
|
PC_LIBS_SECURE = $(addprefix -l, $(LIBS_SECURE)) |
|
endif # EMBED_OPENSSL |
|
endif # NO_SECURE |
|
|
|
ifeq ($(OPENSSL_PKG_CONFIG),true) |
|
LDLIBS_SECURE += $(shell $(PKG_CONFIG) --libs-only-l openssl) |
|
else |
|
LDLIBS_SECURE += $(addprefix -l, $(LIBS_SECURE)) |
|
endif |
|
|
|
PROTOBUF_PKG_CONFIG = false |
|
|
|
PC_REQUIRES_GRPCXX = |
|
PC_LIBS_GRPCXX = |
|
|
|
CPPFLAGS := -Ithird_party/googletest/googletest/include -Ithird_party/googletest/googlemock/include $(CPPFLAGS) |
|
|
|
PROTOC_PLUGINS_ALL =\ |
|
% for tgt in filtered_targets: |
|
% if tgt.build == 'protoc': |
|
$(BINDIR)/$(CONFIG)/${tgt.name}\ |
|
% endif |
|
% endfor |
|
|
|
PROTOC_PLUGINS_DIR = $(BINDIR)/$(CONFIG) |
|
|
|
ifeq ($(HAS_SYSTEM_PROTOBUF),true) |
|
ifeq ($(HAS_PKG_CONFIG),true) |
|
PROTOBUF_PKG_CONFIG = true |
|
PC_REQUIRES_GRPCXX = protobuf |
|
CPPFLAGS := $(CPPFLAGS) $(shell $(PKG_CONFIG) --cflags protobuf) |
|
LDFLAGS_PROTOBUF_PKG_CONFIG = $(shell $(PKG_CONFIG) --libs-only-L protobuf) |
|
ifeq ($(SYSTEM),Linux) |
|
ifneq ($(LDFLAGS_PROTOBUF_PKG_CONFIG),) |
|
LDFLAGS_PROTOBUF_PKG_CONFIG += $(shell $(PKG_CONFIG) --libs-only-L protobuf | sed s/L/Wl,-rpath,/) |
|
endif |
|
endif |
|
else |
|
PC_LIBS_GRPCXX = -lprotobuf |
|
endif |
|
PROTOC_PLUGINS = $(PROTOC_PLUGINS_ALL) |
|
else |
|
ifeq ($(HAS_EMBEDDED_PROTOBUF),true) |
|
PROTOBUF_DEP = $(LIBDIR)/$(CONFIG)/protobuf/libprotobuf.a |
|
CPPFLAGS := -Ithird_party/protobuf/src $(CPPFLAGS) |
|
LDFLAGS := -L$(LIBDIR)/$(CONFIG)/protobuf $(LDFLAGS) |
|
ifneq ($(USE_BUILT_PROTOC),false) |
|
PROTOC = $(BINDIR)/$(CONFIG)/protobuf/protoc |
|
PROTOC_PLUGINS = $(PROTOC_PLUGINS_ALL) |
|
else |
|
PROTOC_PLUGINS = |
|
PROTOC_PLUGINS_DIR = $(prefix)/bin |
|
endif |
|
else |
|
NO_PROTOBUF = true |
|
endif |
|
endif |
|
|
|
LIBS_PROTOBUF = protobuf |
|
LIBS_PROTOC = protoc protobuf |
|
|
|
HOST_LDLIBS_PROTOC += $(addprefix -l, $(LIBS_PROTOC)) |
|
|
|
ifeq ($(PROTOBUF_PKG_CONFIG),true) |
|
LDLIBS_PROTOBUF += $(shell $(PKG_CONFIG) --libs-only-l protobuf) |
|
else |
|
LDLIBS_PROTOBUF += $(addprefix -l, $(LIBS_PROTOBUF)) |
|
endif |
|
|
|
ifeq ($(MAKECMDGOALS),clean) |
|
NO_DEPS = true |
|
endif |
|
|
|
.SECONDARY = %.pb.h %.pb.cc |
|
|
|
ifeq ($(DEP_MISSING),) |
|
all: static shared plugins\ |
|
% for tgt in filtered_targets: |
|
% if tgt.build == 'all': |
|
$(BINDIR)/$(CONFIG)/${tgt.name}\ |
|
% endif |
|
% endfor |
|
|
|
dep_error: |
|
@echo "You shouldn't see this message - all of your dependencies are correct." |
|
else |
|
all: dep_error git_update stop |
|
|
|
dep_error: |
|
@echo |
|
@echo "DEPENDENCY ERROR" |
|
@echo |
|
@echo "You are missing system dependencies that are essential to build grpc," |
|
@echo "and the third_party directory doesn't have them:" |
|
@echo |
|
@echo " $(DEP_MISSING)" |
|
@echo |
|
@echo "Installing the development packages for your system will solve" |
|
@echo "this issue. Please consult INSTALL to get more information." |
|
@echo |
|
@echo "If you need information about why these tests failed, run:" |
|
@echo |
|
@echo " make run_dep_checks" |
|
@echo |
|
endif |
|
|
|
git_update: |
|
ifeq ($(IS_GIT_FOLDER),true) |
|
@echo "Additionally, since you are in a git clone, you can download the" |
|
@echo "missing dependencies in third_party by running the following command:" |
|
@echo |
|
@echo " git submodule update --init" |
|
@echo |
|
endif |
|
|
|
openssl_dep_error: openssl_dep_message git_update stop |
|
|
|
protobuf_dep_error: protobuf_dep_message git_update stop |
|
|
|
protoc_dep_error: protoc_dep_message git_update stop |
|
|
|
openssl_dep_message: |
|
@echo |
|
@echo "DEPENDENCY ERROR" |
|
@echo |
|
@echo "The target you are trying to run requires an OpenSSL implementation." |
|
@echo "Your system doesn't have one, and either the third_party directory" |
|
@echo "doesn't have it, or your compiler can't build BoringSSL." |
|
@echo |
|
@echo "Please consult BUILDING.md to get more information." |
|
@echo |
|
@echo "If you need information about why these tests failed, run:" |
|
@echo |
|
@echo " make run_dep_checks" |
|
@echo |
|
|
|
protobuf_dep_message: |
|
@echo |
|
@echo "DEPENDENCY ERROR" |
|
@echo |
|
@echo "The target you are trying to run requires protobuf 3.12.0+" |
|
@echo "Your system doesn't have it, and neither does the third_party directory." |
|
@echo |
|
@echo "Please consult BUILDING.md to get more information." |
|
@echo |
|
@echo "If you need information about why these tests failed, run:" |
|
@echo |
|
@echo " make run_dep_checks" |
|
@echo |
|
|
|
protoc_dep_message: |
|
@echo |
|
@echo "DEPENDENCY ERROR" |
|
@echo |
|
@echo "The target you are trying to run requires protobuf-compiler 3.12.0+" |
|
@echo "Your system doesn't have it, and neither does the third_party directory." |
|
@echo |
|
@echo "Please consult BUILDING.md to get more information." |
|
@echo |
|
@echo "If you need information about why these tests failed, run:" |
|
@echo |
|
@echo " make run_dep_checks" |
|
@echo |
|
|
|
systemtap_dep_error: |
|
@echo |
|
@echo "DEPENDENCY ERROR" |
|
@echo |
|
@echo "Under the '$(CONFIG)' configutation, the target you are trying " |
|
@echo "to build requires systemtap 2.7+ (on Linux) or dtrace (on other " |
|
@echo "platforms such as Solaris and *BSD). " |
|
@echo |
|
@echo "Please consult BUILDING.md to get more information." |
|
@echo |
|
|
|
install_not_supported_message: |
|
@echo |
|
@echo "Installing via 'make' is no longer supported. Use cmake or bazel instead." |
|
@echo |
|
@echo "Please consult BUILDING.md to get more information." |
|
@echo |
|
|
|
install_not_supported_error: install_not_supported_message stop |
|
|
|
stop: |
|
@false |
|
|
|
% for tgt in filtered_targets: |
|
${tgt.name}: $(BINDIR)/$(CONFIG)/${tgt.name} |
|
% endfor |
|
|
|
run_dep_checks: |
|
$(OPENSSL_ALPN_CHECK_CMD) || true |
|
$(ZLIB_CHECK_CMD) || true |
|
$(PERFTOOLS_CHECK_CMD) || true |
|
$(PROTOBUF_CHECK_CMD) || true |
|
$(PROTOC_CHECK_VERSION_CMD) || true |
|
$(CARES_CHECK_CMD) || true |
|
|
|
third_party/protobuf/configure: |
|
$(E) "[AUTOGEN] Preparing protobuf" |
|
$(Q)(cd third_party/protobuf ; autoreconf -f -i -Wall,no-obsolete) |
|
|
|
$(LIBDIR)/$(CONFIG)/protobuf/libprotobuf.a: third_party/protobuf/configure |
|
$(E) "[MAKE] Building protobuf" |
|
$(Q)mkdir -p $(LIBDIR)/$(CONFIG)/protobuf |
|
$(Q)(cd third_party/protobuf ; CC="$(CC)" CXX="$(CXX)" LDFLAGS="$(LDFLAGS_$(CONFIG)) -g $(PROTOBUF_LDFLAGS_EXTRA)" CPPFLAGS="$(PIC_CPPFLAGS) $(CPPFLAGS_$(CONFIG)) -g $(PROTOBUF_CPPFLAGS_EXTRA)" ./configure --disable-shared --enable-static $(PROTOBUF_CONFIG_OPTS)) |
|
$(Q)$(MAKE) -C third_party/protobuf clean |
|
$(Q)$(MAKE) -C third_party/protobuf |
|
$(Q)mkdir -p $(BINDIR)/$(CONFIG)/protobuf |
|
$(Q)cp third_party/protobuf/src/.libs/libprotoc.a $(LIBDIR)/$(CONFIG)/protobuf |
|
$(Q)cp third_party/protobuf/src/.libs/libprotobuf.a $(LIBDIR)/$(CONFIG)/protobuf |
|
$(Q)cp third_party/protobuf/src/protoc $(BINDIR)/$(CONFIG)/protobuf |
|
|
|
static: static_c static_cxx |
|
|
|
static_c: cache.mk \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'all' and lib.language == 'c' and not lib.get('external_deps', None): |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
|
|
static_cxx: cache.mk \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'all' and lib.language == 'c++': |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
|
|
static_csharp: static_c \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'all' and lib.language == 'csharp': |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
|
|
shared: shared_c shared_cxx |
|
|
|
shared_c: cache.mk\ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'all' and lib.language == 'c' and not lib.get('external_deps', None): |
|
$(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CORE).$(SHARED_EXT_CORE)\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
shared_cxx: cache.mk\ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'all' and lib.language == 'c++': |
|
$(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CPP).$(SHARED_EXT_CPP)\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
|
|
shared_csharp: shared_c \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'all' and lib.language == 'csharp': |
|
$(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CSHARP).$(SHARED_EXT_CSHARP)\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
grpc_csharp_ext: shared_csharp |
|
|
|
plugins: $(PROTOC_PLUGINS) |
|
|
|
privatelibs: privatelibs_c privatelibs_cxx |
|
|
|
privatelibs_c: \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'private' and lib.language == 'c' and not lib.get('external_deps', None) and not lib.boringssl: |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
ifeq ($(EMBED_OPENSSL),true) |
|
privatelibs_cxx: \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'private' and lib.language == 'c++' and not lib.get('external_deps', None): |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
else |
|
privatelibs_cxx: \ |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.build == 'private' and lib.language == 'c++' and not lib.get('external_deps', None) and not lib.boringssl: |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a\ |
|
% endif |
|
% endif |
|
% endfor |
|
|
|
endif |
|
|
|
|
|
strip: strip-static strip-shared |
|
|
|
strip-static: strip-static_c strip-static_cxx |
|
|
|
strip-shared: strip-shared_c strip-shared_cxx |
|
|
|
strip-static_c: static_c |
|
ifeq ($(CONFIG),opt) |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.language == "c": |
|
% if lib.build == "all": |
|
% if not lib.get('external_deps', None): |
|
$(E) "[STRIP] Stripping lib${lib.name}.a" |
|
$(Q) $(STRIP) $(LIBDIR)/$(CONFIG)/lib${lib.name}.a |
|
% endif |
|
% endif |
|
% endif |
|
% endif |
|
% endfor |
|
endif |
|
|
|
strip-static_cxx: static_cxx |
|
ifeq ($(CONFIG),opt) |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.language == "c++": |
|
% if lib.build == "all": |
|
$(E) "[STRIP] Stripping lib${lib.name}.a" |
|
$(Q) $(STRIP) $(LIBDIR)/$(CONFIG)/lib${lib.name}.a |
|
% endif |
|
% endif |
|
% endif |
|
% endfor |
|
endif |
|
|
|
strip-shared_c: shared_c |
|
ifeq ($(CONFIG),opt) |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.language == "c": |
|
% if lib.build == "all": |
|
% if not lib.get('external_deps', None): |
|
$(E) "[STRIP] Stripping $(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CORE).$(SHARED_EXT_CORE)" |
|
$(Q) $(STRIP) $(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CORE).$(SHARED_EXT_CORE) |
|
% endif |
|
% endif |
|
% endif |
|
% endif |
|
% endfor |
|
endif |
|
|
|
strip-shared_cxx: shared_cxx |
|
ifeq ($(CONFIG),opt) |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.language == "c++": |
|
% if lib.build == "all": |
|
$(E) "[STRIP] Stripping $(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CPP).$(SHARED_EXT_CPP)" |
|
$(Q) $(STRIP) $(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CPP).$(SHARED_EXT_CPP) |
|
% endif |
|
% endif |
|
% endif |
|
% endfor |
|
endif |
|
|
|
strip-shared_csharp: shared_csharp |
|
ifeq ($(CONFIG),opt) |
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
% if lib.language == "csharp": |
|
% if lib.build == "all": |
|
$(E) "[STRIP] Stripping $(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CSHARP).$(SHARED_EXT_CSHARP)" |
|
$(Q) $(STRIP) $(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_CSHARP).$(SHARED_EXT_CSHARP) |
|
% endif |
|
% endif |
|
% endif |
|
% endfor |
|
endif |
|
|
|
cache.mk:: |
|
$(E) "[MAKE] Generating $@" |
|
$(Q) echo "$(CACHE_MK)" | tr , '\n' >$@ |
|
|
|
% for p in protos: |
|
ifeq ($(NO_PROTOC),true) |
|
$(GENDIR)/${p}.pb.cc: protoc_dep_error |
|
$(GENDIR)/${p}.grpc.pb.cc: protoc_dep_error |
|
else |
|
<% |
|
pluginflags="" |
|
%> |
|
% if p in ["src/proto/grpc/testing/compiler_test", "src/proto/grpc/testing/echo"]: |
|
<% |
|
pluginflags="generate_mock_code=true:" |
|
%> |
|
% endif |
|
$(GENDIR)/${p}.pb.cc: ${p}.proto $(PROTOBUF_DEP) $(PROTOC_PLUGINS) ${' '.join('$(GENDIR)/%s.pb.cc' % q for q in proto_deps.get(p, []))} |
|
$(E) "[PROTOC] Generating protobuf CC file from $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(PROTOC) -Ithird_party/protobuf/src -I. --cpp_out=$(GENDIR) $< |
|
|
|
$(GENDIR)/${p}.grpc.pb.cc: ${p}.proto $(GENDIR)/${p}.pb.cc $(PROTOBUF_DEP) $(PROTOC_PLUGINS) ${' '.join('$(GENDIR)/%s.pb.cc $(GENDIR)/%s.grpc.pb.cc' % (q,q) for q in proto_deps.get(p, []))} |
|
$(E) "[GRPC] Generating gRPC's protobuf service CC file from $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(PROTOC) -Ithird_party/protobuf/src -I. --grpc_out=${pluginflags}$(GENDIR) --plugin=protoc-gen-grpc=$(PROTOC_PLUGINS_DIR)/grpc_cpp_plugin$(EXECUTABLE_SUFFIX) $< |
|
endif |
|
|
|
% endfor |
|
|
|
ifeq ($(CONFIG),stapprof) |
|
src/core/profiling/stap_timers.c: $(GENDIR)/src/core/profiling/stap_probes.h |
|
ifeq ($(HAS_SYSTEMTAP),true) |
|
$(GENDIR)/src/core/profiling/stap_probes.h: src/core/profiling/stap_probes.d |
|
$(E) "[DTRACE] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(DTRACE) -C -h -s $< -o $@ |
|
else |
|
$(GENDIR)/src/core/profiling/stap_probes.h: systemtap_dep_error stop |
|
endif |
|
endif |
|
|
|
$(OBJDIR)/$(CONFIG)/%.o : %.c |
|
$(E) "[C] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CC) $(CPPFLAGS) $(CFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
$(OBJDIR)/$(CONFIG)/%.o : $(GENDIR)/%.pb.cc |
|
$(E) "[CXX] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CXX) $(CPPFLAGS) $(CXXFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
$(OBJDIR)/$(CONFIG)/src/compiler/%.o : src/compiler/%.cc |
|
$(E) "[HOSTCXX] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(HOST_CXX) $(HOST_CXXFLAGS) $(HOST_CPPFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
$(OBJDIR)/$(CONFIG)/src/core/%.o : src/core/%.cc |
|
$(E) "[CXX] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CXX) $(CPPFLAGS) $(CXXFLAGS) $(COREFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
$(OBJDIR)/$(CONFIG)/test/core/%.o : test/core/%.cc |
|
$(E) "[CXX] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CXX) $(CPPFLAGS) $(CXXFLAGS) $(COREFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
$(OBJDIR)/$(CONFIG)/%.o : %.cc |
|
$(E) "[CXX] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CXX) $(CPPFLAGS) $(CXXFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
$(OBJDIR)/$(CONFIG)/%.o : %.cpp |
|
$(E) "[CXX] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CXX) $(CPPFLAGS) $(CXXFLAGS) -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
|
|
install: install_not_supported_error |
|
|
|
install_c: install_not_supported_error |
|
|
|
install_cxx: install_not_supported_error |
|
|
|
install_csharp: install_not_supported_error |
|
|
|
install-static: install_not_supported_error |
|
|
|
install-certs: install_not_supported_error |
|
|
|
clean: |
|
$(E) "[CLEAN] Cleaning build directories." |
|
$(Q) $(RM) -rf $(OBJDIR) $(LIBDIR) $(BINDIR) $(GENDIR) cache.mk |
|
|
|
|
|
# The various libraries |
|
|
|
% for lib in filtered_libs: |
|
% if 'Makefile' in lib.get('build_system', ['Makefile']): |
|
${makelib(lib)} |
|
% endif |
|
% endfor |
|
|
|
# Add private ABSEIL target which contains all sources used by all baselib libraries. |
|
<% |
|
# Collect all abseil source and header files used by gpr, grpc, so on. |
|
used_abseil_rules = set() |
|
for lib in libs: |
|
if lib.get("baselib"): |
|
for dep in lib.transitive_deps: |
|
if is_absl_lib(dep): |
|
used_abseil_rules.add(dep) |
|
used_abseil_srcs = [] |
|
used_abseil_hdrs = [] |
|
for lib in libs: |
|
if lib.name in used_abseil_rules: |
|
used_abseil_srcs.extend(lib.get("src", [])) |
|
used_abseil_hdrs.extend(lib.get("hdr", [])) |
|
# Create `grpc_abseil` rule with collected files. |
|
lib_type = type(libs[0]) |
|
grpc_abseil_lib = lib_type({ |
|
"name": "grpc_abseil", |
|
"build": "private", |
|
"language": "c", |
|
"defaults": "abseil", |
|
"src": sorted(used_abseil_srcs), |
|
"hdr": sorted(used_abseil_hdrs), |
|
"secure": False, |
|
}) |
|
%> |
|
${makelib(grpc_abseil_lib)} |
|
|
|
# All of the test targets, and protoc plugins |
|
|
|
% for tgt in filtered_targets: |
|
${maketarget(tgt)} |
|
% endfor |
|
|
|
<%def name="makelib(lib)"> |
|
# start of build recipe for library "${lib.name}" (generated by makelib(lib) template function) |
|
LIB${lib.name.upper()}_SRC = \\ |
|
|
|
% for src in lib.src: |
|
${proto_to_cc(src)} \\ |
|
|
|
% endfor |
|
|
|
% if "public_headers" in lib: |
|
% if lib.language == "c++": |
|
PUBLIC_HEADERS_CXX += \\ |
|
|
|
% else: |
|
PUBLIC_HEADERS_C += \\ |
|
|
|
% endif |
|
% for hdr in lib.public_headers: |
|
${hdr} \\ |
|
|
|
% endfor |
|
% endif |
|
|
|
LIB${lib.name.upper()}_OBJS = $(addprefix $(OBJDIR)/$(CONFIG)/, $(addsuffix .o, $(basename $(LIB${lib.name.upper()}_SRC)))) |
|
|
|
% if lib.get('defaults', None): |
|
% for name, value in defaults.get(lib.defaults).iteritems(): |
|
$(LIB${lib.name.upper()}_OBJS): ${name} += ${value} |
|
% endfor |
|
% endif |
|
|
|
## If the library requires OpenSSL, let's add some restrictions. |
|
% if lib.get('secure', 'check') == True or lib.get('secure', 'check') == 'check': |
|
ifeq ($(NO_SECURE),true) |
|
|
|
# You can't build secure libraries if you don't have OpenSSL. |
|
|
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a: openssl_dep_error |
|
|
|
% if lib.build == "all": |
|
$(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_${lang_to_var[lib.language]}).$(SHARED_EXT_${lang_to_var[lib.language]}): openssl_dep_error |
|
% endif |
|
|
|
else |
|
|
|
% if lib.language == 'c++': |
|
ifeq ($(NO_PROTOBUF),true) |
|
|
|
# You can't build a C++ library if you don't have protobuf - a bit overreached, but still okay. |
|
|
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a: protobuf_dep_error |
|
|
|
% if lib.build == "all": |
|
$(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_${lang_to_var[lib.language]}).$(SHARED_EXT_${lang_to_var[lib.language]}): protobuf_dep_error |
|
% endif |
|
|
|
else |
|
% endif |
|
|
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a: $(ZLIB_DEP) $(OPENSSL_DEP) $(CARES_DEP) $(ADDRESS_SORTING_DEP) $(RE2_DEP) $(UPB_DEP) $(GRPC_ABSEIL_DEP) \ |
|
## The else here corresponds to the if secure earlier. |
|
% else: |
|
% if lib.language == 'c++': |
|
ifeq ($(NO_PROTOBUF),true) |
|
|
|
# You can't build a C++ library if you don't have protobuf - a bit overreached, but still okay. |
|
|
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a: protobuf_dep_error |
|
|
|
% if lib.build == "all": |
|
$(LIBDIR)/$(CONFIG)/$(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_${lang_to_var[lib.language]}).$(SHARED_EXT_${lang_to_var[lib.language]}): protobuf_dep_error |
|
% endif |
|
|
|
else |
|
|
|
% endif |
|
$(LIBDIR)/$(CONFIG)/lib${lib.name}.a: \ |
|
% if lib.name not in ['z', 'ares', 'address_sorting', 're2', 'upb', 'grpc_abseil']: |
|
$(ZLIB_DEP) \ |
|
$(CARES_DEP) \ |
|
$(ADDRESS_SORTING_DEP) \ |
|
$(RE2_DEP) \ |
|
$(UPB_DEP) \ |
|
$(GRPC_ABSEIL_DEP) \ |
|
% endif |
|
% endif |
|
% if lib.language == 'c++': |
|
$(PROTOBUF_DEP)\ |
|
% endif |
|
$(LIB${lib.name.upper()}_OBJS) \ |
|
% if lib.get('baselib', False): |
|
$(LIBGPR_OBJS) \ |
|
$(LIBGRPC_ABSEIL_OBJS) \ |
|
$(ZLIB_MERGE_OBJS) \ |
|
$(CARES_MERGE_OBJS) \ |
|
$(ADDRESS_SORTING_MERGE_OBJS) \ |
|
$(RE2_MERGE_OBJS) \ |
|
$(UPB_MERGE_OBJS) \ |
|
% if lib.get('secure', 'check') == True: |
|
$(OPENSSL_MERGE_OBJS) \ |
|
% endif |
|
% endif |
|
|
|
$(E) "[AR] Creating $@" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) rm -f $(LIBDIR)/$(CONFIG)/lib${lib.name}.a |
|
$(Q) $(AR) $(ARFLAGS) $(LIBDIR)/$(CONFIG)/lib${lib.name}.a $(LIB${lib.name.upper()}_OBJS) \ |
|
% if lib.get('baselib', False): |
|
$(LIBGPR_OBJS) \ |
|
$(LIBGRPC_ABSEIL_OBJS) \ |
|
$(ZLIB_MERGE_OBJS) \ |
|
$(CARES_MERGE_OBJS) \ |
|
$(ADDRESS_SORTING_MERGE_OBJS) \ |
|
$(RE2_MERGE_OBJS) \ |
|
$(UPB_MERGE_OBJS) \ |
|
% if lib.get('secure', 'check') == True: |
|
$(OPENSSL_MERGE_OBJS) \ |
|
% endif |
|
% endif |
|
|
|
ifeq ($(SYSTEM),Darwin) |
|
$(Q) ranlib -no_warning_for_no_symbols $(LIBDIR)/$(CONFIG)/lib${lib.name}.a |
|
endif |
|
|
|
<% |
|
|
|
if lib.language == 'c++': |
|
ld = '$(LDXX)' |
|
else: |
|
ld = '$(LDXX)' |
|
|
|
out_mingbase = '$(LIBDIR)/$(CONFIG)/' + lib.name + '$(SHARED_VERSION_' + lang_to_var[lib.language] + ')' |
|
out_libbase = '$(LIBDIR)/$(CONFIG)/lib' + lib.name + '$(SHARED_VERSION_' + lang_to_var[lib.language] + ')' |
|
|
|
common = '$(LIB' + lib.name.upper() + '_OBJS)' |
|
|
|
link_libs = '' |
|
lib_deps = ' $(ZLIB_DEP) $(CARES_DEP) $(ADDRESS_SORTING_DEP) $(RE2_DEP) $(UPB_DEP) $(GRPC_ABSEIL_DEP)' |
|
mingw_libs = '' |
|
mingw_lib_deps = ' $(ZLIB_DEP) $(CARES_DEP) $(ADDRESS_SORTING_DEP) $(RE2_DEP) $(UPB_DEP) $(GRPC_ABSEIL_DEP)' |
|
if lib.language == 'c++': |
|
lib_deps += ' $(PROTOBUF_DEP)' |
|
mingw_lib_deps += ' $(PROTOBUF_DEP)' |
|
if lib.get('deps_linkage', None) == 'static': |
|
for dep in lib.get('deps', []): |
|
if is_absl_lib(dep): continue |
|
lib_archive = '$(LIBDIR)/$(CONFIG)/lib' + dep + '.a' |
|
common = common + ' ' + lib_archive |
|
lib_deps = lib_deps + ' ' + lib_archive |
|
mingw_lib_deps = mingw_lib_deps + ' ' + lib_archive |
|
else: |
|
for dep in lib.get('deps', []): |
|
if is_absl_lib(dep): continue |
|
dep_lib = None |
|
for dl in libs: |
|
if dl.name == dep: |
|
dep_lib = dl |
|
assert dep_lib, 'lib %s not found (in %s)' % (dep, lib.name) |
|
link_libs = link_libs + ' -l' + dep |
|
lib_deps = lib_deps + ' $(LIBDIR)/$(CONFIG)/lib' + dep + '.$(SHARED_EXT_' + lang_to_var[dep_lib.language] + ')' |
|
mingw_libs = mingw_libs + ' -l' + dep + '$(SHARED_VERSION_' + lang_to_var[dep_lib.language] + ')-dll' |
|
mingw_lib_deps = mingw_lib_deps + ' $(LIBDIR)/$(CONFIG)/' + dep + '$(SHARED_VERSION_' + lang_to_var[dep_lib.language] + ').$(SHARED_EXT_' + lang_to_var[dep_lib.language] + ')' |
|
|
|
security = lib.get('secure', 'check') |
|
if security == True: |
|
common = common + ' $(OPENSSL_MERGE_LIBS) $(LDLIBS_SECURE)' |
|
common = common + ' $(ZLIB_MERGE_LIBS) $(CARES_MERGE_LIBS) $(ADDRESS_SORTING_MERGE_LIBS) $(RE2_MERGE_LIBS) $(UPB_MERGE_LIBS) $(GRPC_ABSEIL_MERGE_LIBS)' |
|
|
|
if security in [True, 'check']: |
|
for src in lib.src: |
|
if not proto_re.match(src): |
|
sources_that_need_openssl.add(src) |
|
else: |
|
for src in lib.src: |
|
sources_that_don_t_need_openssl.add(src) |
|
|
|
if lib.get('secure', 'check') == True or lib.get('secure', 'check') == 'check': |
|
lib_deps = lib_deps + ' $(OPENSSL_DEP)' |
|
mingw_lib_deps = mingw_lib_deps + ' $(OPENSSL_DEP)' |
|
|
|
if lib.language == 'c++': |
|
common = common + ' $(LDLIBSXX) $(LDLIBS_PROTOBUF)' |
|
|
|
ldflags = '$(LDFLAGS)' |
|
if lib.get('LDFLAGS', None): |
|
ldflags += ' ' + lib['LDFLAGS'] |
|
|
|
common = common + ' $(LDLIBS)' |
|
%> |
|
|
|
% if lib.build == "all": |
|
ifeq ($(SYSTEM),MINGW32) |
|
${out_mingbase}.$(SHARED_EXT_${lang_to_var[lib.language]}): $(LIB${lib.name.upper()}_OBJS) ${mingw_lib_deps} |
|
$(E) "[LD] Linking $@" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) ${ld} ${ldflags} -L$(LIBDIR)/$(CONFIG) -shared -Wl,--output-def=${out_mingbase}.def -Wl,--out-implib=${out_libbase}-dll.a -o ${out_mingbase}.$(SHARED_EXT_${lang_to_var[lib.language]}) ${common}${mingw_libs} |
|
else |
|
${out_libbase}.$(SHARED_EXT_${lang_to_var[lib.language]}): $(LIB${lib.name.upper()}_OBJS) ${lib_deps} |
|
$(E) "[LD] Linking $@" |
|
$(Q) mkdir -p `dirname $@` |
|
ifeq ($(SYSTEM),Darwin) |
|
$(Q) ${ld} ${ldflags} -L$(LIBDIR)/$(CONFIG) -install_name $(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_${lang_to_var[lib.language]}).$(SHARED_EXT_${lang_to_var[lib.language]}) -dynamiclib -o ${out_libbase}.$(SHARED_EXT_${lang_to_var[lib.language]}) ${common}${link_libs} |
|
else |
|
$(Q) ${ld} ${ldflags} -L$(LIBDIR)/$(CONFIG) -shared -Wl,-soname,lib${lib.name}.so.${settings.get(lang_to_var[lib.language].lower() + '_version').major} -o ${out_libbase}.$(SHARED_EXT_${lang_to_var[lib.language]}) ${common}${link_libs} |
|
$(Q) ln -sf $(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_${lang_to_var[lib.language]}).$(SHARED_EXT_${lang_to_var[lib.language]}) ${out_libbase}.so.${settings.get(lang_to_var[lib.language].lower() + '_version').major} |
|
$(Q) ln -sf $(SHARED_PREFIX)${lib.name}$(SHARED_VERSION_${lang_to_var[lib.language]}).$(SHARED_EXT_${lang_to_var[lib.language]}) ${out_libbase}.so |
|
endif |
|
endif |
|
% endif |
|
% if lib.get('secure', 'check') == True or lib.get('secure', 'check') == 'check': |
|
## If the lib was secure, we have to close the Makefile's if that tested |
|
## the presence of OpenSSL. |
|
|
|
endif |
|
% endif |
|
% if lib.language == 'c++': |
|
## If the lib was C++, we have to close the Makefile's if that tested |
|
## the presence of protobuf 3.12.0+ |
|
|
|
endif |
|
% endif |
|
|
|
% if lib.get('secure', 'check') == True or lib.get('secure', 'check') == 'check': |
|
ifneq ($(NO_SECURE),true) |
|
% endif |
|
ifneq ($(NO_DEPS),true) |
|
-include $(LIB${lib.name.upper()}_OBJS:.o=.dep) |
|
endif |
|
% if lib.get('secure', 'check') == True or lib.get('secure', 'check') == 'check': |
|
endif |
|
% endif |
|
% for src in lib.src: |
|
% if not proto_re.match(src) and any(proto_re.match(src2) for src2 in lib.src): |
|
$(OBJDIR)/$(CONFIG)/${os.path.splitext(src)[0]}.o: ${' '.join(proto_to_cc(src2) for src2 in lib.src if proto_re.match(src2))} |
|
% endif |
|
% endfor |
|
# end of build recipe for library "${lib.name}" |
|
</%def> |
|
|
|
<%def name="maketarget(tgt)"><% has_no_sources = not tgt.src %> |
|
# start of build recipe for target "${tgt.name}" (generated by maketarget(tgt) template function) |
|
% if not has_no_sources: |
|
${tgt.name.upper()}_SRC = \\ |
|
|
|
% for src in tgt.src: |
|
${proto_to_cc(src)} \\ |
|
|
|
% endfor |
|
|
|
${tgt.name.upper()}_OBJS = $(addprefix $(OBJDIR)/$(CONFIG)/, $(addsuffix .o, $(basename $(${tgt.name.upper()}_SRC)))) |
|
% endif |
|
% if tgt.get('secure', 'check') == True or tgt.get('secure', 'check') == 'check': |
|
ifeq ($(NO_SECURE),true) |
|
|
|
# You can't build secure targets if you don't have OpenSSL. |
|
|
|
$(BINDIR)/$(CONFIG)/${tgt.name}: openssl_dep_error |
|
|
|
else |
|
|
|
% endif |
|
|
|
% if tgt.boringssl: |
|
# boringssl needs an override to ensure that it does not include |
|
# system openssl headers regardless of other configuration |
|
# we do so here with a target specific variable assignment |
|
$(${tgt.name.upper()}_OBJS): CFLAGS := -Ithird_party/boringssl-with-bazel/src/include $(CFLAGS) -Wno-sign-conversion -Wno-conversion -Wno-unused-value $(NO_W_EXTRA_SEMI) |
|
$(${tgt.name.upper()}_OBJS): CXXFLAGS := -Ithird_party/boringssl-with-bazel/src/include $(CXXFLAGS) |
|
$(${tgt.name.upper()}_OBJS): CPPFLAGS += -DOPENSSL_NO_ASM -D_GNU_SOURCE |
|
% else: |
|
% endif |
|
|
|
## |
|
## We're not trying to add a dependency on building zlib and openssl here, |
|
## as it's already done in the libraries. We're assuming that the build |
|
## trickles down, and that a secure target requires a secure version of |
|
## a library. |
|
## |
|
## That simplifies the codegen a bit, but prevents a fully defined Makefile. |
|
## I can live with that. |
|
## |
|
% if tgt.build == 'protoc' or tgt.language == 'c++': |
|
|
|
ifeq ($(NO_PROTOBUF),true) |
|
|
|
# You can't build the protoc plugins or protobuf-enabled targets if you don't have protobuf 3.12.0+. |
|
|
|
$(BINDIR)/$(CONFIG)/${tgt.name}: protobuf_dep_error |
|
|
|
else |
|
|
|
$(BINDIR)/$(CONFIG)/${tgt.name}: \ |
|
% if not has_no_sources: |
|
$(PROTOBUF_DEP) $(${tgt.name.upper()}_OBJS)\ |
|
% endif |
|
% else: |
|
$(BINDIR)/$(CONFIG)/${tgt.name}: \ |
|
% if not has_no_sources: |
|
$(${tgt.name.upper()}_OBJS)\ |
|
% endif |
|
% endif |
|
% for dep in tgt.deps: |
|
% if not is_absl_lib(dep): |
|
$(LIBDIR)/$(CONFIG)/lib${dep}.a\ |
|
% endif |
|
% endfor |
|
|
|
% if tgt.language == "c++" or tgt.boringssl or tgt.build == 'fuzzer': |
|
## C++ targets specificies. |
|
% if tgt.build == 'protoc': |
|
$(E) "[HOSTLD] Linking $@" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(HOST_LDXX) $(HOST_LDFLAGS) \ |
|
% if not has_no_sources: |
|
$(${tgt.name.upper()}_OBJS)\ |
|
% endif |
|
% else: |
|
$(E) "[LD] Linking $@" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(LDXX) $(LDFLAGS) \ |
|
% if not has_no_sources: |
|
$(${tgt.name.upper()}_OBJS)\ |
|
% endif |
|
% endif |
|
% else: |
|
## C-only targets specificities. |
|
$(E) "[LD] Linking $@" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(LDXX) $(LDFLAGS) \ |
|
% if not has_no_sources: |
|
$(${tgt.name.upper()}_OBJS)\ |
|
% endif |
|
% endif |
|
% for dep in tgt.deps: |
|
$(LIBDIR)/$(CONFIG)/lib${dep}.a\ |
|
% endfor |
|
% if tgt.language == "c++": |
|
% if tgt.build == 'protoc': |
|
$(HOST_LDLIBSXX) $(HOST_LDLIBS_PROTOC)\ |
|
% else: |
|
$(LDLIBSXX) $(LDLIBS_PROTOBUF)\ |
|
% endif |
|
% endif |
|
% if tgt.build == 'protoc': |
|
$(HOST_LDLIBS)\ |
|
% else: |
|
$(LDLIBS)\ |
|
% endif |
|
% if tgt.build == 'protoc': |
|
$(HOST_LDLIBS_PROTOC)\ |
|
% elif tgt.get('secure', 'check') == True or tgt.get('secure', 'check') == 'check': |
|
$(LDLIBS_SECURE)\ |
|
% endif |
|
% if tgt.language == 'c++' and tgt.build == 'test': |
|
$(GTEST_LIB)\ |
|
% elif tgt.language == 'c++' and tgt.build == 'benchmark': |
|
$(GTEST_LIB)\ |
|
% endif |
|
% if tgt.build == 'fuzzer': |
|
-lFuzzer\ |
|
% endif |
|
-o $(BINDIR)/$(CONFIG)/${tgt.name} |
|
% if tgt.build == 'protoc' or tgt.language == 'c++': |
|
|
|
endif |
|
% endif |
|
% if tgt.get('secure', 'check') == True or tgt.get('secure', 'check') == 'check': |
|
|
|
endif |
|
% endif |
|
|
|
% if tgt.get('defaults', None): |
|
% for name, value in defaults.get(tgt.defaults).iteritems(): |
|
$(${tgt.name.upper()}_OBJS): ${name} += ${value} |
|
% endfor |
|
% endif |
|
% for src in tgt.src: |
|
$(OBJDIR)/$(CONFIG)/${os.path.splitext(src)[0]}.o: \ |
|
% for dep in tgt.deps: |
|
$(LIBDIR)/$(CONFIG)/lib${dep}.a\ |
|
% endfor |
|
|
|
% if tgt.language == 'c89': |
|
% for src in tgt.src: |
|
$(OBJDIR)/$(CONFIG)/${os.path.splitext(src)[0]}.o : ${src} |
|
$(E) "[C] Compiling $<" |
|
$(Q) mkdir -p `dirname $@` |
|
$(Q) $(CC) $(CPPFLAGS) $(CFLAGS) -std=c89 -pedantic -MMD -MF $(addsuffix .dep, $(basename $@)) -c -o $@ $< |
|
% endfor |
|
% endif |
|
|
|
% endfor |
|
% if not has_no_sources: |
|
deps_${tgt.name}: $(${tgt.name.upper()}_OBJS:.o=.dep) |
|
% endif |
|
|
|
% if not has_no_sources: |
|
% if tgt.get('secure', 'check') == True or tgt.get('secure', 'check') == 'check': |
|
ifneq ($(NO_SECURE),true) |
|
% endif |
|
ifneq ($(NO_DEPS),true) |
|
-include $(${tgt.name.upper()}_OBJS:.o=.dep) |
|
endif |
|
% if tgt.get('secure', 'check') == True or tgt.get('secure', 'check') == 'check': |
|
endif |
|
% endif |
|
% endif |
|
% for src in tgt.src: |
|
% if not proto_re.match(src) and any(proto_re.match(src2) for src2 in tgt.src): |
|
$(OBJDIR)/$(CONFIG)/${os.path.splitext(src)[0]}.o: ${' '.join(proto_to_cc(src2) for src2 in tgt.src if proto_re.match(src2))} |
|
% endif |
|
% endfor |
|
# end of build recipe for target "${tgt.name}" |
|
</%def> |
|
|
|
ifneq ($(OPENSSL_DEP),) |
|
# This is to ensure the embedded OpenSSL is built beforehand, properly |
|
# installing headers to their final destination on the drive. We need this |
|
# otherwise parallel compilation will fail if a source is compiled first. |
|
% for src in sorted(sources_that_need_openssl): |
|
% if src not in sources_that_don_t_need_openssl: |
|
${src}: $(OPENSSL_DEP) |
|
% endif |
|
% endfor |
|
endif |
|
|
|
.PHONY: all strip tools \ |
|
dep_error openssl_dep_error openssl_dep_message git_update stop \ |
|
buildtests buildtests_c buildtests_cxx \ |
|
test test_c test_cxx \ |
|
install install_c install_cxx install_csharp install-static install-certs \ |
|
strip strip-shared strip-static \ |
|
strip_c strip-shared_c strip-static_c \ |
|
strip_cxx strip-shared_cxx strip-static_cxx \ |
|
dep_c dep_cxx bins_dep_c bins_dep_cxx \ |
|
clean |
|
|
|
.PHONY: printvars |
|
printvars: |
|
@$(foreach V,$(sort $(.VARIABLES)), \ |
|
$(if $(filter-out environment% default automatic, \ |
|
$(origin $V)),$(warning $V=$($V) ($(value $V)))))
|
|
|