Makefile 73.9 KB
Newer Older
J
jorlow@chromium.org 已提交
1 2 3 4
# Copyright (c) 2011 The LevelDB Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file. See the AUTHORS file for names of contributors.

5
# Inherit some settings from environment variables, if available
J
jorlow@chromium.org 已提交
6

7
#-----------------------------------------------
奏之章 已提交
8 9
USE_RTTI = 1

J
Jonathan Lee 已提交
10 11 12
BASH_EXISTS := $(shell which bash)
SHELL := $(shell which bash)

L
leipeng 已提交
13
COMPRESSION_CXXFLAGS ?= -DSNAPPY=1 -DZLIB=1 -DLZ4=1 -DLZ4_DISABLE_DEPRECATE_WARNINGS -DZSTD=1 -Isnappy-1.1.4 -Ilz4-1.8.0/lib -Izstd-1.3.3/lib/include -Izlib-1.2.11
L
leipeng 已提交
14
COMPRESSION_LDFLAGS  ?= -L. -lsnappy -lz -llz4
15

16
CLEAN_FILES = # deliberately empty, so we can append below.
17
CFLAGS += ${EXTRA_CFLAGS}
L
leipeng 已提交
18 19
CXXFLAGS += ${EXTRA_CXXFLAGS} ${COMPRESSION_CXXFLAGS}
LDFLAGS += $(EXTRA_LDFLAGS) ${COMPRESSION_LDFLAGS}
20
MACHINE ?= $(shell uname -m)
T
Tomas Kolda 已提交
21 22
ARFLAGS = ${EXTRA_ARFLAGS} rs
STRIPFLAGS = -S -x
23

雷鹏 已提交
24
CXXFLAGS += -fPIC
25 26
# Transform parallel LOG output into something more readable.
perl_command = perl -n \
27 28 29
  -e '@a=split("\t",$$_,-1); $$t=$$a[8];'				\
  -e '$$t =~ /.*if\s\[\[\s"(.*?\.[\w\/]+)/ and $$t=$$1;'		\
  -e '$$t =~ s,^\./,,;'							\
Y
Yueh-Hsuan Chiang 已提交
30 31 32
  -e '$$t =~ s, >.*,,; chomp $$t;'					\
  -e '$$t =~ /.*--gtest_filter=(.*?\.[\w\/]+)/ and $$t=$$1;'		\
  -e 'printf "%7.3f %s %s\n", $$a[3], $$a[6] == 0 ? "PASS" : "FAIL", $$t'
33 34
quoted_perl_command = $(subst ','\'',$(perl_command))

35 36 37 38 39 40 41 42 43
# DEBUG_LEVEL can have three values:
# * DEBUG_LEVEL=2; this is the ultimate debug mode. It will compile rocksdb
# without any optimizations. To compile with level 2, issue `make dbg`
# * DEBUG_LEVEL=1; debug level 1 enables all assertions and debug code, but
# compiles rocksdb with -O2 optimizations. this is the default debug level.
# `make all` or `make <binary_target>` compile RocksDB with debug level 1.
# We use this debug level when developing RocksDB.
# * DEBUG_LEVEL=0; this is the debug level we use for release. If you're
# running rocksdb in production you most definitely want to compile RocksDB
A
agiardullo 已提交
44
# with debug level 0. To compile with level 0, run `make shared_lib`,
45 46
# `make install-shared`, `make static_lib`, `make install-static` or
# `make install`
47 48 49

# Set the default DEBUG_LEVEL to 1
DEBUG_LEVEL?=1
50 51

ifeq ($(MAKECMDGOALS),dbg)
Y
Yueh-Hsuan Chiang 已提交
52
	DEBUG_LEVEL=2
53
endif
54

55 56 57 58 59 60 61 62
ifeq ($(MAKECMDGOALS),clean)
	DEBUG_LEVEL=0
endif

ifeq ($(MAKECMDGOALS),release)
	DEBUG_LEVEL=0
endif

63
ifeq ($(MAKECMDGOALS),shared_lib)
Y
Yueh-Hsuan Chiang 已提交
64
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
65
endif
I
Igor Canadi 已提交
66

I
Igor Canadi 已提交
67
ifeq ($(MAKECMDGOALS),install-shared)
Y
Yueh-Hsuan Chiang 已提交
68
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
69 70
endif

I
Igor Canadi 已提交
71
ifeq ($(MAKECMDGOALS),static_lib)
Y
Yueh-Hsuan Chiang 已提交
72
	DEBUG_LEVEL=0
73
endif
I
Igor Canadi 已提交
74

I
Igor Canadi 已提交
75
ifeq ($(MAKECMDGOALS),install-static)
Y
Yueh-Hsuan Chiang 已提交
76
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
77 78 79
endif

ifeq ($(MAKECMDGOALS),install)
Y
Yueh-Hsuan Chiang 已提交
80
	DEBUG_LEVEL=0
81 82
endif

83
ifeq ($(MAKECMDGOALS),rocksdbjavastatic)
84 85 86
	ifneq ($(DEBUG_LEVEL),2)
		DEBUG_LEVEL=0
	endif
87 88
endif

Y
Yueh-Hsuan Chiang 已提交
89 90 91 92
ifeq ($(MAKECMDGOALS),rocksdbjavastaticrelease)
	DEBUG_LEVEL=0
endif

93 94 95 96
ifeq ($(MAKECMDGOALS),rocksdbjavastaticreleasedocker)
        DEBUG_LEVEL=0
endif

Y
Yueh-Hsuan Chiang 已提交
97 98 99 100
ifeq ($(MAKECMDGOALS),rocksdbjavastaticpublish)
	DEBUG_LEVEL=0
endif

雷鹏 已提交
101 102
###############################################################################
## Terark specific
L
leipeng 已提交
103

104
ifeq (${DEBUG_LEVEL},0)
奏之章 已提交
105
  DBG_OR_RLS=r
106 107 108 109 110
endif
ifeq (${DEBUG_LEVEL},1)
  DBG_OR_RLS=a
endif
ifeq (${DEBUG_LEVEL},2)
奏之章 已提交
111 112 113
  DBG_OR_RLS=d
endif

雷鹏 已提交
114
BMI2 ?= $(shell bash cpu_has_bmi2.sh)
雷鹏 已提交
115 116 117 118
BUILD_NAME := $(shell bash get_terark_build_name.sh ${CXX} ${BMI2})
BUILD_ROOT := build/${BUILD_NAME}
xdir:=${BUILD_ROOT}/dbg-${DEBUG_LEVEL}

L
leipeng 已提交
119 120 121 122 123
ifdef TERARK_CORE_BRANCH
  TERARK_CORE_HOME := terark-core
else
  TERARK_CORE_HOME ?= ../terark-core
endif
C
chenchanglong 已提交
124
TERARK_CORE_PKG_DIR := ${TERARK_CORE_HOME}/pkg/terark-fsa_all-${BUILD_NAME}
125

L
leipeng 已提交
126
CXXFLAGS += -march=haswell
127
CXXFLAGS += -I${TERARK_CORE_HOME}/src -I${TERARK_CORE_HOME}/boost-include -I${TERARK_CORE_HOME}/output/include
L
leipeng 已提交
128 129

# BUNDLE_TERARK_ZIP_ROCKSDB can use precompiled terark-core
130 131 132 133
# ifdef BUNDLE_TERARK_ZIP_ROCKSDB
#   CXXFLAGS += -Iterark-zip-rocksdb/src

# # do not use wildcard, to kill dependency to terark-zip-rocksdb.got
C
chenchanglong 已提交
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
   TERARK_ZIP_SRC := \
       memtable/terark_zip_entry_index.cc \
       memtable/terark_zip_memtable.cc    \
       table/terark_zip_common.cc         \
       table/terark_zip_config.cc         \
       table/terark_zip_table.cc          \
       table/terark_zip_table_builder.cc  \
       table/terark_zip_table_reader.cc   \

   TERARK_ZIP_OBJ := $(addprefix ${xdir}/,${TERARK_ZIP_SRC:.cc=.o}) \
      $(addprefix shared-objects/${xdir}/,${TERARK_ZIP_SRC:.cc=.o})

   SRC_NEEDS_TERARK_ZIP := ${TERARK_ZIP_SRC}               \
                           db/compacted_db_impl.cc         \
                           db/db_impl.cc                   \
                           db/db_impl_compaction_flush.cc  \
                           db/db_impl_debug.cc             \
                           db/db_impl_experimental.cc      \
                           db/db_impl_files.cc             \
                           db/db_impl_open.cc              \
                           db/db_impl_readonly.cc          \
                           db/db_impl_write.cc             \
                           tools/sst_dump_tool.cc

   SRC_NEEDS_BOOST := util/thread_local.cc \
                      ${TERARK_ZIP_SRC}
L
leipeng 已提交
160

L
leipeng 已提交
161
#------------------------------------------------------------------------------
L
leipeng 已提交
162
ifeq (${TERARK_CORE_HOME},terark-core)
L
leipeng 已提交
163 164
terark-core.got:
	rm -rf terark-core
165
	git clone git@code.byted.org:storage/terark-core.git
L
leipeng 已提交
166
ifdef TERARK_CORE_BRANCH
167 168
	cd terark-core && git checkout ${TERARK_CORE_BRANCH}
endif
C
chenchanglong 已提交
169 170
	cd terark-core && git submodule update --init
	+$(MAKE) -C terark-core pkg PKG_WITH_DBG=1 PKG_WITH_STATIC=1 WITH_BMI2=${BMI2}
L
leipeng 已提交
171
	touch $@
L
leipeng 已提交
172
${SRC_NEEDS_BOOST} ${SRC_NEEDS_BOOST:.o=.cc.d}: terark-core.got
C
chenchanglong 已提交
173
${TERARK_ZIP_OBJ} ${TERARK_ZIP_OBJ:.o=.cc.d}: terark-core.got
L
leipeng 已提交
174
endif
C
chenchanglong 已提交
175
${TERARK_ZIP_OBJ} ${TERARK_ZIP_OBJ:.o=.cc.d}: CXXFLAGS += -Wno-unused-parameter -I${TERARK_CORE_HOME}/3rdparty/zstd{,/zstd}
L
leipeng 已提交
176 177

LINK_TERARK ?= static
雷鹏 已提交
178

L
leipeng 已提交
179 180 181 182
ifeq ($(shell uname),Darwin)
  LIB_GOMP :=
else
  LIB_GOMP := -lgomp
雷鹏 已提交
183 184 185
endif

ifeq ($(LINK_TERARK),shared)
186 187
  export LD_LIBRARY_PATH:=${TERARK_CORE_PKG_DIR}/lib:${LD_LIBRARY_PATH}
  TerarkLDFLAGS += 	-lterark-idx-${DBG_OR_RLS} \
奏之章 已提交
188 189
                    -lterark-zbs-${DBG_OR_RLS} \
                    -lterark-fsa-${DBG_OR_RLS} \
L
leipeng 已提交
190
                    -lterark-core-${DBG_OR_RLS} -ldl ${LIB_GOMP}
奏之章 已提交
191
endif
雷鹏 已提交
192
ifeq ($(LINK_TERARK),static)
193 194 195 196 197
  override LINK_STATIC_TERARK := -L${TERARK_CORE_PKG_DIR}/lib_static \
    ${TERARK_CORE_PKG_DIR}/lib_static/libterark-idx-${DBG_OR_RLS}.a \
    ${TERARK_CORE_PKG_DIR}/lib_static/libterark-zbs-${DBG_OR_RLS}.a \
    ${TERARK_CORE_PKG_DIR}/lib_static/libterark-fsa-${DBG_OR_RLS}.a \
    ${TERARK_CORE_PKG_DIR}/lib_static/libterark-core-${DBG_OR_RLS}.a
L
leipeng 已提交
198
  ifeq ($(shell uname),Darwin)
L
leipeng 已提交
199 200 201 202 203
    override LINK_STATIC_TERARK := \
      -Wl,-all_load ${LINK_STATIC_TERARK} -Wl,-noall_load
  else
    override LINK_STATIC_TERARK := \
      -Wl,--whole-archive ${LINK_STATIC_TERARK} -Wl,--no-whole-archive
L
leipeng 已提交
204
  endif
L
leipeng 已提交
205
  override LINK_STATIC_TERARK += ${LIB_GOMP}
L
leipeng 已提交
206

奏之章 已提交
207
endif
L
leipeng 已提交
208

雷鹏 已提交
209
###############################################################################
奏之章 已提交
210

Y
Yi Wu 已提交
211 212
# Lite build flag.
LITE ?= 0
213 214 215 216 217 218 219 220
ifeq ($(LITE), 0)
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
  # Be backward compatible and support older format where OPT=-DROCKSDB_LITE is
  # specified instead of LITE=1 on the command line.
  LITE=1
endif
else ifeq ($(LITE), 1)
ifeq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yi Wu 已提交
221 222
	OPT += -DROCKSDB_LITE
endif
223
endif
Y
Yi Wu 已提交
224 225 226 227 228 229 230 231 232 233

# Figure out optimize level.
ifneq ($(DEBUG_LEVEL), 2)
ifeq ($(LITE), 0)
	OPT += -O2
else
	OPT += -Os
endif
endif

234 235
# compile with -O2 if debug level is not 2
ifneq ($(DEBUG_LEVEL), 2)
Y
Yi Wu 已提交
236
OPT += -fno-omit-frame-pointer
237 238
# Skip for archs that don't support -momit-leaf-frame-pointer
ifeq (,$(shell $(CXX) -fsyntax-only -momit-leaf-frame-pointer -xc /dev/null 2>&1))
239 240 241 242
OPT += -momit-leaf-frame-pointer
endif
endif

243 244 245 246 247 248 249 250 251 252 253 254
ifeq (,$(shell $(CXX) -fsyntax-only -maltivec -xc /dev/null 2>&1))
CXXFLAGS += -DHAS_ALTIVEC
CFLAGS += -DHAS_ALTIVEC
HAS_ALTIVEC=1
endif

ifeq (,$(shell $(CXX) -fsyntax-only -mcpu=power8 -xc /dev/null 2>&1))
CXXFLAGS += -DHAVE_POWER8
CFLAGS +=  -DHAVE_POWER8
HAVE_POWER8=1
endif

255
# if we're compiling for release, compile without debug code (-DNDEBUG)
256
ifeq ($(DEBUG_LEVEL),0)
L
leipeng 已提交
257
OPT += -DNDEBUG -DBOOST_DISABLE_ASSERTS
S
Siying Dong 已提交
258 259 260 261 262 263

ifneq ($(USE_RTTI), 0)
	CXXFLAGS += -DROCKSDB_USE_RTTI
else
	CXXFLAGS += -fno-rtti
endif
雷鹏 已提交
264
else
265
$(warning Warning: Compiling in debug mode. Don't use the resulting binary in production)
I
Igor Canadi 已提交
266 267
endif

268
#-----------------------------------------------
269
include src.mk
270

奏之章 已提交
271
AM_DEFAULT_VERBOSITY = 1
272 273 274 275 276

AM_V_GEN = $(am__v_GEN_$(V))
am__v_GEN_ = $(am__v_GEN_$(AM_DEFAULT_VERBOSITY))
am__v_GEN_0 = @echo "  GEN     " $@;
am__v_GEN_1 =
J
Jim Meyering 已提交
277 278 279 280
AM_V_at = $(am__v_at_$(V))
am__v_at_ = $(am__v_at_$(AM_DEFAULT_VERBOSITY))
am__v_at_0 = @
am__v_at_1 =
281 282 283 284 285 286 287 288 289 290 291

AM_V_CC = $(am__v_CC_$(V))
am__v_CC_ = $(am__v_CC_$(AM_DEFAULT_VERBOSITY))
am__v_CC_0 = @echo "  CC      " $@;
am__v_CC_1 =
CCLD = $(CC)
LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@
AM_V_CCLD = $(am__v_CCLD_$(V))
am__v_CCLD_ = $(am__v_CCLD_$(AM_DEFAULT_VERBOSITY))
am__v_CCLD_0 = @echo "  CCLD    " $@;
am__v_CCLD_1 =
J
Jim Meyering 已提交
292 293 294 295
AM_V_AR = $(am__v_AR_$(V))
am__v_AR_ = $(am__v_AR_$(AM_DEFAULT_VERBOSITY))
am__v_AR_0 = @echo "  AR      " $@;
am__v_AR_1 =
296

297 298 299 300
ifdef ROCKSDB_USE_LIBRADOS
LIB_SOURCES += utilities/env_librados.cc
LDFLAGS += -lrados
endif
301

雷鹏 已提交
302 303
LIB_SOURCES += ${TERARK_ZIP_SRC}

奏之章 已提交
304
AM_LINK = $(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ ${TerarkLDFLAGS} $(LDFLAGS) $(COVERAGEFLAGS)
305
# detect what platform we're building on
奏之章 已提交
306 307 308 309
dummy := $(shell (export ROCKSDB_ROOT="$(CURDIR)"; export PORTABLE="$(PORTABLE)"; "$(CURDIR)/build_tools/build_detect_platform" "$(CURDIR)/make_config.mk"; echo $$?))
ifneq ("${dummy}","0")
  $(error "$(CURDIR)/build_tools/build_detect_platform failed")
endif
S
Sanjay Ghemawat 已提交
310
# this file is generated by the previous line to set build flags and sources
I
Igor Canadi 已提交
311
include make_config.mk
312
CLEAN_FILES += make_config.mk
J
jorlow@chromium.org 已提交
313

314 315 316 317 318 319 320 321 322
missing_make_config_paths := $(shell				\
	grep "\/\S*" -o $(CURDIR)/make_config.mk | 		\
	while read path;					\
		do [ -e $$path ] || echo $$path; 		\
	done | sort | uniq)

$(foreach path, $(missing_make_config_paths), \
	$(warning Warning: $(path) dont exist))

T
Tomas Kolda 已提交
323 324 325
ifeq ($(PLATFORM), OS_AIX)
# no debug info
else ifneq ($(PLATFORM), IOS)
I
Igor Canadi 已提交
326 327 328 329
CFLAGS += -g
CXXFLAGS += -g
else
# no debug info for IOS, that will make our library big
L
leipeng 已提交
330
OPT += -DNDEBUG -DBOOST_DISABLE_ASSERTS
I
Igor Canadi 已提交
331 332
endif

T
Tomas Kolda 已提交
333 334 335 336 337
ifeq ($(PLATFORM), OS_AIX)
ARFLAGS = -X64 rs
STRIPFLAGS = -X64 -x
endif

D
David Bernard 已提交
338 339 340
ifeq ($(PLATFORM), OS_SOLARIS)
	PLATFORM_CXXFLAGS += -D _GLIBCXX_USE_C99
endif
341
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yueh-Hsuan Chiang 已提交
342 343 344
	# found
	CFLAGS += -fno-exceptions
	CXXFLAGS += -fno-exceptions
345 346
	# LUA is not supported under ROCKSDB_LITE
	LUA_PATH =
347 348
endif

I
Igor Canadi 已提交
349 350
# ASAN doesn't work well with jemalloc. If we're compiling with ASAN, we should use regular malloc.
ifdef COMPILE_WITH_ASAN
Y
Yueh-Hsuan Chiang 已提交
351 352 353 354
	DISABLE_JEMALLOC=1
	EXEC_LDFLAGS += -fsanitize=address
	PLATFORM_CCFLAGS += -fsanitize=address
	PLATFORM_CXXFLAGS += -fsanitize=address
I
Igor Canadi 已提交
355 356 357 358
endif

# TSAN doesn't work well with jemalloc. If we're compiling with TSAN, we should use regular malloc.
ifdef COMPILE_WITH_TSAN
Y
Yueh-Hsuan Chiang 已提交
359
	DISABLE_JEMALLOC=1
S
Siying Dong 已提交
360
	EXEC_LDFLAGS += -fsanitize=thread
361 362
	PLATFORM_CCFLAGS += -fsanitize=thread -fPIC
	PLATFORM_CXXFLAGS += -fsanitize=thread -fPIC
363 364
        # Turn off -pg when enabling TSAN testing, because that induces
        # a link failure.  TODO: find the root cause
D
dx9 已提交
365
	PROFILING_FLAGS =
366 367
	# LUA is not supported under TSAN
	LUA_PATH =
368 369 370
	# Limit keys for crash test under TSAN to avoid error:
	# "ThreadSanitizer: DenseSlabAllocator overflow. Dying."
	CRASH_TEST_EXT_ARGS += --max_key=1000000
I
Igor Canadi 已提交
371 372
endif

T
Tomas Kolda 已提交
373 374 375 376 377
# AIX doesn't work with -pg
ifeq ($(PLATFORM), OS_AIX)
	PROFILING_FLAGS =
endif

378 379 380
# USAN doesn't work well with jemalloc. If we're compiling with USAN, we should use regular malloc.
ifdef COMPILE_WITH_UBSAN
	DISABLE_JEMALLOC=1
S
Siying Dong 已提交
381 382 383 384
	# Suppress alignment warning because murmurhash relies on casting unaligned
	# memory to integer. Fixing it may cause performance regression. 3-way crc32
	# relies on it too, although it can be rewritten to eliminate with minimal
	# performance regression.
385 386 387
	EXEC_LDFLAGS += -fsanitize=undefined -fno-sanitize-recover=all
	PLATFORM_CCFLAGS += -fsanitize=undefined -fno-sanitize-recover=all -DROCKSDB_UBSAN_RUN
	PLATFORM_CXXFLAGS += -fsanitize=undefined -fno-sanitize-recover=all -DROCKSDB_UBSAN_RUN
388 389
endif

390 391 392 393 394
ifdef ROCKSDB_VALGRIND_RUN
	PLATFORM_CCFLAGS += -DROCKSDB_VALGRIND_RUN
	PLATFORM_CXXFLAGS += -DROCKSDB_VALGRIND_RUN
endif

I
Igor Canadi 已提交
395
ifndef DISABLE_JEMALLOC
396
	ifdef JEMALLOC
T
Tamir Duberstein 已提交
397 398
		PLATFORM_CXXFLAGS += -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE
		PLATFORM_CCFLAGS  += -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE
399
	endif
400 401 402 403
	ifdef WITH_JEMALLOC_FLAG
		PLATFORM_LDFLAGS += -ljemalloc
		JAVA_LDFLAGS += -ljemalloc
	endif
Y
Yueh-Hsuan Chiang 已提交
404 405 406
	EXEC_LDFLAGS := $(JEMALLOC_LIB) $(EXEC_LDFLAGS)
	PLATFORM_CXXFLAGS += $(JEMALLOC_INCLUDE)
	PLATFORM_CCFLAGS += $(JEMALLOC_INCLUDE)
I
Igor Canadi 已提交
407 408
endif

T
Tamir Duberstein 已提交
409 410
export GTEST_THROW_ON_FAILURE=1
export GTEST_HAS_EXCEPTIONS=1
I
Igor Sugak 已提交
411
GTEST_DIR = ./third-party/gtest-1.7.0/fused-src
T
Tomas Kolda 已提交
412 413 414 415 416 417 418 419
# AIX: pre-defined system headers are surrounded by an extern "C" block
ifeq ($(PLATFORM), OS_AIX)
	PLATFORM_CCFLAGS += -I$(GTEST_DIR)
	PLATFORM_CXXFLAGS += -I$(GTEST_DIR)
else
	PLATFORM_CCFLAGS += -isystem $(GTEST_DIR)
	PLATFORM_CXXFLAGS += -isystem $(GTEST_DIR)
endif
I
Igor Sugak 已提交
420

421 422 423
# This (the first rule) must depend on "all".
default: all

424
WARNING_FLAGS = -W -Wextra -Wall -Wsign-compare \
425
  -Wunused-parameter
426

427 428 429 430
ifdef Wshadow_local
    WARNING_FLAGS += -Wshadow=local
endif

431 432 433 434
ifeq ($(PLATFORM), OS_OPENBSD)
	WARNING_FLAGS += -Wno-unused-lambda-capture
endif

435
ifndef DISABLE_WARNING_AS_ERROR
Y
Yueh-Hsuan Chiang 已提交
436
	WARNING_FLAGS += -Werror
437 438
endif

439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461

ifdef LUA_PATH

ifndef LUA_INCLUDE
LUA_INCLUDE=$(LUA_PATH)/include
endif

LUA_INCLUDE_FILE=$(LUA_INCLUDE)/lualib.h

ifeq ("$(wildcard $(LUA_INCLUDE_FILE))", "")
# LUA_INCLUDE_FILE does not exist
$(error Cannot find lualib.h under $(LUA_INCLUDE).  Try to specify both LUA_PATH and LUA_INCLUDE manually)
endif
LUA_FLAGS = -I$(LUA_INCLUDE) -DLUA -DLUA_COMPAT_ALL
CFLAGS += $(LUA_FLAGS)
CXXFLAGS += $(LUA_FLAGS)

ifndef LUA_LIB
LUA_LIB = $(LUA_PATH)/lib/liblua.a
endif
ifeq ("$(wildcard $(LUA_LIB))", "") # LUA_LIB does not exist
$(error $(LUA_LIB) does not exist.  Try to specify both LUA_PATH and LUA_LIB manually)
endif
462
EXEC_LDFLAGS += $(LUA_LIB)
463 464 465

endif

466 467 468
ifeq ($(NO_THREEWAY_CRC32C), 1)
	CXXFLAGS += -DNO_THREEWAY_CRC32C
endif
469

I
Igor Canadi 已提交
470
CFLAGS += $(WARNING_FLAGS) -I. -I./include $(PLATFORM_CCFLAGS) $(OPT)
雷鹏 已提交
471
CXXFLAGS += $(WARNING_FLAGS) -I. -I./include $(PLATFORM_CXXFLAGS) $(OPT) -Woverloaded-virtual -Wnon-virtual-dtor -Wno-missing-field-initializers
472

S
Sanjay Ghemawat 已提交
473
LDFLAGS += $(PLATFORM_LDFLAGS)
J
jorlow@chromium.org 已提交
474

475 476 477
# If NO_UPDATE_BUILD_VERSION is set we don't update util/build_version.cc, but
# the file needs to already exist or else the build will fail
ifndef NO_UPDATE_BUILD_VERSION
478
date := $(shell date +%F)
I
Igor Canadi 已提交
479
ifdef FORCE_GIT_SHA
Y
Yueh-Hsuan Chiang 已提交
480
	git_sha := $(FORCE_GIT_SHA)
I
Igor Canadi 已提交
481
else
Y
Yueh-Hsuan Chiang 已提交
482
	git_sha := $(shell git rev-parse HEAD 2>/dev/null)
I
Igor Canadi 已提交
483
endif
484
gen_build_version = sed -e s/@@GIT_SHA@@/$(git_sha)/ -e s/@@GIT_DATE_TIME@@/$(date)/ util/build_version.cc.in
485 486 487 488 489 490

# Record the version of the source that we are compiling.
# We keep a record of the git revision in this file.  It is then built
# as a regular source file as part of the compilation process.
# One can run "strings executable_filename | grep _build_" to find
# the version of the source that we used to build the executable file.
491 492
FORCE:
util/build_version.cc: FORCE
Y
Yueh-Hsuan Chiang 已提交
493 494 495 496 497
	$(AM_V_GEN)rm -f $@-t
	$(AM_V_at)$(gen_build_version) > $@-t
	$(AM_V_at)if test -f $@; then					\
	  cmp -s $@-t $@ && rm -f $@-t || mv -f $@-t $@;		\
	else mv -f $@-t $@; fi
498
endif
499

雷鹏 已提交
500 501
LIBOBJECTS = $(addprefix ${xdir}/, $(LIB_SOURCES:.cc=.o))
LIB_CC_OBJECTS = $(LIBOBJECTS)
L
leipeng 已提交
502

503
ifeq ($(HAVE_POWER8),1)
雷鹏 已提交
504 505
LIBOBJECTS += $(addprefix ${xdir}/, $(LIB_SOURCES_C:.c=.o))
LIBOBJECTS += $(addprefix ${xdir}/, $(LIB_SOURCES_ASM:.S=.o))
506 507
endif

雷鹏 已提交
508 509
LIBOBJECTS += $(addprefix ${xdir}/, $(TOOL_LIB_SOURCES:.cc=.o))
MOCKOBJECTS = $(addprefix ${xdir}/, $(MOCK_LIB_SOURCES:.cc=.o))
J
jorlow@chromium.org 已提交
510

雷鹏 已提交
511 512 513
GTEST = ${xdir}/$(GTEST_DIR)/gtest/gtest-all.o
TESTUTIL = ${xdir}/util/testutil.o
TESTHARNESS = ${xdir}/util/testharness.o $(TESTUTIL) $(MOCKOBJECTS) $(GTEST)
514
VALGRIND_ERROR = 2
515
VALGRIND_VER := $(join $(VALGRIND_VER),valgrind)
516

517
VALGRIND_OPTS = --error-exitcode=$(VALGRIND_ERROR) --leak-check=full
518

雷鹏 已提交
519
BENCHTOOLOBJECTS = $(addprefix ${xdir}/, $(BENCH_LIB_SOURCES:.cc=.o) $(LIBNAME).so) $(TESTUTIL)
520

雷鹏 已提交
521
EXPOBJECTS = $(addprefix ${xdir}/, $(EXP_LIB_SOURCES:.cc=.o)) $(LIBOBJECTS) $(TESTUTIL)
O
omegaga 已提交
522

J
jorlow@chromium.org 已提交
523
TESTS = \
524
	db_basic_test \
E
Ewout Prangsma 已提交
525
	db_encryption_test \
526
	db_test2 \
S
Siying Dong 已提交
527
	external_sst_file_basic_test \
S
Siying Dong 已提交
528 529 530 531 532 533 534 535 536 537
	auto_roll_logger_test \
	bloom_test \
	dynamic_bloom_test \
	c_test \
	checkpoint_test \
	crc32c_test \
	coding_test \
	inlineskiplist_test \
	env_basic_test \
	env_test \
538
	hash_test \
S
Siying Dong 已提交
539 540 541 542 543
	thread_local_test \
	rate_limiter_test \
	perf_context_test \
	iostats_context_test \
	db_wal_test \
544
	db_block_cache_test \
545
	db_test \
Y
Yi Wu 已提交
546
	db_bloom_filter_test \
547
	db_iter_test \
548
	db_iter_stress_test \
549 550
	db_log_iter_test \
	db_compaction_filter_test \
551
	db_compaction_test \
552
	db_dynamic_level_test \
553
	db_flush_test \
554
	db_inplace_update_test \
Y
Yi Wu 已提交
555
	db_iterator_test \
556
	db_memtable_test \
557
	db_merge_operator_test \
558
	db_options_test \
559
	db_range_del_test \
Y
Yi Wu 已提交
560
	db_sst_test \
561
	db_tailing_iter_test \
O
omegaga 已提交
562
	db_io_failure_test \
563
	db_properties_test \
564
	db_table_properties_test \
565
	db_statistics_test \
Y
Yi Wu 已提交
566
	db_write_test \
567
	error_handler_test \
568
	autovector_test \
M
Maysam Yabandeh 已提交
569
	cleanable_test \
570 571 572 573
	column_family_test \
	table_properties_collector_test \
	arena_test \
	block_test \
574
	data_block_hash_index_test \
575 576 577 578 579 580 581
	cache_test \
	corruption_test \
	slice_transform_test \
	dbformat_test \
	fault_injection_test \
	filelock_test \
	filename_test \
582
	file_reader_writer_test \
583 584
	block_based_filter_block_test \
	full_filter_block_test \
M
Maysam Yabandeh 已提交
585
	partitioned_filter_block_test \
586
	hash_table_test \
587 588 589 590 591 592
	histogram_test \
	log_test \
	manual_compaction_test \
	mock_env_test \
	memtable_list_test \
	merge_helper_test \
593
	memory_test \
594 595
	merge_test \
	merger_test \
596
	util_merge_operators_test \
597
	options_file_test \
598 599 600 601
	redis_test \
	reduce_levels_test \
	plain_table_db_test \
	comparator_db_test \
602
	external_sst_file_test \
603 604
	prefix_test \
	skiplist_test \
605
	write_buffer_manager_test \
606
	stringappend_test \
607
	cassandra_format_test \
608
	cassandra_functional_test \
609 610
	cassandra_row_merge_test \
	cassandra_serialize_test \
611
	ttl_test \
O
omegaga 已提交
612
	date_tiered_test \
613 614 615
	backupable_db_test \
	document_db_test \
	json_document_test \
616
	sim_cache_test \
617 618 619 620 621 622 623 624 625 626
	spatial_db_test \
	version_edit_test \
	version_set_test \
	compaction_picker_test \
	version_builder_test \
	file_indexer_test \
	write_batch_test \
	write_batch_with_index_test \
	write_controller_test\
	deletefile_test \
627
	obsolete_files_test \
628 629
	table_test \
	geodb_test \
I
Islam AbdelRahman 已提交
630
	delete_scheduler_test \
631
	options_test \
632
	options_settable_test \
633
	options_util_test \
634
	event_logger_test \
A
Anirban Rahut 已提交
635
	timer_queue_test \
636 637 638 639 640 641
	cuckoo_table_builder_test \
	cuckoo_table_reader_test \
	cuckoo_table_db_test \
	flush_job_test \
	wal_manager_test \
	listener_test \
A
Andres Noetzli 已提交
642
	compaction_iterator_test \
643 644 645
	compaction_job_test \
	thread_list_test \
	sst_dump_test \
O
omegaga 已提交
646
	column_aware_encoding_test \
647 648 649
	compact_files_test \
	optimistic_transaction_test \
	write_callback_test \
650 651
	heap_test \
	compact_on_deletion_collector_test \
A
agiardullo 已提交
652
	compaction_job_stats_test \
653
	option_change_migration_test \
654
	transaction_test \
655
	ldb_cmd_test \
656
	persistent_cache_test \
657
	statistics_test \
658
	lua_test \
Y
Yi Wu 已提交
659
	lru_cache_test \
660
	object_registry_test \
A
Andrew Kryczka 已提交
661
	repair_test \
A
Andrew Kryczka 已提交
662
	env_timed_test \
663
	write_prepared_transaction_test \
664
	write_unprepared_transaction_test \
Z
Zhongyi Xie 已提交
665
	db_universal_compaction_test \
Z
Zhichao Cao 已提交
666
	trace_analyzer_test \
667
	repeatable_thread_test \
奏之章 已提交
668 669
	terark_zip_table_db_test \
	terark_zip_table_reader_test \
670
	range_tombstone_fragmenter_test \
671
	range_del_aggregator_test \
672
	sst_file_reader_test \
673

Y
Yi Wu 已提交
674 675 676 677
PARALLEL_TEST = \
	backupable_db_test \
	db_compaction_filter_test \
	db_compaction_test \
678
	db_merge_operator_test \
679
	db_sst_test \
Y
Yi Wu 已提交
680 681
	db_test \
	db_universal_compaction_test \
682 683
	db_wal_test \
	external_sst_file_test \
Y
Yi Wu 已提交
684 685 686
	fault_injection_test \
	inlineskiplist_test \
	manual_compaction_test \
687 688
	persistent_cache_test \
	table_test \
689
	transaction_test \
690
	write_prepared_transaction_test \
691
	write_unprepared_transaction_test \
Y
Yi Wu 已提交
692

693 694 695 696
# options_settable_test doesn't pass with UBSAN as we use hack in the test
ifdef COMPILE_WITH_UBSAN
        TESTS := $(shell echo $(TESTS) | sed 's/\boptions_settable_test\b//g')
endif
I
Islam AbdelRahman 已提交
697 698 699 700 701 702 703 704
SUBSET := $(TESTS)
ifdef ROCKSDBTESTS_START
        SUBSET := $(shell echo $(SUBSET) | sed 's/^.*$(ROCKSDBTESTS_START)/$(ROCKSDBTESTS_START)/')
endif

ifdef ROCKSDBTESTS_END
        SUBSET := $(shell echo $(SUBSET) | sed 's/$(ROCKSDBTESTS_END).*//')
endif
705

706
TOOLS = \
Y
Yueh-Hsuan Chiang 已提交
707 708 709
	sst_dump \
	db_sanity_test \
	db_stress \
I
Igor Canadi 已提交
710
	write_stress \
Y
Yueh-Hsuan Chiang 已提交
711
	ldb \
L
leipeng 已提交
712
	kvpipe \
713
	remote_compaction_worker_101.cc \
Y
Yueh-Hsuan Chiang 已提交
714 715
	db_repl_stress \
	rocksdb_dump \
Y
Yi Wu 已提交
716 717
	rocksdb_undump \
	blob_dump \
Z
Zhichao Cao 已提交
718
	trace_analyzer \
J
jorlow@chromium.org 已提交
719

720 721 722
TEST_LIBS = \
	librocksdb_env_basic_test.a

S
sdong 已提交
723
# TODO: add back forward_iterator_bench, after making it build in all environemnts.
724
BENCHMARKS = db_bench table_reader_bench cache_bench memtablerep_bench column_aware_encoding_exp persistent_cache_bench range_del_aggregator_bench
J
jorlow@chromium.org 已提交
725

726
# if user didn't config LIBNAME, set the default
727
ifeq ($(LIBNAME),)
728 729
# we should only run rocksdb in production with DEBUG_LEVEL 0
ifeq ($(DEBUG_LEVEL),0)
Y
Yueh-Hsuan Chiang 已提交
730
        LIBNAME=librocksdb
L
leipeng 已提交
731 732 733 734 735
endif
ifeq ($(DEBUG_LEVEL),1)
        LIBNAME=librocksdb_assert
endif
ifeq ($(DEBUG_LEVEL),2)
736 737
        LIBNAME=librocksdb_debug
endif
738
endif
739
LIBRARY = ${LIBNAME}.a
740
TOOLS_LIBRARY = ${LIBNAME}_tools.a
741

742 743 744
ROCKSDB_MAJOR = $(shell egrep "ROCKSDB_MAJOR.[0-9]" include/rocksdb/version.h | cut -d ' ' -f 3)
ROCKSDB_MINOR = $(shell egrep "ROCKSDB_MINOR.[0-9]" include/rocksdb/version.h | cut -d ' ' -f 3)
ROCKSDB_PATCH = $(shell egrep "ROCKSDB_PATCH.[0-9]" include/rocksdb/version.h | cut -d ' ' -f 3)
745

746 747
default: all

748 749 750
#-----------------------------------------------
# Create platform independent shared libraries.
#-----------------------------------------------
751
ifneq ($(PLATFORM_SHARED_EXT),)
H
heyongqiang 已提交
752 753

ifneq ($(PLATFORM_SHARED_VERSIONED),true)
754
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
H
heyongqiang 已提交
755 756
SHARED2 = $(SHARED1)
SHARED3 = $(SHARED1)
757
SHARED4 = $(SHARED1)
H
heyongqiang 已提交
758 759
SHARED = $(SHARED1)
else
760 761
SHARED_MAJOR = $(ROCKSDB_MAJOR)
SHARED_MINOR = $(ROCKSDB_MINOR)
762
SHARED_PATCH = $(ROCKSDB_PATCH)
763
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
764 765 766 767 768 769
ifeq ($(PLATFORM), OS_MACOSX)
SHARED_OSX = $(LIBNAME).$(SHARED_MAJOR)
SHARED2 = $(SHARED_OSX).$(PLATFORM_SHARED_EXT)
SHARED3 = $(SHARED_OSX).$(SHARED_MINOR).$(PLATFORM_SHARED_EXT)
SHARED4 = $(SHARED_OSX).$(SHARED_MINOR).$(SHARED_PATCH).$(PLATFORM_SHARED_EXT)
else
770 771
SHARED2 = $(SHARED1).$(SHARED_MAJOR)
SHARED3 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR)
772
SHARED4 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR).$(SHARED_PATCH)
773
endif
774
SHARED = $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4)
奏之章 已提交
775

L
leipeng 已提交
776 777 778 779 780
$(SHARED1): $(SHARED2)
	ln -fs $(SHARED2) $(SHARED1)
$(SHARED2): $(SHARED3)
	ln -fs $(SHARED3) $(SHARED2)
$(SHARED3): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
781
	ln -fs $(SHARED4) $(SHARED3)
雷鹏 已提交
782 783
$(SHARED4): shared-objects/${xdir}/${SHARED4}
	ln -sf $< $@
奏之章 已提交
784

785
ifeq ($(HAVE_POWER8),1)
雷鹏 已提交
786 787
SHARED_C_OBJECTS = $(addprefix ${xdir}/, $(LIB_SOURCES_C:.c=.o))
SHARED_ASM_OBJECTS = $(addprefix ${xdir}/, $(LIB_SOURCES_ASM:.S=.o))
788 789 790 791
SHARED_C_LIBOBJECTS = $(patsubst %.o,shared-objects/%.o,$(SHARED_C_OBJECTS))
SHARED_ASM_LIBOBJECTS = $(patsubst %.o,shared-objects/%.o,$(SHARED_ASM_OBJECTS))
shared_libobjects = $(patsubst %,shared-objects/%,$(LIB_CC_OBJECTS))
else
792
shared_libobjects = $(patsubst %,shared-objects/%,$(LIBOBJECTS))
793 794
endif

795
CLEAN_FILES += shared-objects
796
shared_all_libobjects = $(shared_libobjects)
797

798 799 800
ifeq ($(HAVE_POWER8),1)
shared-ppc-objects = $(SHARED_C_LIBOBJECTS) $(SHARED_ASM_LIBOBJECTS)

雷鹏 已提交
801
shared-objects/${xdir}/util/crc32c_ppc.o: util/crc32c_ppc.c
802 803
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@

雷鹏 已提交
804
shared-objects/${xdir}/util/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
805 806
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
endif
雷鹏 已提交
807
shared-objects/${xdir}/%.o: %.cc
808 809
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) -c $< -o $@

810 811 812
ifeq ($(HAVE_POWER8),1)
shared_all_libobjects = $(shared_libobjects) $(shared-ppc-objects)
endif
奏之章 已提交
813

雷鹏 已提交
814
shared-objects/${xdir}/$(SHARED1): shared-objects/${xdir}/$(SHARED4)
奏之章 已提交
815
	cd  $(dir $@) ; ln -fs $(notdir $<) $(notdir $@)
雷鹏 已提交
816
shared-objects/${xdir}/$(SHARED2): shared-objects/${xdir}/$(SHARED4)
奏之章 已提交
817
	cd  $(dir $@) ; ln -fs $(notdir $<) $(notdir $@)
雷鹏 已提交
818
shared-objects/${xdir}/$(SHARED3): shared-objects/${xdir}/$(SHARED4)
奏之章 已提交
819 820 821 822
	cd  $(dir $@) ; ln -fs $(notdir $<) $(notdir $@)

endif # PLATFORM_SHARED_VERSIONED

雷鹏 已提交
823
shared-objects/${xdir}/$(SHARED4): $(shared_all_libobjects)
奏之章 已提交
824
	$(CXX) $^ $(PLATFORM_SHARED_LDFLAGS)$(SHARED3) \
雷鹏 已提交
825
		      $(PLATFORM_SHARED_CFLAGS) $(LDFLAGS) $(LINK_STATIC_TERARK) $(TerarkLDFLAGS) -o $@
奏之章 已提交
826 827 828

${xdir}/%.o: %.cc
	@mkdir -p $(dir $@)
829
	$(CXX) -c $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) -o $@ $<
H
heyongqiang 已提交
830 831 832

endif  # PLATFORM_SHARED_EXT

833
.PHONY: blackbox_crash_test check clean coverage crash_test ldb_tests package \
834
	release tags tags0 valgrind_check whitebox_crash_test format static_lib shared_lib all \
Y
Yueh-Hsuan Chiang 已提交
835
	dbg rocksdbjavastatic rocksdbjava install install-static install-shared uninstall \
836
	analyze tools tools_lib
837

838
all: $(LIBRARY) $(BENCHMARKS) tools tools_lib test_libs $(TESTS)
839

840 841
all_but_some_tests: $(LIBRARY) $(BENCHMARKS) tools tools_lib test_libs $(SUBSET)

I
Igor Canadi 已提交
842 843 844 845
static_lib: $(LIBRARY)

shared_lib: $(SHARED)

M
maurice barnum 已提交
846 847
tools: $(TOOLS)

848 849
tools_lib: $(TOOLS_LIBRARY)

850 851
test_libs: $(TEST_LIBS)

M
maurice barnum 已提交
852
dbg: $(LIBRARY) $(BENCHMARKS) tools $(TESTS)
K
Kai Liu 已提交
853

854
# creates static library and programs
855
release:
Y
Yueh-Hsuan Chiang 已提交
856
	$(MAKE) clean
857
	DEBUG_LEVEL=0 $(MAKE) static_lib tools db_bench
K
Kai Liu 已提交
858 859

coverage:
Y
Yueh-Hsuan Chiang 已提交
860 861 862 863
	$(MAKE) clean
	COVERAGEFLAGS="-fprofile-arcs -ftest-coverage" LDFLAGS+="-lgcov" $(MAKE) J=1 all check
	cd coverage && ./coverage_test.sh
        # Delete intermediate files
864
	$(FIND) . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
J
jorlow@chromium.org 已提交
865

Y
Yi Wu 已提交
866 867 868 869 870
ifneq (,$(filter check parallel_check,$(MAKECMDGOALS)),)
# Use /dev/shm if it has the sticky bit set (otherwise, /tmp),
# and create a randomly-named rocksdb.XXXX directory therein.
# We'll use that directory in the "make check" rules.
ifeq ($(TMPD),)
T
Tomas Kolda 已提交
871 872
TMPDIR := $(shell echo $${TMPDIR:-/tmp})
TMPD := $(shell f=/dev/shm; test -k $$f || f=$(TMPDIR);     \
Y
Yi Wu 已提交
873 874 875 876 877 878 879 880 881 882 883 884 885 886
  perl -le 'use File::Temp "tempdir";'					\
    -e 'print tempdir("'$$f'/rocksdb.XXXX", CLEANUP => 0)')
endif
endif

# Run all tests in parallel, accumulating per-test logs in t/log-*.
#
# Each t/run-* file is a tiny generated bourne shell script that invokes one of
# sub-tests. Why use a file for this?  Because that makes the invocation of
# parallel below simpler, which in turn makes the parsing of parallel's
# LOG simpler (the latter is for live monitoring as parallel
# tests run).
#
# Test names are extracted by running tests with --gtest_list_tests.
887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904
# This filter removes the "#"-introduced comments, and expands to
# fully-qualified names by changing input like this:
#
#   DBTest.
#     Empty
#     WriteEmptyBatch
#   MultiThreaded/MultiThreadedDBTest.
#     MultiThreaded/0  # GetParam() = 0
#     MultiThreaded/1  # GetParam() = 1
#
# into this:
#
#   DBTest.Empty
#   DBTest.WriteEmptyBatch
#   MultiThreaded/MultiThreadedDBTest.MultiThreaded/0
#   MultiThreaded/MultiThreadedDBTest.MultiThreaded/1
#

Y
Yi Wu 已提交
905 906 907 908 909 910 911 912 913 914 915
parallel_tests = $(patsubst %,parallel_%,$(PARALLEL_TEST))
.PHONY: gen_parallel_tests $(parallel_tests)
$(parallel_tests): $(PARALLEL_TEST)
	$(AM_V_at)TEST_BINARY=$(patsubst parallel_%,%,$@); \
  TEST_NAMES=` \
    ./$$TEST_BINARY --gtest_list_tests \
    | perl -n \
      -e 's/ *\#.*//;' \
      -e '/^(\s*)(\S+)/; !$$1 and do {$$p=$$2; break};'	\
      -e 'print qq! $$p$$2!'`; \
	for TEST_NAME in $$TEST_NAMES; do \
916
		TEST_SCRIPT=t/run-$$TEST_BINARY-$${TEST_NAME//\//-}; \
Y
Yi Wu 已提交
917 918 919 920 921
		echo "  GEN     " $$TEST_SCRIPT; \
    printf '%s\n' \
      '#!/bin/sh' \
      "d=\$(TMPD)$$TEST_SCRIPT" \
      'mkdir -p $$d' \
922
      "TEST_TMPDIR=\$$d $(DRIVER) ./$$TEST_BINARY --gtest_filter=$$TEST_NAME" \
Y
Yi Wu 已提交
923 924 925 926 927 928 929 930
		> $$TEST_SCRIPT; \
		chmod a=rx $$TEST_SCRIPT; \
	done

gen_parallel_tests:
	$(AM_V_at)mkdir -p t
	$(AM_V_at)rm -f t/run-*
	$(MAKE) $(parallel_tests)
931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948

# Reorder input lines (which are one per test) so that the
# longest-running tests appear first in the output.
# Do this by prefixing each selected name with its duration,
# sort the resulting names, and remove the leading numbers.
# FIXME: the "100" we prepend is a fake time, for now.
# FIXME: squirrel away timings from each run and use them
# (when present) on subsequent runs to order these tests.
#
# Without this reordering, these two tests would happen to start only
# after almost all other tests had completed, thus adding 100 seconds
# to the duration of parallel "make check".  That's the difference
# between 4 minutes (old) and 2m20s (new).
#
# 152.120 PASS t/DBTest.FileCreationRandomFailure
# 107.816 PASS t/DBTest.EncodeDecompressedBlockSizeTest
#
slow_test_regexp = \
Y
Yi Wu 已提交
949
	^.*SnapshotConcurrentAccessTest.*$$|^t/run-table_test-HarnessTest.Randomized$$|^t/run-db_test-.*(?:FileCreationRandomFailure|EncodeDecompressedBlockSizeTest)$$|^.*RecoverFromCorruptedWALWithoutFlush$$
950
prioritize_long_running_tests =						\
Y
Yueh-Hsuan Chiang 已提交
951 952 953
  perl -pe 's,($(slow_test_regexp)),100 $$1,'				\
    | sort -k1,1gr							\
    | sed 's/^[.0-9]* //'
954 955 956 957 958 959

# "make check" uses
# Run with "make J=1 check" to disable parallelism in "make check".
# Run with "make J=200% check" to run two parallel jobs per core.
# The default is to run one job per core (J=100%).
# See "man parallel" for its "-j ..." option.
Y
Yi Wu 已提交
960
J ?= 100%
961

V
Venkatesh Radhakrishnan 已提交
962 963 964
# Use this regexp to select the subset of tests whose names match.
tests-regexp = .

Y
Yi Wu 已提交
965
t_run = $(wildcard t/run-*)
966
.PHONY: check_0
Y
Yi Wu 已提交
967 968
check_0:
	$(AM_V_GEN)export TEST_TMPDIR=$(TMPD); \
Y
Yueh-Hsuan Chiang 已提交
969 970 971
	printf '%s\n' ''						\
	  'To monitor subtest <duration,pass/fail,name>,'		\
	  '  run "make watch-log" in a separate window' '';		\
Y
Yi Wu 已提交
972 973 974 975 976
	test -t 1 && eta=--eta || eta=; \
	{ \
		printf './%s\n' $(filter-out $(PARALLEL_TEST),$(TESTS)); \
		printf '%s\n' $(t_run); \
	} \
Y
Yueh-Hsuan Chiang 已提交
977 978
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
979
	  | build_tools/gnu_parallel -j$(J) --plain --joblog=LOG $$eta --gnu '{} >& t/log-{/}'
S
sdong 已提交
980

981
valgrind-blacklist-regexp = InlineSkipTest.ConcurrentInsert|TransactionStressTest.DeadlockStress|DBCompactionTest.SuggestCompactRangeNoTwoLevel0Compactions|BackupableDBTest.RateLimiting|DBTest.CloseSpeedup|DBTest.ThreadStatusFlush|DBTest.RateLimitingTest|DBTest.EncodeDecompressedBlockSizeTest|FaultInjectionTest.UninstalledCompaction|HarnessTest.Randomized|ExternalSSTFileTest.CompactDuringAddFileRandom|ExternalSSTFileTest.IngestFileWithGlobalSeqnoRandomized|MySQLStyleTransactionTest.TransactionStressTest
982

S
sdong 已提交
983
.PHONY: valgrind_check_0
Y
Yi Wu 已提交
984
valgrind_check_0:
S
sdong 已提交
985 986 987 988 989 990
	$(AM_V_GEN)export TEST_TMPDIR=$(TMPD);				\
	printf '%s\n' ''						\
	  'To monitor subtest <duration,pass/fail,name>,'		\
	  '  run "make watch-log" in a separate window' '';		\
	test -t 1 && eta=--eta || eta=;					\
	{								\
Y
Yi Wu 已提交
991
	  printf './%s\n' $(filter-out $(PARALLEL_TEST) %skiplist_test options_settable_test, $(TESTS));		\
S
sdong 已提交
992 993 994 995
	  printf '%s\n' $(t_run);					\
	}								\
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
996
	  | grep -E -v '$(valgrind-blacklist-regexp)'					\
997
	  | build_tools/gnu_parallel -j$(J) --plain --joblog=LOG $$eta --gnu \
998 999
	  '(if [[ "{}" == "./"* ]] ; then $(DRIVER) {}; else {}; fi) ' \
	  '>& t/valgrind_log-{/}'
1000 1001

CLEAN_FILES += t LOG $(TMPD)
1002

1003 1004 1005 1006 1007 1008 1009 1010
# When running parallel "make check", you can monitor its progress
# from another window.
# Run "make watch_LOG" to show the duration,PASS/FAIL,name of parallel
# tests as they are being run.  We sort them so that longer-running ones
# appear at the top of the list and any failing tests remain at the top
# regardless of their duration. As with any use of "watch", hit ^C to
# interrupt.
watch-log:
1011
	$(WATCH) --interval=0 'sort -k7,7nr -k4,4gr LOG|$(quoted_perl_command)'
1012

I
Igor Canadi 已提交
1013
# If J != 1 and GNU parallel is installed, run the tests in parallel,
1014 1015
# via the check_0 rule above.  Otherwise, run them sequentially.
check: all
Y
Yi Wu 已提交
1016
	$(MAKE) gen_parallel_tests
Y
Yueh-Hsuan Chiang 已提交
1017
	$(AM_V_GEN)if test "$(J)" != 1                                  \
1018
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
Y
Yueh-Hsuan Chiang 已提交
1019 1020 1021 1022 1023 1024 1025 1026
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
	    $(MAKE) T="$$t" TMPD=$(TMPD) check_0;                       \
	else                                                            \
	    for t in $(TESTS); do                                       \
	      echo "===== Running $$t"; ./$$t || exit 1; done;          \
	fi
	rm -rf $(TMPD)
T
Tomas Kolda 已提交
1027
ifneq ($(PLATFORM), OS_AIX)
I
Islam AbdelRahman 已提交
1028
ifeq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yueh-Hsuan Chiang 已提交
1029 1030
	python tools/ldb_test.py
	sh tools/rocksdb_dump_test.sh
I
Islam AbdelRahman 已提交
1031
endif
T
Tomas Kolda 已提交
1032
endif
1033

S
Siying Dong 已提交
1034 1035
# TODO add ldb_tests
check_some: $(SUBSET)
Y
Yueh-Hsuan Chiang 已提交
1036
	for t in $(SUBSET); do echo "===== Running $$t"; ./$$t || exit 1; done
1037 1038

.PHONY: ldb_tests
1039
ldb_tests: ldb
Y
Yueh-Hsuan Chiang 已提交
1040
	python tools/ldb_test.py
1041

I
Igor Canadi 已提交
1042
crash_test: whitebox_crash_test blackbox_crash_test
1043 1044

blackbox_crash_test: db_stress
1045
	python -u tools/db_crashtest.py --simple blackbox $(CRASH_TEST_EXT_ARGS)
1046
	python -u tools/db_crashtest.py --enable_atomic_flush blackbox $(CRASH_TEST_EXT_ARGS)
1047
	python -u tools/db_crashtest.py blackbox $(CRASH_TEST_EXT_ARGS)
1048

1049 1050 1051 1052
ifeq ($(CRASH_TEST_KILL_ODD),)
  CRASH_TEST_KILL_ODD=888887
endif

1053
whitebox_crash_test: db_stress
1054
	python -u tools/db_crashtest.py --simple whitebox --random_kill_odd \
1055 1056
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
	python -u tools/db_crashtest.py --enable_atomic_flush whitebox  --random_kill_odd \
1057
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
1058
	python -u tools/db_crashtest.py whitebox  --random_kill_odd \
1059
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
1060

I
Igor Canadi 已提交
1061
asan_check:
Y
Yueh-Hsuan Chiang 已提交
1062 1063 1064
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) check -j32
	$(MAKE) clean
1065 1066

asan_crash_test:
Y
Yueh-Hsuan Chiang 已提交
1067 1068 1069
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test
	$(MAKE) clean
I
Igor Canadi 已提交
1070

1071 1072 1073 1074 1075 1076 1077 1078 1079 1080
ubsan_check:
	$(MAKE) clean
	COMPILE_WITH_UBSAN=1 $(MAKE) check -j32
	$(MAKE) clean

ubsan_crash_test:
	$(MAKE) clean
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test
	$(MAKE) clean

1081
valgrind_test:
1082
	ROCKSDB_VALGRIND_RUN=1 DISABLE_JEMALLOC=1 $(MAKE) valgrind_check
1083

I
Igor Canadi 已提交
1084
valgrind_check: $(TESTS)
1085
	$(MAKE) DRIVER="$(VALGRIND_VER) $(VALGRIND_OPTS)" gen_parallel_tests
S
sdong 已提交
1086
	$(AM_V_GEN)if test "$(J)" != 1                                  \
1087
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
S
sdong 已提交
1088 1089
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
Y
Yi Wu 已提交
1090
      $(MAKE) TMPD=$(TMPD)                                        \
S
sdong 已提交
1091 1092 1093 1094 1095 1096 1097 1098 1099 1100
      DRIVER="$(VALGRIND_VER) $(VALGRIND_OPTS)" valgrind_check_0; \
	else                                                            \
		for t in $(filter-out %skiplist_test options_settable_test,$(TESTS)); do \
			$(VALGRIND_VER) $(VALGRIND_OPTS) ./$$t; \
			ret_code=$$?; \
			if [ $$ret_code -ne 0 ]; then \
				exit $$ret_code; \
			fi; \
		done; \
	fi
1101

1102 1103 1104 1105 1106 1107 1108

ifneq ($(PAR_TEST),)
parloop:
	ret_bad=0;							\
	for t in $(PAR_TEST); do		\
		echo "===== Running $$t in parallel $(NUM_PAR)";\
		if [ $(db_test) -eq 1 ]; then \
1109
			seq $(J) | v="$$t" build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{};  export TEST_TMPDIR=$$s;' \
1110 1111
				'timeout 2m ./db_test --gtest_filter=$$v >> $$s/log-{} 2>1'; \
		else\
1112
			seq $(J) | v="./$$t" build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{};' \
1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123
			     'export TEST_TMPDIR=$$s; timeout 10m $$v >> $$s/log-{} 2>1'; \
		fi; \
		ret_code=$$?; \
		if [ $$ret_code -ne 0 ]; then \
			ret_bad=$$ret_code; \
			echo $$t exited with $$ret_code; \
		fi; \
	done; \
	exit $$ret_bad;
endif

Y
Yi Wu 已提交
1124 1125 1126 1127 1128 1129 1130
test_names = \
  ./db_test --gtest_list_tests						\
    | perl -n								\
      -e 's/ *\#.*//;'							\
      -e '/^(\s*)(\S+)/; !$$1 and do {$$p=$$2; break};'			\
      -e 'print qq! $$p$$2!'

1131 1132
parallel_check: $(TESTS)
	$(AM_V_GEN)if test "$(J)" > 1                                  \
1133
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
1134 1135 1136 1137 1138 1139 1140 1141 1142
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
	    echo Running in parallel $(J);			\
	else                                                            \
	    echo "Need to have GNU Parallel and J > 1"; exit 1;		\
	fi;								\
	ret_bad=0;							\
	echo $(J);\
	echo Test Dir: $(TMPD); \
1143
        seq $(J) | build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{}; rm -rf $$s; mkdir $$s'; \
1144
	$(MAKE)  PAR_TEST="$(shell $(test_names))" TMPD=$(TMPD) \
1145 1146 1147 1148
		J=$(J) db_test=1 parloop; \
	$(MAKE) PAR_TEST="$(filter-out db_test, $(TESTS))" \
		TMPD=$(TMPD) J=$(J) db_test=0 parloop;

1149
analyze: clean
Y
Yueh-Hsuan Chiang 已提交
1150 1151 1152 1153
	$(CLANG_SCAN_BUILD) --use-analyzer=$(CLANG_ANALYZER) \
		--use-c++=$(CXX) --use-cc=$(CC) --status-bugs \
		-o $(CURDIR)/scan_build_report \
		$(MAKE) dbg
1154

1155 1156
CLEAN_FILES += unity.cc
unity.cc: Makefile
Y
Yueh-Hsuan Chiang 已提交
1157 1158
	rm -f $@ $@-t
	for source_file in $(LIB_SOURCES); do \
E
Evan Shaw 已提交
1159
		echo "#include \"$$source_file\"" >> $@-t; \
Y
Yueh-Hsuan Chiang 已提交
1160 1161 1162
	done
	chmod a=r $@-t
	mv $@-t $@
M
miguelportilla 已提交
1163

E
Evan Shaw 已提交
1164 1165 1166 1167
unity.a: unity.o
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ unity.o

1168 1169

TOOLLIBOBJECTS = $(TOOL_LIB_SOURCES:.cc=.o)
I
Igor Canadi 已提交
1170
# try compiling db_test with unity
1171
unity_test: db/db_test.o db/db_test_util.o $(TESTHARNESS) $(TOOLLIBOBJECTS) unity.a
I
Igor Canadi 已提交
1172 1173 1174
	$(AM_LINK)
	./unity_test

E
Evan Shaw 已提交
1175 1176
rocksdb.h rocksdb.cc: build_tools/amalgamate.py Makefile $(LIB_SOURCES) unity.cc
	build_tools/amalgamate.py -I. -i./include unity.cc -x include/rocksdb/c.h -H rocksdb.h -o rocksdb.cc
M
miguelportilla 已提交
1177

J
jorlow@chromium.org 已提交
1178
clean:
Y
Yueh-Hsuan Chiang 已提交
1179 1180
	rm -f $(BENCHMARKS) $(TOOLS) $(TESTS) $(LIBRARY) $(SHARED)
	rm -rf $(CLEAN_FILES) ios-x86 ios-arm scan_build_report
1181 1182
	$(FIND) . -name "*.[oda]" -exec rm -f {} \;
	$(FIND) . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
S
Sagar Vemuri 已提交
1183
	rm -rf bzip2* snappy* zlib* lz4* zstd*
L
leipeng 已提交
1184
	rm -rf librocksdb*
Y
Yi Wu 已提交
1185
	cd java; $(MAKE) clean
1186

1187
tags:
1188
	ctags -R .
1189
	cscope -b `$(FIND) . -name '*.cc'` `$(FIND) . -name '*.h'` `$(FIND) . -name '*.c'`
L
Leonidas Galanis 已提交
1190
	ctags -e -R -o etags *
1191

1192 1193 1194 1195 1196 1197 1198
tags0:
	ctags -R .
	cscope -b `$(FIND) . -name '*.cc' -and ! -name '*_test.cc'` \
		  `$(FIND) . -name '*.c' -and ! -name '*_test.c'` \
		  `$(FIND) . -name '*.h' -and ! -name '*_test.h'`
	ctags -e -R -o etags *

1199
format:
Y
Yueh-Hsuan Chiang 已提交
1200
	build_tools/format-diff.sh
1201

1202
package:
Y
Yueh-Hsuan Chiang 已提交
1203
	bash build_tools/make_package.sh $(SHARED_MAJOR).$(SHARED_MINOR)
1204

1205 1206 1207
# ---------------------------------------------------------------------------
# 	Unit tests and tools
# ---------------------------------------------------------------------------
1208
$(LIBRARY): $(LIBOBJECTS)
Y
Yueh-Hsuan Chiang 已提交
1209 1210
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(LIBOBJECTS)
雷鹏 已提交
1211 1212
ifeq (${BUNDLE_ALL_TERARK_STATIC},1)
	mv $@ orgin-$@
1213
	ln -s ${TERARK_CORE_PKG_DIR}/lib_static/libterark-{idx,zbs,fsa,core}-${DBG_OR_RLS}.a .
雷鹏 已提交
1214 1215
	(\
	echo create $@; \
1216
	echo addlib libterark-idx-${DBG_OR_RLS}.a; \
雷鹏 已提交
1217 1218 1219 1220 1221 1222 1223
	echo addlib libterark-zbs-${DBG_OR_RLS}.a; \
	echo addlib libterark-fsa-${DBG_OR_RLS}.a; \
	echo addlib libterark-core-${DBG_OR_RLS}.a; \
	echo addlib orgin-$@; \
	echo save; \
	echo end; \
	) | ar -M
1224
	rm -f libterark-{idx,zbs,fsa,core}-${DBG_OR_RLS}.a
雷鹏 已提交
1225
endif
J
jorlow@chromium.org 已提交
1226

1227
$(TOOLS_LIBRARY): $(BENCH_LIB_SOURCES:.cc=.o) $(TOOL_LIB_SOURCES:.cc=.o) $(LIB_SOURCES:.cc=.o) $(TESTUTIL) $(ANALYZER_LIB_SOURCES:.cc=.o)
1228 1229 1230
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1231
librocksdb_env_basic_test.a: env/env_basic_test.o $(LIBOBJECTS) $(TESTHARNESS)
1232 1233 1234
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1235
db_bench: tools/db_bench.o $(BENCHTOOLOBJECTS)
Y
Yueh-Hsuan Chiang 已提交
1236
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1237

1238 1239 1240
trace_analyzer: tools/trace_analyzer.o $(ANALYZETOOLOBJECTS) $(LIBOBJECTS)
	$(AM_LINK)

1241
cache_bench: cache/cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1242
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1243

1244 1245 1246
persistent_cache_bench: utilities/persistent_cache/persistent_cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

1247
memtablerep_bench: memtable/memtablerep_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1248
	$(AM_LINK)
A
Ameya Gupte 已提交
1249

1250
db_stress: tools/db_stress.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1251
	$(AM_LINK)
1252

I
Igor Canadi 已提交
1253 1254 1255
write_stress: tools/write_stress.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

I
Igor Canadi 已提交
1256
db_sanity_test: tools/db_sanity_test.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1257
	$(AM_LINK)
1258

1259
db_repl_stress: tools/db_repl_stress.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1260
	$(AM_LINK)
1261

J
jorlow@chromium.org 已提交
1262
arena_test: util/arena_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1263
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1264

K
kailiu 已提交
1265
autovector_test: util/autovector_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1266
	$(AM_LINK)
K
kailiu 已提交
1267

1268
column_family_test: db/column_family_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1269
	$(AM_LINK)
1270

K
kailiu 已提交
1271
table_properties_collector_test: db/table_properties_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1272
	$(AM_LINK)
1273

S
Sanjay Ghemawat 已提交
1274
bloom_test: util/bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1275
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
1276

1277
dynamic_bloom_test: util/dynamic_bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1278
	$(AM_LINK)
1279

1280
c_test: db/c_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1281
	$(AM_LINK)
1282

1283
cache_test: cache/cache_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1284
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1285 1286

coding_test: util/coding_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1287
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1288

1289 1290 1291
hash_test: util/hash_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1292 1293 1294
option_change_migration_test: utilities/option_change_migration/option_change_migration_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1295
stringappend_test: utilities/merge_operators/string_append/stringappend_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1296
	$(AM_LINK)
1297

1298
cassandra_format_test: utilities/cassandra/cassandra_format_test.o utilities/cassandra/test_utils.o $(LIBOBJECTS) $(TESTHARNESS)
1299 1300
	$(AM_LINK)

1301
cassandra_functional_test: utilities/cassandra/cassandra_functional_test.o utilities/cassandra/test_utils.o $(LIBOBJECTS) $(TESTHARNESS)
1302 1303
	$(AM_LINK)

1304
cassandra_row_merge_test: utilities/cassandra/cassandra_row_merge_test.o utilities/cassandra/test_utils.o $(LIBOBJECTS) $(TESTHARNESS)
1305 1306
	$(AM_LINK)

1307
cassandra_serialize_test: utilities/cassandra/cassandra_serialize_test.o $(LIBOBJECTS) $(TESTHARNESS)
1308 1309
	$(AM_LINK)

1310
redis_test: utilities/redis/redis_lists_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1311
	$(AM_LINK)
1312

1313 1314 1315
hash_table_test: utilities/persistent_cache/hash_table_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1316
histogram_test: monitoring/histogram_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1317
	$(AM_LINK)
A
Abhishek Kona 已提交
1318

雷鹏 已提交
1319
thread_local_test: util/thread_local_test.o $(SHARED1) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1320
	$(AM_LINK)
L
Lei Jin 已提交
1321

J
jorlow@chromium.org 已提交
1322
corruption_test: db/corruption_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1323
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1324 1325

crc32c_test: util/crc32c_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1326
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1327

1328
slice_transform_test: util/slice_transform_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1329
	$(AM_LINK)
1330

1331
db_basic_test: db/db_basic_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
E
Ewout Prangsma 已提交
1332 1333 1334
	$(AM_LINK)

db_encryption_test: db/db_encryption_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1335 1336
	$(AM_LINK)

1337
db_test: db/db_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1338
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1339

1340 1341 1342
db_test2: db/db_test2.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1343 1344 1345
db_block_cache_test: db/db_block_cache_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yi Wu 已提交
1346 1347 1348
db_bloom_filter_test: db/db_bloom_filter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1349
db_log_iter_test: db/db_log_iter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1350
	$(AM_LINK)
1351

1352
db_compaction_filter_test: db/db_compaction_filter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1353 1354
	$(AM_LINK)

1355
db_compaction_test: db/db_compaction_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1356 1357
	$(AM_LINK)

1358
db_dynamic_level_test: db/db_dynamic_level_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1359 1360
	$(AM_LINK)

1361 1362 1363
db_flush_test: db/db_flush_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1364
db_inplace_update_test: db/db_inplace_update_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1365 1366
	$(AM_LINK)

Y
Yi Wu 已提交
1367 1368 1369
db_iterator_test: db/db_iterator_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1370 1371 1372
db_memtable_test: db/db_memtable_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1373 1374 1375
db_merge_operator_test: db/db_merge_operator_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1376 1377 1378
db_options_test: db/db_options_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1379 1380 1381
db_range_del_test: db/db_range_del_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yi Wu 已提交
1382 1383 1384
db_sst_test: db/db_sst_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1385 1386 1387
db_statistics_test: db/db_statistics_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yi Wu 已提交
1388 1389 1390
db_write_test: db/db_write_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1391 1392 1393
error_handler_test: db/error_handler_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

S
Siying Dong 已提交
1394 1395 1396
external_sst_file_basic_test: db/external_sst_file_basic_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1397 1398 1399
external_sst_file_test: db/external_sst_file_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1400
db_tailing_iter_test: db/db_tailing_iter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1401 1402
	$(AM_LINK)

S
Stanislau Hlebik 已提交
1403
db_iter_test: db/db_iter_test.o $(LIBOBJECTS) $(TESTHARNESS)
1404
	$(AM_LINK)
S
Stanislau Hlebik 已提交
1405

1406
db_universal_compaction_test: db/db_universal_compaction_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1407 1408
	$(AM_LINK)

1409
db_wal_test: db/db_wal_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
S
sdong 已提交
1410 1411
	$(AM_LINK)

O
omegaga 已提交
1412 1413 1414
db_io_failure_test: db/db_io_failure_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1415 1416 1417
db_properties_test: db/db_properties_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1418 1419 1420
db_table_properties_test: db/db_table_properties_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1421
log_write_bench: util/log_write_bench.o $(LIBOBJECTS) $(TESTHARNESS)
D
dx9 已提交
1422
	$(AM_LINK) $(PROFILING_FLAGS)
1423

S
Siying Dong 已提交
1424
plain_table_db_test: db/plain_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1425
	$(AM_LINK)
S
Siying Dong 已提交
1426

1427
comparator_db_test: db/comparator_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1428
	$(AM_LINK)
1429

1430
table_reader_bench: table/table_reader_bench.o $(LIBOBJECTS) $(TESTHARNESS)
D
dx9 已提交
1431
	$(AM_LINK) $(PROFILING_FLAGS)
1432

1433
perf_context_test: db/perf_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
奏之章 已提交
1434
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(TerarkLDFLAGS)
1435

H
Haobo Xu 已提交
1436
prefix_test: db/prefix_test.o $(LIBOBJECTS) $(TESTHARNESS)
奏之章 已提交
1437
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(TerarkLDFLAGS)
H
Haobo Xu 已提交
1438

I
Igor Canadi 已提交
1439
backupable_db_test: utilities/backupable/backupable_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1440
	$(AM_LINK)
I
Igor Canadi 已提交
1441

1442 1443 1444
checkpoint_test: utilities/checkpoint/checkpoint_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
1445
document_db_test: utilities/document/document_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1446
	$(AM_LINK)
I
Igor Canadi 已提交
1447

I
Igor Canadi 已提交
1448
json_document_test: utilities/document/json_document_test.o $(LIBOBJECTS) $(TESTHARNESS)
1449
	$(AM_LINK)
I
Igor Canadi 已提交
1450

1451 1452 1453
sim_cache_test: utilities/simulator_cache/sim_cache_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
1454
spatial_db_test: utilities/spatialdb/spatial_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1455
	$(AM_LINK)
I
Igor Canadi 已提交
1456

S
Sage Weil 已提交
1457 1458 1459
env_mirror_test: utilities/env_mirror_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
Andrew Kryczka 已提交
1460 1461 1462
env_timed_test: utilities/env_timed_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1463 1464 1465 1466 1467
ifdef ROCKSDB_USE_LIBRADOS
env_librados_test: utilities/env_librados_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(COVERAGEFLAGS)
endif

1468
object_registry_test: utilities/object_registry_test.o $(LIBOBJECTS) $(TESTHARNESS)
1469 1470
	$(AM_LINK)

1471
ttl_test: utilities/ttl/ttl_test.o $(LIBOBJECTS) $(TESTHARNESS)
1472
	$(AM_LINK)
1473

O
omegaga 已提交
1474 1475 1476
date_tiered_test: utilities/date_tiered/date_tiered_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1477
write_batch_with_index_test: utilities/write_batch_with_index/write_batch_with_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
1478
	$(AM_LINK)
1479

I
Igor Canadi 已提交
1480
flush_job_test: db/flush_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
1481
	$(AM_LINK)
A
Andres Noetzli 已提交
1482 1483 1484

compaction_iterator_test: db/compaction_iterator_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)
I
Igor Canadi 已提交
1485

I
Igor Canadi 已提交
1486
compaction_job_test: db/compaction_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
1487
	$(AM_LINK)
I
Igor Canadi 已提交
1488

1489 1490 1491
compaction_job_stats_test: db/compaction_job_stats_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1492 1493 1494
compact_on_deletion_collector_test: utilities/table_properties_collectors/compact_on_deletion_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
1495
wal_manager_test: db/wal_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
1496
	$(AM_LINK)
I
Igor Canadi 已提交
1497

J
jorlow@chromium.org 已提交
1498
dbformat_test: db/dbformat_test.o $(LIBOBJECTS) $(TESTHARNESS)
1499
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1500

1501
env_basic_test: env/env_basic_test.o $(LIBOBJECTS) $(TESTHARNESS)
1502 1503
	$(AM_LINK)

1504
env_test: env/env_test.o $(LIBOBJECTS) $(TESTHARNESS)
1505
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1506

1507
fault_injection_test: db/fault_injection_test.o $(LIBOBJECTS) $(TESTHARNESS)
1508
	$(AM_LINK)
1509

A
Andrew Kryczka 已提交
1510
rate_limiter_test: util/rate_limiter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1511
	$(AM_LINK)
L
Lei Jin 已提交
1512

I
Islam AbdelRahman 已提交
1513 1514 1515
delete_scheduler_test: util/delete_scheduler_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
jorlow@chromium.org 已提交
1516
filename_test: db/filename_test.o $(LIBOBJECTS) $(TESTHARNESS)
1517
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1518

1519 1520 1521
file_reader_writer_test: util/file_reader_writer_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1522
block_based_filter_block_test: table/block_based_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
1523
	$(AM_LINK)
1524 1525

full_filter_block_test: table/full_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
1526
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
1527

M
Maysam Yabandeh 已提交
1528 1529 1530
partitioned_filter_block_test: table/partitioned_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
jorlow@chromium.org 已提交
1531
log_test: db/log_test.o $(LIBOBJECTS) $(TESTHARNESS)
M
Maysam Yabandeh 已提交
1532 1533 1534
	$(AM_LINK)

cleanable_test: table/cleanable_test.o $(LIBOBJECTS) $(TESTHARNESS)
1535
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1536 1537

table_test: table/table_test.o $(LIBOBJECTS) $(TESTHARNESS)
1538
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1539

D
Dhruba Borthakur 已提交
1540
block_test: table/block_test.o $(LIBOBJECTS) $(TESTHARNESS)
1541
	$(AM_LINK)
D
Dhruba Borthakur 已提交
1542

1543 1544 1545
data_block_hash_index_test: table/data_block_hash_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1546
inlineskiplist_test: memtable/inlineskiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
N
Nathan Bronson 已提交
1547 1548
	$(AM_LINK)

1549
skiplist_test: memtable/skiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
1550
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1551

1552 1553 1554
write_buffer_manager_test: memtable/write_buffer_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
jorlow@chromium.org 已提交
1555
version_edit_test: db/version_edit_test.o $(LIBOBJECTS) $(TESTHARNESS)
1556
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1557

1558
version_set_test: db/version_set_test.o $(LIBOBJECTS) $(TESTHARNESS)
1559
	$(AM_LINK)
1560

S
sdong 已提交
1561
compaction_picker_test: db/compaction_picker_test.o $(LIBOBJECTS) $(TESTHARNESS)
1562
	$(AM_LINK)
S
sdong 已提交
1563

S
sdong 已提交
1564
version_builder_test: db/version_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
1565
	$(AM_LINK)
S
sdong 已提交
1566

1567
file_indexer_test: db/file_indexer_test.o $(LIBOBJECTS) $(TESTHARNESS)
1568
	$(AM_LINK)
1569

1570
reduce_levels_test: tools/reduce_levels_test.o $(LIBOBJECTS) $(TESTHARNESS)
1571
	$(AM_LINK)
1572

J
jorlow@chromium.org 已提交
1573
write_batch_test: db/write_batch_test.o $(LIBOBJECTS) $(TESTHARNESS)
1574
	$(AM_LINK)
1575

1576
write_controller_test: db/write_controller_test.o $(LIBOBJECTS) $(TESTHARNESS)
1577
	$(AM_LINK)
1578

1579 1580 1581
merge_helper_test: db/merge_helper_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1582 1583 1584
memory_test: utilities/memory/memory_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
Jim Paton 已提交
1585
merge_test: db/merge_test.o $(LIBOBJECTS) $(TESTHARNESS)
1586
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1587

I
Igor Canadi 已提交
1588
merger_test: table/merger_test.o $(LIBOBJECTS) $(TESTHARNESS)
1589
	$(AM_LINK)
I
Igor Canadi 已提交
1590

1591 1592 1593
util_merge_operators_test: utilities/util_merge_operators_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1594 1595 1596
options_file_test: db/options_file_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1597
deletefile_test: db/deletefile_test.o $(LIBOBJECTS) $(TESTHARNESS)
1598
	$(AM_LINK)
1599

1600 1601 1602
obsolete_files_test: db/obsolete_files_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1603
geodb_test: utilities/geodb/geodb_test.o $(LIBOBJECTS) $(TESTHARNESS)
1604
	$(AM_LINK)
1605

1606 1607 1608 1609 1610 1611
rocksdb_dump: tools/dump/rocksdb_dump.o $(LIBOBJECTS)
	$(AM_LINK)

rocksdb_undump: tools/dump/rocksdb_undump.o $(LIBOBJECTS)
	$(AM_LINK)

1612
cuckoo_table_builder_test: table/cuckoo_table_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
1613
	$(AM_LINK)
1614

I
Igor Canadi 已提交
1615
cuckoo_table_reader_test: table/cuckoo_table_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
1616
	$(AM_LINK)
1617

1618
cuckoo_table_db_test: db/cuckoo_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1619
	$(AM_LINK)
1620

1621
listener_test: db/listener_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1622
	$(AM_LINK)
1623

Y
Yueh-Hsuan Chiang 已提交
1624
thread_list_test: util/thread_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
1625
	$(AM_LINK)
Y
Yueh-Hsuan Chiang 已提交
1626

1627 1628 1629
compact_files_test: db/compact_files_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1630
options_test: options/options_test.o $(LIBOBJECTS) $(TESTHARNESS)
1631 1632
	$(AM_LINK)

1633
options_settable_test: options/options_settable_test.o $(LIBOBJECTS) $(TESTHARNESS)
1634
	$(AM_LINK)
1635

1636 1637 1638
options_util_test: utilities/options/options_util_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1639 1640 1641
db_bench_tool_test: tools/db_bench_tool_test.o $(BENCHTOOLOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1642
trace_analyzer_test: tools/trace_analyzer_test.o $(LIBOBJECTS) $(ANALYZETOOLOBJECTS) $(TESTHARNESS)
Z
Zhichao Cao 已提交
1643 1644
	$(AM_LINK)

I
Igor Canadi 已提交
1645 1646 1647
event_logger_test: util/event_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
Anirban Rahut 已提交
1648 1649 1650
timer_queue_test: util/timer_queue_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1651
sst_dump_test: tools/sst_dump_test.o $(LIBOBJECTS) $(TESTHARNESS)
1652
	$(AM_LINK)
1653

O
omegaga 已提交
1654 1655 1656
column_aware_encoding_test: utilities/column_aware_encoding_test.o $(TESTHARNESS) $(EXPOBJECTS)
	$(AM_LINK)

A
agiardullo 已提交
1657 1658 1659
optimistic_transaction_test: utilities/transactions/optimistic_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1660
mock_env_test : env/mock_env_test.o $(LIBOBJECTS) $(TESTHARNESS)
1661
	$(AM_LINK)
1662

1663
manual_compaction_test: db/manual_compaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
1664
	$(AM_LINK)
1665

1666
filelock_test: util/filelock_test.o $(LIBOBJECTS) $(TESTHARNESS)
1667
	$(AM_LINK)
K
Kai Liu 已提交
1668

1669
auto_roll_logger_test: util/auto_roll_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
1670
	$(AM_LINK)
1671

A
agiardullo 已提交
1672 1673 1674
memtable_list_test: db/memtable_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
agiardullo 已提交
1675 1676 1677
write_callback_test: db/write_callback_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

奏之章 已提交
1678
heap_test: util/heap_test.o $(GTEST) ${LIBNAME}.so
1679 1680
	$(AM_LINK)

A
agiardullo 已提交
1681 1682 1683
transaction_test: utilities/transactions/transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1684 1685 1686
write_prepared_transaction_test: utilities/transactions/write_prepared_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1687 1688 1689
write_unprepared_transaction_test: utilities/transactions/write_unprepared_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

L
leipeng 已提交
1690
sst_dump: ${xdir}/tools/sst_dump.o $(LIBOBJECTS) ${LIBNAME}.so
1691
	$(AM_LINK)
1692

L
leipeng 已提交
1693
blob_dump: ${xdir}/tools/blob_dump.o $(LIBOBJECTS)
Y
Yi Wu 已提交
1694 1695
	$(AM_LINK)

O
omegaga 已提交
1696 1697 1698
column_aware_encoding_exp: utilities/column_aware_encoding_exp.o $(EXPOBJECTS)
	$(AM_LINK)

A
Andrew Kryczka 已提交
1699 1700 1701
repair_test: db/repair_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

L
leipeng 已提交
1702
ldb_cmd_test: ${xdir}/tools/ldb_cmd_test.o $(LIBOBJECTS) $(TESTHARNESS) ${LIBNAME}.so
1703 1704
	$(AM_LINK)

L
leipeng.tk 已提交
1705
ldb: ${xdir}/tools/ldb.o $(SHARED1)
1706
	$(AM_LINK)
1707

L
leipeng 已提交
1708
kvpipe: ${xdir}/tools/kvpipe.o ${SHARED1}
1709 1710
	$(AM_LINK)

1711 1712 1713
remote_compaction_worker_101: ${xdir}/tools/remote_compaction_worker_101.o ${SHARED1}
	$(AM_LINK)

L
leipeng 已提交
1714
multi_get: ${xdir}/tools/multi_get.o ${SHARED1}
1715
	$(AM_LINK)
1716

1717
iostats_context_test: monitoring/iostats_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
奏之章 已提交
1718
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(TerarkLDFLAGS)
1719

1720 1721 1722
persistent_cache_test: utilities/persistent_cache/persistent_cache_test.o  db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1723
statistics_test: monitoring/statistics_test.o $(LIBOBJECTS) $(TESTHARNESS)
1724 1725
	$(AM_LINK)

1726
lru_cache_test: cache/lru_cache_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yi Wu 已提交
1727 1728
	$(AM_LINK)

1729 1730
lua_test: utilities/lua/rocks_lua_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)
Y
Yi Wu 已提交
1731

A
Andrew Kryczka 已提交
1732 1733 1734
range_del_aggregator_test: db/range_del_aggregator_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1735 1736 1737
range_del_aggregator_bench: db/range_del_aggregator_bench.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

1738 1739 1740
repeatable_thread_test: util/repeatable_thread_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

奏之章 已提交
1741 1742 1743 1744
terark_zip_table_db_test: db/terark_zip_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

terark_zip_table_reader_test: table/terark_zip_table_reader_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS) ${LIBNAME}.so
Z
ZhaoMing 已提交
1745

1746 1747 1748
range_tombstone_fragmenter_test: db/range_tombstone_fragmenter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1749
sst_file_reader_test: table/sst_file_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
奏之章 已提交
1750 1751
	$(AM_LINK)

I
Igor Canadi 已提交
1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765
#-------------------------------------------------
# make install related stuff
INSTALL_PATH ?= /usr/local

uninstall:
	rm -rf $(INSTALL_PATH)/include/rocksdb \
	  $(INSTALL_PATH)/lib/$(LIBRARY) \
	  $(INSTALL_PATH)/lib/$(SHARED4) \
	  $(INSTALL_PATH)/lib/$(SHARED3) \
	  $(INSTALL_PATH)/lib/$(SHARED2) \
	  $(INSTALL_PATH)/lib/$(SHARED1)

install-headers:
	install -d $(INSTALL_PATH)/lib
1766
	for header_dir in `$(FIND) "include/rocksdb" -type d`; do \
I
Igor Canadi 已提交
1767 1768
		install -d $(INSTALL_PATH)/$$header_dir; \
	done
1769
	for header in `$(FIND) "include/rocksdb" -type f -name *.h`; do \
I
Igor Canadi 已提交
1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783
		install -C -m 644 $$header $(INSTALL_PATH)/$$header; \
	done

install-static: install-headers $(LIBRARY)
	install -C -m 755 $(LIBRARY) $(INSTALL_PATH)/lib

install-shared: install-headers $(SHARED4)
	install -C -m 755 $(SHARED4) $(INSTALL_PATH)/lib && \
		ln -fs $(SHARED4) $(INSTALL_PATH)/lib/$(SHARED3) && \
		ln -fs $(SHARED4) $(INSTALL_PATH)/lib/$(SHARED2) && \
		ln -fs $(SHARED4) $(INSTALL_PATH)/lib/$(SHARED1)

# install static by default + install shared if it exists
install: install-static
I
Igor Canadi 已提交
1784
	[ -e $(SHARED4) ] && $(MAKE) install-shared || :
I
Igor Canadi 已提交
1785 1786 1787 1788

#-------------------------------------------------


1789 1790 1791 1792
# ---------------------------------------------------------------------------
# Jni stuff
# ---------------------------------------------------------------------------

1793
JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux
D
David Bernard 已提交
1794 1795
ifeq ($(PLATFORM), OS_SOLARIS)
	ARCH := $(shell isainfo -b)
1796 1797 1798 1799 1800 1801
else ifeq ($(PLATFORM), OS_OPENBSD)
	ifneq (,$(filter $(MACHINE), amd64 arm64 sparc64))
		ARCH := 64
	else
		ARCH := 32
	endif
D
David Bernard 已提交
1802 1803 1804
else
	ARCH := $(shell getconf LONG_BIT)
endif
1805 1806 1807 1808 1809 1810

ifeq (,$(findstring ppc,$(MACHINE)))
        ROCKSDBJNILIB = librocksdbjni-linux$(ARCH).so
else
        ROCKSDBJNILIB = librocksdbjni-linux-$(MACHINE).so
endif
1811
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH).jar
1812
ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
C
Chris Riccomini 已提交
1813
ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar
1814
ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar
1815 1816
SHA256_CMD = sha256sum

T
Tomas Kolda 已提交
1817 1818 1819 1820 1821
ZLIB_VER ?= 1.2.11
ZLIB_SHA256 ?= c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1
ZLIB_DOWNLOAD_BASE ?= http://zlib.net
BZIP2_VER ?= 1.0.6
BZIP2_SHA256 ?= a2848f34fcd5d6cf47def00461fcb528a0484d8edef8208d6d2e2909dc61d9cd
1822
BZIP2_DOWNLOAD_BASE ?= https://web.archive.org/web/20180624184835/http://www.bzip.org
S
Sagar Vemuri 已提交
1823 1824
SNAPPY_VER ?= 1.1.4
SNAPPY_SHA256 ?= 134bfe122fd25599bb807bb8130e7ba6d9bdb851e0b16efcb83ac4f5d0b70057
T
Tomas Kolda 已提交
1825
SNAPPY_DOWNLOAD_BASE ?= https://github.com/google/snappy/releases/download
A
Adam Retter 已提交
1826 1827
LZ4_VER ?= 1.8.0
LZ4_SHA256 ?= 2ca482ea7a9bb103603108b5a7510b7592b90158c151ff50a28f1ca8389fccf6
T
Tomas Kolda 已提交
1828
LZ4_DOWNLOAD_BASE ?= https://github.com/lz4/lz4/archive
A
Adam Retter 已提交
1829 1830
ZSTD_VER ?= 1.3.3
ZSTD_SHA256 ?= a77c47153ee7de02626c5b2a097005786b71688be61e9fb81806a011f90b297b
1831
ZSTD_DOWNLOAD_BASE ?= https://github.com/facebook/zstd/archive
P
Pengchao Wang 已提交
1832
CURL_SSL_OPTS ?= --tlsv1
1833 1834

ifeq ($(PLATFORM), OS_MACOSX)
D
David Bernard 已提交
1835 1836
	ROCKSDBJNILIB = librocksdbjni-osx.jnilib
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar
1837
	SHA256_CMD = openssl sha256 -r
1838 1839 1840 1841 1842
ifneq ("$(wildcard $(JAVA_HOME)/include/darwin)","")
	JAVA_INCLUDE = -I$(JAVA_HOME)/include -I $(JAVA_HOME)/include/darwin
else
	JAVA_INCLUDE = -I/System/Library/Frameworks/JavaVM.framework/Headers/
endif
1843
endif
1844
ifeq ($(PLATFORM), OS_FREEBSD)
1845
	JAVA_INCLUDE = -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/freebsd
1846 1847 1848
	ROCKSDBJNILIB = librocksdbjni-freebsd$(ARCH).so
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-freebsd$(ARCH).jar
endif
D
David Bernard 已提交
1849 1850 1851 1852
ifeq ($(PLATFORM), OS_SOLARIS)
	ROCKSDBJNILIB = librocksdbjni-solaris$(ARCH).so
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-solaris$(ARCH).jar
	JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/solaris
1853
	SHA256_CMD = digest -a sha256
D
David Bernard 已提交
1854
endif
T
Tomas Kolda 已提交
1855 1856 1857 1858 1859 1860
ifeq ($(PLATFORM), OS_AIX)
	JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/aix
	ROCKSDBJNILIB = librocksdbjni-aix.so
	EXTRACT_SOURCES = gunzip < TAR_GZ | tar xvf -
	SNAPPY_MAKE_TARGET = libsnappy.la
endif
1861 1862 1863 1864 1865
ifeq ($(PLATFORM), OS_OPENBSD)
        JAVA_INCLUDE = -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/openbsd
	ROCKSDBJNILIB = librocksdbjni-openbsd$(ARCH).so
        ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-openbsd$(ARCH).jar
endif
1866

L
leipeng 已提交
1867 1868
libz.a: zlib-1.2.11/zlib.h
zlib-1.2.11/zlib.h:
1869
	-rm -rf zlib-$(ZLIB_VER)
G
guokuankuan 已提交
1870 1871
	cp -a downloads/zlib-$(ZLIB_VER).tar.gz .
	#curl -O -L ${ZLIB_DOWNLOAD_BASE}/zlib-$(ZLIB_VER).tar.gz
1872 1873 1874 1875 1876 1877
	ZLIB_SHA256_ACTUAL=`$(SHA256_CMD) zlib-$(ZLIB_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(ZLIB_SHA256)" != "$$ZLIB_SHA256_ACTUAL" ]; then \
		echo zlib-$(ZLIB_VER).tar.gz checksum mismatch, expected=\"$(ZLIB_SHA256)\" actual=\"$$ZLIB_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf zlib-$(ZLIB_VER).tar.gz
L
leipeng 已提交
1878 1879
	cd zlib-$(ZLIB_VER) && CFLAGS='-fPIC ${EXTRA_CFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' ./configure --static
	cd zlib-$(ZLIB_VER) && CFLAGS='-fPIC ${EXTRA_CFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' $(MAKE)
1880
	cp zlib-$(ZLIB_VER)/libz.a .
N
Naveen 已提交
1881 1882

libbz2.a:
1883
	-rm -rf bzip2-$(BZIP2_VER)
G
guokuankuan 已提交
1884 1885 1886
	cp -a downloads/bzip2-$(BZIP2_VER).tar.gz .
	#wget ${BZIP2_DOWNLOAD_BASE}/$(BZIP2_VER)/bzip2-$(BZIP2_VER).tar.gz
	#curl -O -L ${BZIP2_DOWNLOAD_BASE}/$(BZIP2_VER)/bzip2-$(BZIP2_VER).tar.gz
1887 1888 1889 1890 1891 1892
	BZIP2_SHA256_ACTUAL=`$(SHA256_CMD) bzip2-$(BZIP2_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(BZIP2_SHA256)" != "$$BZIP2_SHA256_ACTUAL" ]; then \
		echo bzip2-$(BZIP2_VER).tar.gz checksum mismatch, expected=\"$(BZIP2_SHA256)\" actual=\"$$BZIP2_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf bzip2-$(BZIP2_VER).tar.gz
L
leipeng 已提交
1893
	cd bzip2-$(BZIP2_VER) && $(MAKE) CFLAGS='-fPIC -O2 -g -D_FILE_OFFSET_BITS=64 ${EXTRA_CFLAGS}' AR='ar ${EXTRA_ARFLAGS}' LDFLAGS=
1894
	cp bzip2-$(BZIP2_VER)/libbz2.a .
N
Naveen 已提交
1895

L
leipeng 已提交
1896 1897
libsnappy.a: snappy-1.1.4/snappy.h
snappy-1.1.4/snappy.h:
1898
	-rm -rf snappy-$(SNAPPY_VER)
G
guokuankuan 已提交
1899 1900 1901
	cp -a downloads/snappy-$(SNAPPY_VER).tar.gz .
	#wget ${SNAPPY_DOWNLOAD_BASE}/$(SNAPPY_VER)/snappy-$(SNAPPY_VER).tar.gz
	#curl -O -L ${CURL_SSL_OPTS} ${SNAPPY_DOWNLOAD_BASE}/$(SNAPPY_VER)/snappy-$(SNAPPY_VER).tar.gz
1902 1903 1904 1905 1906 1907
	SNAPPY_SHA256_ACTUAL=`$(SHA256_CMD) snappy-$(SNAPPY_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(SNAPPY_SHA256)" != "$$SNAPPY_SHA256_ACTUAL" ]; then \
		echo snappy-$(SNAPPY_VER).tar.gz checksum mismatch, expected=\"$(SNAPPY_SHA256)\" actual=\"$$SNAPPY_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf snappy-$(SNAPPY_VER).tar.gz
T
Tomas Kolda 已提交
1908
	cd snappy-$(SNAPPY_VER) && CFLAGS='${EXTRA_CFLAGS}' CXXFLAGS='${EXTRA_CXXFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' ./configure --with-pic --enable-static --disable-shared
L
leipeng 已提交
1909
	cd snappy-$(SNAPPY_VER) && CFLAGS='${EXTRA_CFLAGS}' CXXFLAGS='${EXTRA_CXXFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' $(MAKE) ${SNAPPY_MAKE_TARGET}
1910
	cp snappy-$(SNAPPY_VER)/.libs/libsnappy.a .
1911

L
leipeng 已提交
1912 1913
liblz4.a: lz4-1.8.0/lib/lz4.h
lz4-1.8.0/lib/lz4.h:
1914
	-rm -rf lz4-$(LZ4_VER)
G
guokuankuan 已提交
1915 1916 1917
	cp -a downloads/lz4-$(LZ4_VER).tar.gz .
	#wget ${LZ4_DOWNLOAD_BASE}/v$(LZ4_VER).tar.gz
	#curl -O -L ${CURL_SSL_OPTS} ${LZ4_DOWNLOAD_BASE}/v$(LZ4_VER).tar.gz
G
guokuankuan 已提交
1918
	#mv v$(LZ4_VER).tar.gz lz4-$(LZ4_VER).tar.gz
1919 1920 1921 1922 1923 1924
	LZ4_SHA256_ACTUAL=`$(SHA256_CMD) lz4-$(LZ4_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(LZ4_SHA256)" != "$$LZ4_SHA256_ACTUAL" ]; then \
		echo lz4-$(LZ4_VER).tar.gz checksum mismatch, expected=\"$(LZ4_SHA256)\" actual=\"$$LZ4_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf lz4-$(LZ4_VER).tar.gz
L
leipeng 已提交
1925
	cd lz4-$(LZ4_VER)/lib && $(MAKE) CFLAGS='-fPIC -O2 ${EXTRA_CFLAGS}' LDFLAGS= all
1926
	cp lz4-$(LZ4_VER)/lib/liblz4.a .
N
Naveen 已提交
1927

L
leipeng 已提交
1928 1929
libzstd.a: zstd-1.3.3/lib/include/zstd.h
zstd-1.3.3/lib/include/zstd.h:
1930
	-rm -rf zstd-$(ZSTD_VER)
G
guokuankuan 已提交
1931 1932
	cp -a downloads/zstd-$(ZSTD_VER).tar.gz .
	#wget ${ZSTD_DOWNLOAD_BASE}/v$(ZSTD_VER).tar.gz
G
guokuankuan 已提交
1933 1934
	#curl -O -L ${CURL_SSL_OPTS} ${ZSTD_DOWNLOAD_BASE}/v$(ZSTD_VER).tar.gz
	#mv v$(ZSTD_VER).tar.gz zstd-$(ZSTD_VER).tar.gz
1935 1936 1937 1938 1939 1940
	ZSTD_SHA256_ACTUAL=`$(SHA256_CMD) zstd-$(ZSTD_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(ZSTD_SHA256)" != "$$ZSTD_SHA256_ACTUAL" ]; then \
		echo zstd-$(ZSTD_VER).tar.gz checksum mismatch, expected=\"$(ZSTD_SHA256)\" actual=\"$$ZSTD_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf zstd-$(ZSTD_VER).tar.gz
L
leipeng 已提交
1941
	cd zstd-$(ZSTD_VER)/lib && LDFLAGS= DESTDIR=. PREFIX= $(MAKE) CFLAGS='-fPIC -O2 ${EXTRA_CFLAGS}' install
1942 1943
	cp zstd-$(ZSTD_VER)/lib/libzstd.a .

1944
# A version of each $(LIBOBJECTS) compiled with -fPIC and a fixed set of static compression libraries
A
Andrew Kryczka 已提交
1945
java_static_libobjects = $(patsubst %,jls/%,$(LIB_CC_OBJECTS))
1946
CLEAN_FILES += jls
A
Andrew Kryczka 已提交
1947
java_static_all_libobjects = $(java_static_libobjects)
1948

1949
ifneq ($(ROCKSDB_JAVA_NO_COMPRESSION), 1)
1950
JAVA_COMPRESSIONS = libz.a libbz2.a libsnappy.a liblz4.a libzstd.a
1951 1952
endif

1953
JAVA_STATIC_FLAGS = -DZLIB -DBZIP2 -DSNAPPY -DLZ4 -DZSTD
1954
JAVA_STATIC_INCLUDES = -I./zlib-$(ZLIB_VER) -I./bzip2-$(BZIP2_VER) -I./snappy-$(SNAPPY_VER) -I./lz4-$(LZ4_VER)/lib -I./zstd-$(ZSTD_VER)/lib/include
1955

A
Andrew Kryczka 已提交
1956
ifeq ($(HAVE_POWER8),1)
雷鹏 已提交
1957 1958
JAVA_STATIC_C_LIBOBJECTS = $(patsubst %.c.o,jls/%.c.o,$(addprefix ${xdir},$(LIB_SOURCES_C:.c=.o)))
JAVA_STATIC_ASM_LIBOBJECTS = $(patsubst %.S.o,jls/%.S.o,$(addprefix ${xdir},$(LIB_SOURCES_ASM:.S=.o)))
A
Andrew Kryczka 已提交
1959 1960 1961

java_static_ppc_libobjects = $(JAVA_STATIC_C_LIBOBJECTS) $(JAVA_STATIC_ASM_LIBOBJECTS)

雷鹏 已提交
1962
jls/${xdir}/util/crc32c_ppc.o: util/crc32c_ppc.c
A
Andrew Kryczka 已提交
1963 1964
	$(AM_V_CC)$(CC) $(CFLAGS) $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES) -c $< -o $@

雷鹏 已提交
1965
jls/${xdir}/util/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
A
Andrew Kryczka 已提交
1966 1967 1968 1969 1970
	$(AM_V_CC)$(CC) $(CFLAGS) $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES) -c $< -o $@

java_static_all_libobjects += $(java_static_ppc_libobjects)
endif

雷鹏 已提交
1971
$(java_static_libobjects): jls/${xdir}/%.o: %.cc $(JAVA_COMPRESSIONS)
1972
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES) -fPIC -c $< -o $@ $(COVERAGEFLAGS)
1973

A
Andrew Kryczka 已提交
1974
rocksdbjavastatic: $(java_static_all_libobjects)
F
fyrz 已提交
1975
	cd java;$(MAKE) javalib;
1976
	rm -f ./java/target/$(ROCKSDBJNILIB)
1977 1978
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC \
	  -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) \
A
Andrew Kryczka 已提交
1979
	  $(java_static_all_libobjects) $(COVERAGEFLAGS) \
1980
	  $(JAVA_COMPRESSIONS) $(JAVA_STATIC_LDFLAGS)
1981 1982 1983
	cd java/target;if [ "$(DEBUG_LEVEL)" == "0" ]; then \
		strip $(STRIPFLAGS) $(ROCKSDBJNILIB); \
	fi
1984 1985 1986 1987 1988
	cd java;jar -cf target/$(ROCKSDB_JAR) HISTORY*.md
	cd java/target;jar -uf $(ROCKSDB_JAR) $(ROCKSDBJNILIB)
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR) org/rocksdb/*.class org/rocksdb/util/*.class
	cd java/target/apidocs;jar -cf ../$(ROCKSDB_JAVADOCS_JAR) *
	cd java/src/main/java;jar -cf ../../../target/$(ROCKSDB_SOURCES_JAR) org
N
Naveen 已提交
1989

1990
rocksdbjavastaticrelease: rocksdbjavastatic
1991
	cd java/crossbuild && vagrant destroy -f && vagrant up linux32 && vagrant halt linux32 && vagrant up linux64 && vagrant halt linux64
1992
	cd java;jar -cf target/$(ROCKSDB_JAR_ALL) HISTORY*.md
1993
	cd java/target;jar -uf $(ROCKSDB_JAR_ALL) librocksdbjni-*.so librocksdbjni-*.jnilib
1994
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR_ALL) org/rocksdb/*.class org/rocksdb/util/*.class
1995

1996 1997 1998 1999 2000 2001 2002
rocksdbjavastaticreleasedocker: rocksdbjavastatic rocksdbjavastaticdockerx86 rocksdbjavastaticdockerx86_64
	cd java;jar -cf target/$(ROCKSDB_JAR_ALL) HISTORY*.md
	cd java/target;jar -uf $(ROCKSDB_JAR_ALL) librocksdbjni-*.so librocksdbjni-*.jnilib
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR_ALL) org/rocksdb/*.class org/rocksdb/util/*.class

rocksdbjavastaticdockerx86:
	mkdir -p java/target
2003 2004
	DOCKER_LINUX_X86_CONTAINER=`docker ps -aqf name=rocksdb_linux_x86-be`; \
	if [ -z "$$DOCKER_LINUX_X86_CONTAINER" ]; then \
2005
		docker container create --attach stdin --attach stdout --attach stderr --volume `pwd`:/rocksdb-host --name rocksdb_linux_x86-be evolvedbinary/rocksjava:centos6_x86-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh; \
2006 2007
	fi
	docker start -a rocksdb_linux_x86-be
2008 2009 2010 2011 2012 2013 2014 2015

rocksdbjavastaticdockerx86_64:
	mkdir -p java/target
	DOCKER_LINUX_X64_CONTAINER=`docker ps -aqf name=rocksdb_linux_x64-be`; \
	if [ -z "$$DOCKER_LINUX_X64_CONTAINER" ]; then \
		docker container create --attach stdin --attach stdout --attach stderr --volume `pwd`:/rocksdb-host --name rocksdb_linux_x64-be evolvedbinary/rocksjava:centos6_x64-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh; \
	fi
	docker start -a rocksdb_linux_x64-be
2016

2017 2018 2019 2020 2021 2022 2023 2024
rocksdbjavastaticdockerppc64le:
	mkdir -p java/target
	DOCKER_LINUX_PPC64LE_CONTAINER=`docker ps -aqf name=rocksdb_linux_ppc64le-be`; \
	if [ -z "$$DOCKER_LINUX_PPC64LE_CONTAINER" ]; then \
		docker container create --attach stdin --attach stdout --attach stderr --volume `pwd`:/rocksdb-host --name rocksdb_linux_ppc64le-be evolvedbinary/rocksjava:centos7_ppc64le-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh; \
	fi
	docker start -a rocksdb_linux_ppc64le-be

2025 2026
rocksdbjavastaticpublish: rocksdbjavastaticrelease rocksdbjavastaticpublishcentral

2027 2028
rocksdbjavastaticpublishdocker: rocksdbjavastaticreleasedocker rocksdbjavastaticpublishcentral

2029
rocksdbjavastaticpublishcentral:
2030 2031 2032 2033 2034
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar -Dclassifier=javadoc
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar -Dclassifier=sources
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux64.jar -Dclassifier=linux64
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux32.jar -Dclassifier=linux32
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar -Dclassifier=osx
2035
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-win64.jar -Dclassifier=win64
2036
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
2037

2038
# A version of each $(LIBOBJECTS) compiled with -fPIC
2039 2040 2041 2042 2043 2044 2045 2046 2047
ifeq ($(HAVE_POWER8),1)
JAVA_CC_OBJECTS = $(SHARED_CC_OBJECTS)
JAVA_C_OBJECTS = $(SHARED_C_OBJECTS)
JAVA_ASM_OBJECTS = $(SHARED_ASM_OBJECTS)

JAVA_C_LIBOBJECTS = $(patsubst %.c.o,jl/%.c.o,$(JAVA_C_OBJECTS))
JAVA_ASM_LIBOBJECTS = $(patsubst %.S.o,jl/%.S.o,$(JAVA_ASM_OBJECTS))
endif

S
Sagar Vemuri 已提交
2048
java_libobjects = $(patsubst %,jl/%,$(LIB_CC_OBJECTS))
2049
CLEAN_FILES += jl
2050 2051 2052 2053 2054
java_all_libobjects = $(java_libobjects)

ifeq ($(HAVE_POWER8),1)
java_ppc_libobjects = $(JAVA_C_LIBOBJECTS) $(JAVA_ASM_LIBOBJECTS)

雷鹏 已提交
2055
jl/${xdir}/crc32c_ppc.o: util/crc32c_ppc.c
2056 2057
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@

雷鹏 已提交
2058
jl/${xdir}/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
2059 2060 2061
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
java_all_libobjects += $(java_ppc_libobjects)
endif
2062

雷鹏 已提交
2063
$(java_libobjects): jl/${xdir}/%.o: %.cc
2064 2065
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) -fPIC -c $< -o $@ $(COVERAGEFLAGS)

2066
rocksdbjava: $(java_all_libobjects)
2067 2068
	$(AM_V_GEN)cd java;$(MAKE) javalib;
	$(AM_V_at)rm -f ./java/target/$(ROCKSDBJNILIB)
2069
	$(AM_V_at)$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) $(java_all_libobjects) $(JAVA_LDFLAGS) $(COVERAGEFLAGS)
2070 2071 2072
	$(AM_V_at)cd java;jar -cf target/$(ROCKSDB_JAR) HISTORY*.md
	$(AM_V_at)cd java/target;jar -uf $(ROCKSDB_JAR) $(ROCKSDBJNILIB)
	$(AM_V_at)cd java/target/classes;jar -uf ../$(ROCKSDB_JAR) org/rocksdb/*.class org/rocksdb/util/*.class
2073 2074 2075 2076

jclean:
	cd java;$(MAKE) clean;

2077 2078 2079 2080 2081 2082
jtest_compile: rocksdbjava
	cd java;$(MAKE) java_test

jtest_run:
	cd java;$(MAKE) run_test

2083
jtest: rocksdbjava
2084
	cd java;$(MAKE) sample;$(MAKE) test;
2085

2086 2087 2088
jdb_bench:
	cd java;$(MAKE) db_bench;

2089 2090
commit_prereq: build_tools/rocksdb-lego-determinator \
               build_tools/precommit_checker.py
2091
	J=$(J) build_tools/precommit_checker.py unit unit_481 clang_unit release release_481 clang_release tsan asan ubsan lite unit_non_shm
2092
	$(MAKE) clean && $(MAKE) jclean && $(MAKE) rocksdbjava;
2093

2094 2095 2096
# ---------------------------------------------------------------------------
#  	Platform-specific compilation
# ---------------------------------------------------------------------------
J
Jim Paton 已提交
2097

2098 2099 2100
ifeq ($(PLATFORM), IOS)
# For iOS, create universal object files to be used on both the simulator and
# a device.
H
heyongqiang 已提交
2101 2102 2103
PLATFORMSROOT=/Applications/Xcode.app/Contents/Developer/Platforms
SIMULATORROOT=$(PLATFORMSROOT)/iPhoneSimulator.platform/Developer
DEVICEROOT=$(PLATFORMSROOT)/iPhoneOS.platform/Developer
I
Igor Canadi 已提交
2104
IOSVERSION=$(shell defaults read $(PLATFORMSROOT)/iPhoneOS.platform/version CFBundleShortVersionString)
2105

2106 2107
.cc.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
2108
	$(CXX) $(CXXFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
2109
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
2110
	xcrun -sdk iphoneos $(CXX) $(CXXFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
2111
	lipo ios-x86/$@ ios-arm/$@ -create -output $@
2112 2113 2114

.c.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
2115
	$(CC) $(CFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
2116
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
2117
	xcrun -sdk iphoneos $(CC) $(CFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
2118 2119
	lipo ios-x86/$@ ios-arm/$@ -create -output $@

2120
else
2121 2122 2123 2124 2125 2126 2127
ifeq ($(HAVE_POWER8),1)
util/crc32c_ppc.o: util/crc32c_ppc.c
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@

util/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
endif
2128
.cc.o:
2129
	$(AM_V_CC)$(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
2130

2131
.c.o:
2132
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
2133
endif
2134 2135 2136 2137
# ---------------------------------------------------------------------------
#  	Source files dependencies detection
# ---------------------------------------------------------------------------

2138
all_sources = $(LIB_SOURCES) $(MAIN_SOURCES) $(MOCK_LIB_SOURCES) $(TOOL_LIB_SOURCES) $(BENCH_LIB_SOURCES) $(TEST_LIB_SOURCES) $(EXP_LIB_SOURCES) $(ANALYZER_LIB_SOURCES)
2139
DEPFILES = $(addprefix ${xdir}/,$(all_sources:.cc=.cc.d))
2140

2141 2142 2143 2144 2145
# Add proper dependency support so changing a .h file forces a .cc file to
# rebuild.

# The .d file indicates .cc file's dependencies on .h files. We generate such
# dependency by g++'s -MM option, whose output is a make dependency rule.
2146 2147
${xdir}/%.cc.d: %.cc
	@mkdir -p $(dir $@)
2148
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
2149
	  -MM -MT'$@' -MT'$(<:.cc=.o)' "$<" -o '$@'
2150

2151
ifeq ($(HAVE_POWER8),1)
2152 2153
DEPFILES_C = $(addprefix ${xdir}/,$(LIB_SOURCES_C:.c=.c.d))
DEPFILES_ASM = $(addprefix ${xdir}/,$(LIB_SOURCES_ASM:.S=.S.d))
2154

2155 2156
${xdir}/%.c.d: %.c
	@mkdir -p $(dir $@)
2157 2158 2159
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.c=.o)' "$<" -o '$@'

2160 2161
${xdir}/%.S.d: %.S
	@mkdir -p $(dir $@)
2162 2163 2164 2165 2166 2167 2168 2169
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.S=.o)' "$<" -o '$@'

$(DEPFILES_C): %.c.d

$(DEPFILES_ASM): %.S.d
depend: $(DEPFILES) $(DEPFILES_C) $(DEPFILES_ASM)
else
2170
depend: $(DEPFILES)
2171
endif
2172

2173 2174 2175 2176 2177 2178 2179 2180
COMPRESSION_HEADERS :=          \
  snappy-1.1.4/snappy.h         \
  lz4-1.8.0/lib/lz4.h           \
  zstd-1.3.3/lib/include/zstd.h \
  zlib-1.2.11/zlib.h

${DEPFILES} : ${COMPRESSION_HEADERS}

2181 2182 2183 2184
# if the make goal is either "clean" or "format", we shouldn't
# try to import the *.d files.
# TODO(kailiu) The unfamiliarity of Make's conditions leads to the ugly
# working solution.
2185
ifneq ($(MAKECMDGOALS),clean)
2186
ifneq ($(MAKECMDGOALS),format)
2187 2188
ifneq ($(MAKECMDGOALS),jclean)
ifneq ($(MAKECMDGOALS),jtest)
2189
ifneq ($(MAKECMDGOALS),package)
2190
ifneq ($(MAKECMDGOALS),analyze)
2191 2192
-include $(DEPFILES)
endif
2193
endif
2194 2195
endif
endif
2196
endif
2197
endif