Makefile 37.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
CLEAN_FILES = # deliberately empty, so we can append below.
10 11 12 13
CFLAGS += ${EXTRA_CFLAGS}
CXXFLAGS += ${EXTRA_CXXFLAGS}
LDFLAGS += $(EXTRA_LDFLAGS)
MACHINE ?= $(shell uname -m)
I
Igor Canadi 已提交
14
ARFLAGS = rs
15

16 17
# Transform parallel LOG output into something more readable.
perl_command = perl -n \
Y
Yueh-Hsuan Chiang 已提交
18 19 20 21
  -e '@a=split("\t",$$_,-1); $$t=$$a[8]; $$t =~ s,^\./,,;'		\
  -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'
22 23
quoted_perl_command = $(subst ','\'',$(perl_command))

24 25 26 27 28 29 30 31 32
# 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 已提交
33
# with debug level 0. To compile with level 0, run `make shared_lib`,
34 35 36 37 38
# `make install-shared`, `make static_lib`, `make install-static` or
# `make install`
DEBUG_LEVEL=1

ifeq ($(MAKECMDGOALS),dbg)
Y
Yueh-Hsuan Chiang 已提交
39
	DEBUG_LEVEL=2
40
endif
41 42

ifeq ($(MAKECMDGOALS),shared_lib)
Y
Yueh-Hsuan Chiang 已提交
43
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
44
endif
I
Igor Canadi 已提交
45

I
Igor Canadi 已提交
46
ifeq ($(MAKECMDGOALS),install-shared)
Y
Yueh-Hsuan Chiang 已提交
47
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
48 49
endif

I
Igor Canadi 已提交
50
ifeq ($(MAKECMDGOALS),static_lib)
Y
Yueh-Hsuan Chiang 已提交
51
	DEBUG_LEVEL=0
52
endif
I
Igor Canadi 已提交
53

I
Igor Canadi 已提交
54
ifeq ($(MAKECMDGOALS),install-static)
Y
Yueh-Hsuan Chiang 已提交
55
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
56 57 58
endif

ifeq ($(MAKECMDGOALS),install)
Y
Yueh-Hsuan Chiang 已提交
59
	DEBUG_LEVEL=0
60 61
endif

62
ifeq ($(MAKECMDGOALS),rocksdbjavastatic)
Y
Yueh-Hsuan Chiang 已提交
63
	DEBUG_LEVEL=0
64 65
endif

66 67 68 69 70 71 72 73 74 75 76
# compile with -O2 if debug level is not 2
ifneq ($(DEBUG_LEVEL), 2)
OPT += -O2 -fno-omit-frame-pointer
ifneq ($(MACHINE),ppc64) # ppc64 doesn't support -momit-leaf-frame-pointer
OPT += -momit-leaf-frame-pointer
endif
endif

# if we're compiling for release, compile without debug code (-DNDEBUG) and
# don't treat warnings as errors
ifeq ($(DEBUG_LEVEL),0)
I
Igor Canadi 已提交
77
OPT += -DNDEBUG
78
DISABLE_WARNING_AS_ERROR=1
79 80
else
$(warning Warning: Compiling in debug mode. Don't use the resulting binary in production)
I
Igor Canadi 已提交
81 82
endif

83
#-----------------------------------------------
84
include src.mk
85

86 87 88 89 90 91
AM_DEFAULT_VERBOSITY = 0

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 已提交
92 93 94 95
AM_V_at = $(am__v_at_$(V))
am__v_at_ = $(am__v_at_$(AM_DEFAULT_VERBOSITY))
am__v_at_0 = @
am__v_at_1 =
96 97 98 99 100 101 102 103 104 105 106

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 已提交
107 108 109 110
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 =
111

112 113
AM_LINK = $(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(COVERAGEFLAGS)

114
# detect what platform we're building on
115
dummy := $(shell (export ROCKSDB_ROOT="$(CURDIR)"; "$(CURDIR)/build_tools/build_detect_platform" "$(CURDIR)/make_config.mk"))
S
Sanjay Ghemawat 已提交
116
# this file is generated by the previous line to set build flags and sources
I
Igor Canadi 已提交
117
include make_config.mk
118
CLEAN_FILES += make_config.mk
J
jorlow@chromium.org 已提交
119

I
Igor Canadi 已提交
120 121 122 123 124 125 126 127
ifneq ($(PLATFORM), IOS)
CFLAGS += -g
CXXFLAGS += -g
else
# no debug info for IOS, that will make our library big
OPT += -DNDEBUG
endif

128
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yueh-Hsuan Chiang 已提交
129 130 131
	# found
	CFLAGS += -fno-exceptions
	CXXFLAGS += -fno-exceptions
132 133
endif

I
Igor Canadi 已提交
134 135
# 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 已提交
136 137 138 139
	DISABLE_JEMALLOC=1
	EXEC_LDFLAGS += -fsanitize=address
	PLATFORM_CCFLAGS += -fsanitize=address
	PLATFORM_CXXFLAGS += -fsanitize=address
I
Igor Canadi 已提交
140 141 142 143
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 已提交
144 145 146 147 148 149 150
	DISABLE_JEMALLOC=1
	EXEC_LDFLAGS += -fsanitize=thread -pie
	PLATFORM_CCFLAGS += -fsanitize=thread -fPIC -DROCKSDB_TSAN_RUN
	PLATFORM_CXXFLAGS += -fsanitize=thread -fPIC -DROCKSDB_TSAN_RUN
        # Turn off -pg when enabling TSAN testing, because that induces
        # a link failure.  TODO: find the root cause
	pg =
151
else
Y
Yueh-Hsuan Chiang 已提交
152
	pg = -pg
I
Igor Canadi 已提交
153 154 155
endif

ifndef DISABLE_JEMALLOC
Y
Yueh-Hsuan Chiang 已提交
156 157 158
	EXEC_LDFLAGS := $(JEMALLOC_LIB) $(EXEC_LDFLAGS)
	PLATFORM_CXXFLAGS += $(JEMALLOC_INCLUDE)
	PLATFORM_CCFLAGS += $(JEMALLOC_INCLUDE)
I
Igor Canadi 已提交
159 160
endif

I
Igor Sugak 已提交
161 162 163 164 165
export GTEST_THROW_ON_FAILURE=1 GTEST_HAS_EXCEPTIONS=1
GTEST_DIR = ./third-party/gtest-1.7.0/fused-src
PLATFORM_CCFLAGS += -isystem $(GTEST_DIR)
PLATFORM_CXXFLAGS += -isystem $(GTEST_DIR)

166 167 168
# This (the first rule) must depend on "all".
default: all

169
WARNING_FLAGS = -W -Wextra -Wall -Wsign-compare -Wshadow \
Y
Yueh-Hsuan Chiang 已提交
170
  -Wno-unused-parameter
171

172
ifndef DISABLE_WARNING_AS_ERROR
Y
Yueh-Hsuan Chiang 已提交
173
	WARNING_FLAGS += -Werror
174 175
endif

I
Igor Canadi 已提交
176
CFLAGS += $(WARNING_FLAGS) -I. -I./include $(PLATFORM_CCFLAGS) $(OPT)
I
Igor Sugak 已提交
177
CXXFLAGS += $(WARNING_FLAGS) -I. -I./include $(PLATFORM_CXXFLAGS) $(OPT) -Woverloaded-virtual -Wnon-virtual-dtor -Wno-missing-field-initializers
178

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

181
date := $(shell date +%F)
I
Igor Canadi 已提交
182
ifdef FORCE_GIT_SHA
Y
Yueh-Hsuan Chiang 已提交
183
	git_sha := $(FORCE_GIT_SHA)
I
Igor Canadi 已提交
184
else
Y
Yueh-Hsuan Chiang 已提交
185
	git_sha := $(shell git rev-parse HEAD 2>/dev/null)
I
Igor Canadi 已提交
186
endif
187
gen_build_version =							\
Y
Yueh-Hsuan Chiang 已提交
188 189 190 191 192 193 194
  printf '%s\n'								\
    '\#include "build_version.h"'					\
    'const char* rocksdb_build_git_sha =				\
      "rocksdb_build_git_sha:$(git_sha)";'			\
    'const char* rocksdb_build_git_date =				\
      "rocksdb_build_git_date:$(date)";'				\
    'const char* rocksdb_build_compile_date = __DATE__;'
195 196 197 198 199 200

# 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.
201
CLEAN_FILES += util/build_version.cc:
202 203
FORCE:
util/build_version.cc: FORCE
Y
Yueh-Hsuan Chiang 已提交
204 205 206 207 208
	$(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
209

210
LIBOBJECTS = $(LIB_SOURCES:.cc=.o)
E
Evan Shaw 已提交
211
LIBOBJECTS += $(TOOL_SOURCES:.cc=.o)
212
MOCKOBJECTS = $(MOCK_SOURCES:.cc=.o)
J
jorlow@chromium.org 已提交
213

I
Igor Sugak 已提交
214
GTEST = $(GTEST_DIR)/gtest/gtest-all.o
J
jorlow@chromium.org 已提交
215
TESTUTIL = ./util/testutil.o
I
Igor Sugak 已提交
216
TESTHARNESS = ./util/testharness.o $(TESTUTIL) $(MOCKOBJECTS) $(GTEST)
217
VALGRIND_ERROR = 2
218
VALGRIND_VER := $(join $(VALGRIND_VER),valgrind)
219

220
VALGRIND_OPTS = --error-exitcode=$(VALGRIND_ERROR) --leak-check=full
221

J
jorlow@chromium.org 已提交
222
TESTS = \
223 224 225 226
	db_test \
	db_iter_test \
	db_log_iter_test \
	db_compaction_filter_test \
227
	db_compaction_test \
228
	db_dynamic_level_test \
229
	db_inplace_update_test \
230 231
	db_tailing_iter_test \
	db_universal_compaction_test \
S
sdong 已提交
232
	db_wal_test \
233
	db_table_properties_test \
234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254
	block_hash_index_test \
	autovector_test \
	column_family_test \
	table_properties_collector_test \
	arena_test \
	auto_roll_logger_test \
	block_test \
	bloom_test \
	dynamic_bloom_test \
	c_test \
	cache_test \
	checkpoint_test \
	coding_test \
	corruption_test \
	crc32c_test \
	slice_transform_test \
	dbformat_test \
	env_test \
	fault_injection_test \
	filelock_test \
	filename_test \
255
	file_reader_writer_test \
256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291
	block_based_filter_block_test \
	full_filter_block_test \
	histogram_test \
	log_test \
	manual_compaction_test \
	memenv_test \
	mock_env_test \
	memtable_list_test \
	merge_helper_test \
	merge_test \
	merger_test \
	redis_test \
	reduce_levels_test \
	plain_table_db_test \
	comparator_db_test \
	prefix_test \
	skiplist_test \
	stringappend_test \
	ttl_test \
	backupable_db_test \
	document_db_test \
	json_document_test \
	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 \
	table_test \
	thread_local_test \
	geodb_test \
	rate_limiter_test \
I
Islam AbdelRahman 已提交
292
	delete_scheduler_test \
293 294 295 296 297 298 299 300
	options_test \
	event_logger_test \
	cuckoo_table_builder_test \
	cuckoo_table_reader_test \
	cuckoo_table_db_test \
	flush_job_test \
	wal_manager_test \
	listener_test \
A
Andres Noetzli 已提交
301
	compaction_iterator_test \
302 303 304 305 306 307 308
	compaction_job_test \
	thread_list_test \
	sst_dump_test \
	compact_files_test \
	perf_context_test \
	optimistic_transaction_test \
	write_callback_test \
309 310
	heap_test \
	compact_on_deletion_collector_test \
A
agiardullo 已提交
311
	compaction_job_stats_test \
312 313
	transaction_test \
	ldb_cmd_test
314

315 316
SUBSET :=  $(shell echo $(TESTS) |sed s/^.*$(ROCKSDBTESTS_START)/$(ROCKSDBTESTS_START)/)

317
TOOLS = \
Y
Yueh-Hsuan Chiang 已提交
318 319 320 321 322 323 324
	sst_dump \
	db_sanity_test \
	db_stress \
	ldb \
	db_repl_stress \
	rocksdb_dump \
	rocksdb_undump
J
jorlow@chromium.org 已提交
325

I
Igor Canadi 已提交
326
BENCHMARKS = db_bench table_reader_bench cache_bench memtablerep_bench
J
jorlow@chromium.org 已提交
327

328
# if user didn't config LIBNAME, set the default
329
ifeq ($(LIBNAME),)
330 331
# we should only run rocksdb in production with DEBUG_LEVEL 0
ifeq ($(DEBUG_LEVEL),0)
Y
Yueh-Hsuan Chiang 已提交
332
        LIBNAME=librocksdb
333 334 335
else
        LIBNAME=librocksdb_debug
endif
336
endif
337
LIBRARY = ${LIBNAME}.a
338

339 340 341
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)
342

343 344
default: all

345 346 347
#-----------------------------------------------
# Create platform independent shared libraries.
#-----------------------------------------------
348
ifneq ($(PLATFORM_SHARED_EXT),)
H
heyongqiang 已提交
349 350

ifneq ($(PLATFORM_SHARED_VERSIONED),true)
351
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
H
heyongqiang 已提交
352 353
SHARED2 = $(SHARED1)
SHARED3 = $(SHARED1)
354
SHARED4 = $(SHARED1)
H
heyongqiang 已提交
355 356
SHARED = $(SHARED1)
else
357 358
SHARED_MAJOR = $(ROCKSDB_MAJOR)
SHARED_MINOR = $(ROCKSDB_MINOR)
359
SHARED_PATCH = $(ROCKSDB_PATCH)
360
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
361 362 363 364 365 366
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
367 368
SHARED2 = $(SHARED1).$(SHARED_MAJOR)
SHARED3 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR)
369
SHARED4 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR).$(SHARED_PATCH)
370
endif
371 372
SHARED = $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4)
$(SHARED1): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
373
	ln -fs $(SHARED4) $(SHARED1)
374
$(SHARED2): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
375
	ln -fs $(SHARED4) $(SHARED2)
376
$(SHARED3): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
377
	ln -fs $(SHARED4) $(SHARED3)
378 379
endif

380
$(SHARED4):
Y
Yueh-Hsuan Chiang 已提交
381 382
	$(CXX) $(PLATFORM_SHARED_LDFLAGS)$(SHARED3) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) $(LIB_SOURCES) \
		$(LDFLAGS) -o $@
H
heyongqiang 已提交
383 384 385

endif  # PLATFORM_SHARED_EXT

386
.PHONY: blackbox_crash_test check clean coverage crash_test ldb_tests package \
Y
Yueh-Hsuan Chiang 已提交
387 388
	release tags valgrind_check whitebox_crash_test format static_lib shared_lib all \
	dbg rocksdbjavastatic rocksdbjava install install-static install-shared uninstall \
M
maurice barnum 已提交
389
	analyze tools
390

M
maurice barnum 已提交
391 392

all: $(LIBRARY) $(BENCHMARKS) tools $(TESTS)
393

I
Igor Canadi 已提交
394 395 396 397
static_lib: $(LIBRARY)

shared_lib: $(SHARED)

M
maurice barnum 已提交
398 399 400
tools: $(TOOLS)

dbg: $(LIBRARY) $(BENCHMARKS) tools $(TESTS)
K
Kai Liu 已提交
401

402
# creates static library and programs
403
release:
Y
Yueh-Hsuan Chiang 已提交
404
	$(MAKE) clean
M
maurice barnum 已提交
405
	OPT="-DNDEBUG -O2" $(MAKE) static_lib tools db_bench
K
Kai Liu 已提交
406 407

coverage:
Y
Yueh-Hsuan Chiang 已提交
408 409 410 411 412
	$(MAKE) clean
	COVERAGEFLAGS="-fprofile-arcs -ftest-coverage" LDFLAGS+="-lgcov" $(MAKE) J=1 all check
	cd coverage && ./coverage_test.sh
        # Delete intermediate files
	find . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
J
jorlow@chromium.org 已提交
413

414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432
# Extract the names of its tests by running db_test with --gtest_list_tests.
# 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
#
test_names = \
Y
Yueh-Hsuan Chiang 已提交
433 434 435 436 437
  ./db_test --gtest_list_tests						\
    | perl -n								\
      -e 's/ *\#.*//;'							\
      -e '/^(\s*)(\S+)/; !$$1 and do {$$p=$$2; break};'			\
      -e 'print qq! $$p$$2!'
438 439 440 441 442 443 444

ifeq ($(MAKECMDGOALS),check)
# 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),)
TMPD := $(shell f=/dev/shm; test -k $$f || f=/tmp;			\
Y
Yueh-Hsuan Chiang 已提交
445 446
  perl -le 'use File::Temp "tempdir";'					\
    -e 'print tempdir("'$$f'/rocksdb.XXXX", CLEANUP => 0)')
447 448
endif
endif
J
jorlow@chromium.org 已提交
449

450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467
ifneq ($(T),)

# Run all tests in parallel, accumulating per-test logs in t/log-*.

# t_sanitized is each $(T) with "-" in place of each "/".
t_sanitized = $(subst /,-,$(T))

# t_run is each sanitized name with a leading "t/".
t_run = $(patsubst %,t/%,$(t_sanitized))

# Each t_run file is a tiny generated bourne shell script
# that invokes one of db_tests's 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).
filter = --gtest_filter=$(subst -,/,$(@F))
$(t_run): Makefile db_test
Y
Yueh-Hsuan Chiang 已提交
468 469 470 471 472 473 474 475 476 477
	$(AM_V_GEN)mkdir -p t
	$(AM_V_at)rm -f $@ $@-t
	$(AM_V_at)printf '%s\n'						\
	    '#!/bin/sh'							\
	    'd=$(TMPD)/$(@F)'						\
	    'mkdir -p $$d'						\
	    'TEST_TMPDIR=$$d ./db_test $(filter)'			\
	  > $@-t
	$(AM_V_at)chmod a=rx $@-t
	$(AM_V_at)mv $@-t $@
478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495

# 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
Yueh-Hsuan Chiang 已提交
496
  ^t/DBTest\.(?:FileCreationRandomFailure|EncodeDecompressedBlockSizeTest)$$
497
prioritize_long_running_tests =						\
Y
Yueh-Hsuan Chiang 已提交
498 499 500
  perl -pe 's,($(slow_test_regexp)),100 $$1,'				\
    | sort -k1,1gr							\
    | sed 's/^[.0-9]* //'
501 502 503 504 505 506 507 508

# "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.
J = 100%

V
Venkatesh Radhakrishnan 已提交
509 510 511
# Use this regexp to select the subset of tests whose names match.
tests-regexp = .

512 513
.PHONY: check_0
check_0: $(t_run)
Y
Yueh-Hsuan Chiang 已提交
514 515 516 517 518 519 520 521 522 523 524 525
	$(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=;					\
	{								\
	  printf './%s\n' $(filter-out db_test, $(TESTS));		\
	  printf '%s\n' $(t_run);					\
	}								\
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
	  | parallel -j$(J) --joblog=LOG $$eta --gnu '{} >& t/log-{/}'
526 527 528
endif

CLEAN_FILES += t LOG $(TMPD)
529

530 531 532 533 534 535 536 537
# 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:
Y
Yueh-Hsuan Chiang 已提交
538
	watch --interval=0 'sort -k7,7nr -k4,4gr LOG|$(quoted_perl_command)'
539

I
Igor Canadi 已提交
540
# If J != 1 and GNU parallel is installed, run the tests in parallel,
541 542
# via the check_0 rule above.  Otherwise, run them sequentially.
check: all
Y
Yueh-Hsuan Chiang 已提交
543 544 545 546 547 548 549 550 551 552 553
	$(AM_V_GEN)if test "$(J)" != 1                                  \
	    && (parallel --gnu --help 2>/dev/null) |                    \
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
	    t=$$($(test_names));                                        \
	    $(MAKE) T="$$t" TMPD=$(TMPD) check_0;                       \
	else                                                            \
	    for t in $(TESTS); do                                       \
	      echo "===== Running $$t"; ./$$t || exit 1; done;          \
	fi
	rm -rf $(TMPD)
I
Islam AbdelRahman 已提交
554
ifeq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yueh-Hsuan Chiang 已提交
555 556
	python tools/ldb_test.py
	sh tools/rocksdb_dump_test.sh
I
Islam AbdelRahman 已提交
557
endif
558 559

check_some: $(SUBSET) ldb_tests
Y
Yueh-Hsuan Chiang 已提交
560
	for t in $(SUBSET); do echo "===== Running $$t"; ./$$t || exit 1; done
561 562

.PHONY: ldb_tests
563
ldb_tests: ldb
Y
Yueh-Hsuan Chiang 已提交
564
	python tools/ldb_test.py
565

I
Igor Canadi 已提交
566
crash_test: whitebox_crash_test blackbox_crash_test
567 568

blackbox_crash_test: db_stress
S
sdong 已提交
569
	python -u tools/db_crashtest.py -s
Y
Yueh-Hsuan Chiang 已提交
570
	python -u tools/db_crashtest.py
571 572

whitebox_crash_test: db_stress
S
sdong 已提交
573
	python -u tools/db_crashtest2.py -s
Y
Yueh-Hsuan Chiang 已提交
574
	python -u tools/db_crashtest2.py
575

I
Igor Canadi 已提交
576
asan_check:
Y
Yueh-Hsuan Chiang 已提交
577 578 579
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) check -j32
	$(MAKE) clean
580 581

asan_crash_test:
Y
Yueh-Hsuan Chiang 已提交
582 583 584
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test
	$(MAKE) clean
I
Igor Canadi 已提交
585

I
Igor Canadi 已提交
586
valgrind_check: $(TESTS)
Y
Yueh-Hsuan Chiang 已提交
587 588
	for t in $(filter-out skiplist_test,$(TESTS)); do \
		$(VALGRIND_VER) $(VALGRIND_OPTS) ./$$t; \
S
sdong 已提交
589
		ret_code=$$?; \
K
krad 已提交
590
		if [ $$ret_code -ne 0 ]; then \
S
sdong 已提交
591
			exit $$ret_code; \
Y
Yueh-Hsuan Chiang 已提交
592 593
		fi; \
	done
594

595
analyze: clean
Y
Yueh-Hsuan Chiang 已提交
596 597 598 599
	$(CLANG_SCAN_BUILD) --use-analyzer=$(CLANG_ANALYZER) \
		--use-c++=$(CXX) --use-cc=$(CC) --status-bugs \
		-o $(CURDIR)/scan_build_report \
		$(MAKE) dbg
600

601 602
CLEAN_FILES += unity.cc
unity.cc: Makefile
Y
Yueh-Hsuan Chiang 已提交
603 604
	rm -f $@ $@-t
	for source_file in $(LIB_SOURCES); do \
E
Evan Shaw 已提交
605
		echo "#include \"$$source_file\"" >> $@-t; \
Y
Yueh-Hsuan Chiang 已提交
606 607 608
	done
	chmod a=r $@-t
	mv $@-t $@
M
miguelportilla 已提交
609

E
Evan Shaw 已提交
610 611 612 613
unity.a: unity.o
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ unity.o

I
Igor Canadi 已提交
614
# try compiling db_test with unity
615
unity_test: db/db_test.o db/db_test_util.o $(TESTHARNESS) unity.a
I
Igor Canadi 已提交
616 617 618
	$(AM_LINK)
	./unity_test

E
Evan Shaw 已提交
619 620
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 已提交
621

J
jorlow@chromium.org 已提交
622
clean:
Y
Yueh-Hsuan Chiang 已提交
623 624 625 626 627
	rm -f $(BENCHMARKS) $(TOOLS) $(TESTS) $(LIBRARY) $(SHARED)
	rm -rf $(CLEAN_FILES) ios-x86 ios-arm scan_build_report
	find . -name "*.[oda]" -exec rm -f {} \;
	find . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
	rm -rf bzip2* snappy* zlib* lz4*
628

629
tags:
Y
Yueh-Hsuan Chiang 已提交
630 631
	ctags * -R
	cscope -b `find . -name '*.cc'` `find . -name '*.h'`
632

633
format:
Y
Yueh-Hsuan Chiang 已提交
634
	build_tools/format-diff.sh
635

636
package:
Y
Yueh-Hsuan Chiang 已提交
637
	bash build_tools/make_package.sh $(SHARED_MAJOR).$(SHARED_MINOR)
638

639 640 641
# ---------------------------------------------------------------------------
# 	Unit tests and tools
# ---------------------------------------------------------------------------
642
$(LIBRARY): $(LIBOBJECTS)
Y
Yueh-Hsuan Chiang 已提交
643 644
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(LIBOBJECTS)
J
jorlow@chromium.org 已提交
645

646
db_bench: db/db_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
647
	$(AM_LINK)
J
jorlow@chromium.org 已提交
648

F
Feng Zhu 已提交
649
cache_bench: util/cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
650
	$(AM_LINK)
J
jorlow@chromium.org 已提交
651

A
Ameya Gupte 已提交
652
memtablerep_bench: db/memtablerep_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
653
	$(AM_LINK)
A
Ameya Gupte 已提交
654

K
kailiu 已提交
655
block_hash_index_test: table/block_hash_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
656
	$(AM_LINK)
K
kailiu 已提交
657

658
db_stress: tools/db_stress.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
659
	$(AM_LINK)
660

I
Igor Canadi 已提交
661
db_sanity_test: tools/db_sanity_test.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
662
	$(AM_LINK)
663

664
db_repl_stress: tools/db_repl_stress.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
665
	$(AM_LINK)
666

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

K
kailiu 已提交
670
autovector_test: util/autovector_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
671
	$(AM_LINK)
K
kailiu 已提交
672

673
column_family_test: db/column_family_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
674
	$(AM_LINK)
675

K
kailiu 已提交
676
table_properties_collector_test: db/table_properties_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
677
	$(AM_LINK)
678

S
Sanjay Ghemawat 已提交
679
bloom_test: util/bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
680
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
681

682
dynamic_bloom_test: util/dynamic_bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
683
	$(AM_LINK)
684

685
c_test: db/c_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
686
	$(AM_LINK)
687

J
jorlow@chromium.org 已提交
688
cache_test: util/cache_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
689
	$(AM_LINK)
J
jorlow@chromium.org 已提交
690 691

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

694
stringappend_test: utilities/merge_operators/string_append/stringappend_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
695
	$(AM_LINK)
696

697
redis_test: utilities/redis/redis_lists_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
698
	$(AM_LINK)
699

A
Abhishek Kona 已提交
700
histogram_test: util/histogram_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
701
	$(AM_LINK)
A
Abhishek Kona 已提交
702

L
Lei Jin 已提交
703
thread_local_test: util/thread_local_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
704
	$(AM_LINK)
L
Lei Jin 已提交
705

J
jorlow@chromium.org 已提交
706
corruption_test: db/corruption_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
707
	$(AM_LINK)
J
jorlow@chromium.org 已提交
708 709

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

712
slice_transform_test: util/slice_transform_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
713
	$(AM_LINK)
714

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

718
db_log_iter_test: db/db_log_iter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
719
	$(AM_LINK)
720

721
db_compaction_filter_test: db/db_compaction_filter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
722 723
	$(AM_LINK)

724
db_compaction_test: db/db_compaction_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
725 726
	$(AM_LINK)

727
db_dynamic_level_test: db/db_dynamic_level_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
728 729
	$(AM_LINK)

730
db_inplace_update_test: db/db_inplace_update_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
731 732
	$(AM_LINK)

733
db_tailing_iter_test: db/db_tailing_iter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
734 735
	$(AM_LINK)

S
Stanislau Hlebik 已提交
736
db_iter_test: db/db_iter_test.o $(LIBOBJECTS) $(TESTHARNESS)
737
	$(AM_LINK)
S
Stanislau Hlebik 已提交
738

739
db_universal_compaction_test: db/db_universal_compaction_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
740 741
	$(AM_LINK)

742
db_wal_test: db/db_wal_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
S
sdong 已提交
743 744
	$(AM_LINK)

745 746 747
db_table_properties_test: db/db_table_properties_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

748
log_write_bench: util/log_write_bench.o $(LIBOBJECTS) $(TESTHARNESS)
749
	$(AM_LINK) $(pg)
750

S
Siying Dong 已提交
751
plain_table_db_test: db/plain_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
752
	$(AM_LINK)
S
Siying Dong 已提交
753

754
comparator_db_test: db/comparator_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
755
	$(AM_LINK)
756

757
table_reader_bench: table/table_reader_bench.o $(LIBOBJECTS) $(TESTHARNESS)
758
	$(AM_LINK) $(pg)
759

760
perf_context_test: db/perf_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
761
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)
762

H
Haobo Xu 已提交
763
prefix_test: db/prefix_test.o $(LIBOBJECTS) $(TESTHARNESS)
764
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)
H
Haobo Xu 已提交
765

I
Igor Canadi 已提交
766
backupable_db_test: utilities/backupable/backupable_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
767
	$(AM_LINK)
I
Igor Canadi 已提交
768

769 770 771
checkpoint_test: utilities/checkpoint/checkpoint_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
772
document_db_test: utilities/document/document_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
773
	$(AM_LINK)
I
Igor Canadi 已提交
774

I
Igor Canadi 已提交
775
json_document_test: utilities/document/json_document_test.o $(LIBOBJECTS) $(TESTHARNESS)
776
	$(AM_LINK)
I
Igor Canadi 已提交
777

I
Igor Canadi 已提交
778
spatial_db_test: utilities/spatialdb/spatial_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
779
	$(AM_LINK)
I
Igor Canadi 已提交
780

781
ttl_test: utilities/ttl/ttl_test.o $(LIBOBJECTS) $(TESTHARNESS)
782
	$(AM_LINK)
783

784
write_batch_with_index_test: utilities/write_batch_with_index/write_batch_with_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
785
	$(AM_LINK)
786

I
Igor Canadi 已提交
787
flush_job_test: db/flush_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
788
	$(AM_LINK)
A
Andres Noetzli 已提交
789 790 791

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

I
Igor Canadi 已提交
793
compaction_job_test: db/compaction_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
794
	$(AM_LINK)
I
Igor Canadi 已提交
795

796 797 798
compaction_job_stats_test: db/compaction_job_stats_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

799 800 801
compact_on_deletion_collector_test: utilities/table_properties_collectors/compact_on_deletion_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
802
wal_manager_test: db/wal_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
803
	$(AM_LINK)
I
Igor Canadi 已提交
804

J
jorlow@chromium.org 已提交
805
dbformat_test: db/dbformat_test.o $(LIBOBJECTS) $(TESTHARNESS)
806
	$(AM_LINK)
J
jorlow@chromium.org 已提交
807 808

env_test: util/env_test.o $(LIBOBJECTS) $(TESTHARNESS)
809
	$(AM_LINK)
J
jorlow@chromium.org 已提交
810

811
fault_injection_test: db/fault_injection_test.o $(LIBOBJECTS) $(TESTHARNESS)
812
	$(AM_LINK)
813

L
Lei Jin 已提交
814
rate_limiter_test: util/rate_limiter_test.o $(LIBOBJECTS) $(TESTHARNESS)
815
	$(AM_LINK)
L
Lei Jin 已提交
816

I
Islam AbdelRahman 已提交
817 818 819
delete_scheduler_test: util/delete_scheduler_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
jorlow@chromium.org 已提交
820
filename_test: db/filename_test.o $(LIBOBJECTS) $(TESTHARNESS)
821
	$(AM_LINK)
J
jorlow@chromium.org 已提交
822

823 824 825
file_reader_writer_test: util/file_reader_writer_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

826
block_based_filter_block_test: table/block_based_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
827
	$(AM_LINK)
828 829

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

J
jorlow@chromium.org 已提交
832
log_test: db/log_test.o $(LIBOBJECTS) $(TESTHARNESS)
833
	$(AM_LINK)
J
jorlow@chromium.org 已提交
834 835

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

D
Dhruba Borthakur 已提交
838
block_test: table/block_test.o $(LIBOBJECTS) $(TESTHARNESS)
839
	$(AM_LINK)
D
Dhruba Borthakur 已提交
840

J
jorlow@chromium.org 已提交
841
skiplist_test: db/skiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
842
	$(AM_LINK)
J
jorlow@chromium.org 已提交
843 844

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

847
version_set_test: db/version_set_test.o $(LIBOBJECTS) $(TESTHARNESS)
848
	$(AM_LINK)
849

S
sdong 已提交
850
compaction_picker_test: db/compaction_picker_test.o $(LIBOBJECTS) $(TESTHARNESS)
851
	$(AM_LINK)
S
sdong 已提交
852

S
sdong 已提交
853
version_builder_test: db/version_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
854
	$(AM_LINK)
S
sdong 已提交
855

856
file_indexer_test: db/file_indexer_test.o $(LIBOBJECTS) $(TESTHARNESS)
857
	$(AM_LINK)
858

859
reduce_levels_test: tools/reduce_levels_test.o $(LIBOBJECTS) $(TESTHARNESS)
860
	$(AM_LINK)
861

J
jorlow@chromium.org 已提交
862
write_batch_test: db/write_batch_test.o $(LIBOBJECTS) $(TESTHARNESS)
863
	$(AM_LINK)
864

865
write_controller_test: db/write_controller_test.o $(LIBOBJECTS) $(TESTHARNESS)
866
	$(AM_LINK)
867

868 869 870
merge_helper_test: db/merge_helper_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
Jim Paton 已提交
871
merge_test: db/merge_test.o $(LIBOBJECTS) $(TESTHARNESS)
872
	$(AM_LINK)
J
jorlow@chromium.org 已提交
873

I
Igor Canadi 已提交
874
merger_test: table/merger_test.o $(LIBOBJECTS) $(TESTHARNESS)
875
	$(AM_LINK)
I
Igor Canadi 已提交
876

877
deletefile_test: db/deletefile_test.o $(LIBOBJECTS) $(TESTHARNESS)
878
	$(AM_LINK)
879

880
geodb_test: utilities/geodb/geodb_test.o $(LIBOBJECTS) $(TESTHARNESS)
881
	$(AM_LINK)
882

883 884 885 886 887 888
rocksdb_dump: tools/dump/rocksdb_dump.o $(LIBOBJECTS)
	$(AM_LINK)

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

889
cuckoo_table_builder_test: table/cuckoo_table_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
890
	$(AM_LINK)
891

I
Igor Canadi 已提交
892
cuckoo_table_reader_test: table/cuckoo_table_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
893
	$(AM_LINK)
894

895
cuckoo_table_db_test: db/cuckoo_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
896
	$(AM_LINK)
897

898
listener_test: db/listener_test.o $(LIBOBJECTS) $(TESTHARNESS)
899
	$(AM_LINK)
900

Y
Yueh-Hsuan Chiang 已提交
901
thread_list_test: util/thread_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
902
	$(AM_LINK)
Y
Yueh-Hsuan Chiang 已提交
903

904 905 906
compact_files_test: db/compact_files_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

907
options_test: util/options_test.o $(LIBOBJECTS) $(TESTHARNESS)
908
	$(AM_LINK)
909

I
Igor Canadi 已提交
910 911 912
event_logger_test: util/event_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

913
sst_dump_test: tools/sst_dump_test.o $(LIBOBJECTS) $(TESTHARNESS)
914
	$(AM_LINK)
915

916
memenv_test : util/memenv_test.o $(LIBOBJECTS) $(TESTHARNESS)
917
	$(AM_LINK)
H
Hans Wennborg 已提交
918

A
agiardullo 已提交
919 920 921
optimistic_transaction_test: utilities/transactions/optimistic_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

922
mock_env_test : util/mock_env_test.o $(LIBOBJECTS) $(TESTHARNESS)
923
	$(AM_LINK)
924

925
manual_compaction_test: db/manual_compaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
926
	$(AM_LINK)
927

928
filelock_test: util/filelock_test.o $(LIBOBJECTS) $(TESTHARNESS)
929
	$(AM_LINK)
K
Kai Liu 已提交
930 931

auto_roll_logger_test: util/auto_roll_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
932
	$(AM_LINK)
933

A
agiardullo 已提交
934 935 936
memtable_list_test: db/memtable_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
agiardullo 已提交
937 938 939
write_callback_test: db/write_callback_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

940 941 942
heap_test: util/heap_test.o $(GTEST)
	$(AM_LINK)

A
agiardullo 已提交
943 944 945
transaction_test: utilities/transactions/transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

946
sst_dump: tools/sst_dump.o $(LIBOBJECTS)
947
	$(AM_LINK)
948

949
ldb_cmd_test: tools/ldb_cmd_test.o $(LIBOBJECTS) $(TESTHARNESS)
950 951
	$(AM_LINK)

952
ldb: tools/ldb.o $(LIBOBJECTS)
953
	$(AM_LINK)
954

I
Igor Canadi 已提交
955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986
#-------------------------------------------------
# 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
	for header_dir in `find "include/rocksdb" -type d`; do \
		install -d $(INSTALL_PATH)/$$header_dir; \
	done
	for header in `find "include/rocksdb" -type f -name *.h`; do \
		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 已提交
987
	[ -e $(SHARED4) ] && $(MAKE) install-shared || :
I
Igor Canadi 已提交
988 989 990 991

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


992 993 994 995
# ---------------------------------------------------------------------------
# Jni stuff
# ---------------------------------------------------------------------------

996
JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux
997 998
ARCH := $(shell getconf LONG_BIT)
ROCKSDBJNILIB = librocksdbjni-linux$(ARCH).so
999
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH).jar
1000
ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
C
Chris Riccomini 已提交
1001
ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar
1002
ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar
1003 1004

ifeq ($(PLATFORM), OS_MACOSX)
1005
ROCKSDBJNILIB = librocksdbjni-osx.jnilib
1006
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar
1007 1008 1009 1010 1011
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
1012 1013
endif

N
Naveen 已提交
1014 1015
libz.a:
	-rm -rf zlib-1.2.8
N
Naveen 已提交
1016 1017 1018
	curl -O http://zlib.net/zlib-1.2.8.tar.gz
	tar xvzf zlib-1.2.8.tar.gz
	cd zlib-1.2.8 && CFLAGS='-fPIC' ./configure --static && make
1019
	cp zlib-1.2.8/libz.a .
N
Naveen 已提交
1020 1021 1022

libbz2.a:
	-rm -rf bzip2-1.0.6
1023
	curl -O  http://www.bzip.org/1.0.6/bzip2-1.0.6.tar.gz
N
Naveen 已提交
1024
	tar xvzf bzip2-1.0.6.tar.gz
1025
	cd bzip2-1.0.6 && make CFLAGS='-fPIC -O2 -g -D_FILE_OFFSET_BITS=64'
N
Naveen 已提交
1026 1027
	cp bzip2-1.0.6/libbz2.a .

N
Naveen 已提交
1028 1029
libsnappy.a:
	-rm -rf snappy-1.1.1
N
Naveen 已提交
1030 1031
	curl -O https://snappy.googlecode.com/files/snappy-1.1.1.tar.gz
	tar xvzf snappy-1.1.1.tar.gz
N
Naveen 已提交
1032
	cd snappy-1.1.1 && ./configure --with-pic --enable-static
N
Naveen 已提交
1033 1034
	cd snappy-1.1.1 && make
	cp snappy-1.1.1/.libs/libsnappy.a .
1035

1036 1037 1038 1039 1040 1041 1042
liblz4.a:
	   -rm -rf lz4-r127
	   curl -O https://codeload.github.com/Cyan4973/lz4/tar.gz/r127
	   mv r127 lz4-r127.tar.gz
	   tar xvzf lz4-r127.tar.gz
	   cd lz4-r127/lib && make CFLAGS='-fPIC' all
	   cp lz4-r127/lib/liblz4.a .
N
Naveen 已提交
1043

1044 1045 1046
# A version of each $(LIBOBJECTS) compiled with -fPIC and a fixed set of static compression libraries
java_static_libobjects = $(patsubst %,jls/%,$(LIBOBJECTS))
CLEAN_FILES += jls
1047

1048 1049 1050 1051 1052
JAVA_STATIC_FLAGS = -DZLIB -DBZIP2 -DSNAPPY -DLZ4
JAVA_STATIC_INCLUDES = -I./zlib-1.2.8 -I./bzip2-1.0.6 -I./snappy-1.1.1 -I./lz4-r127/lib

$(java_static_libobjects): jls/%.o: %.cc libz.a libbz2.a libsnappy.a liblz4.a
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES) -fPIC -c $< -o $@ $(COVERAGEFLAGS)
1053

1054
rocksdbjavastatic: $(java_static_libobjects)
F
fyrz 已提交
1055
	cd java;$(MAKE) javalib;
1056
	rm -f ./java/target/$(ROCKSDBJNILIB)
1057 1058
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC \
	  -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) \
1059
	  $(java_static_libobjects) $(COVERAGEFLAGS) \
1060
	  libz.a libbz2.a libsnappy.a liblz4.a $(JAVA_STATIC_LDFLAGS)
1061 1062 1063 1064 1065 1066
	cd java/target;strip -S -x $(ROCKSDBJNILIB)
	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 已提交
1067

1068
rocksdbjavastaticrelease: rocksdbjavastatic
1069
	cd java/crossbuild && vagrant destroy -f && vagrant up linux32 && vagrant halt linux32 && vagrant up linux64 && vagrant halt linux64
1070
	cd java;jar -cf target/$(ROCKSDB_JAR_ALL) HISTORY*.md
1071
	cd java/target;jar -uf $(ROCKSDB_JAR_ALL) librocksdbjni-*.so librocksdbjni-*.jnilib
1072
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR_ALL) org/rocksdb/*.class org/rocksdb/util/*.class
1073

1074
rocksdbjavastaticpublish: rocksdbjavastaticrelease
1075 1076 1077 1078 1079 1080
	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
	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
1081

1082 1083 1084 1085 1086 1087 1088
# A version of each $(LIBOBJECTS) compiled with -fPIC
java_libobjects = $(patsubst %,jl/%,$(LIBOBJECTS))
CLEAN_FILES += jl

$(java_libobjects): jl/%.o: %.cc
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) -fPIC -c $< -o $@ $(COVERAGEFLAGS)

1089
rocksdbjava: $(java_libobjects)
1090 1091 1092 1093 1094 1095
	$(AM_V_GEN)cd java;$(MAKE) javalib;
	$(AM_V_at)rm -f ./java/target/$(ROCKSDBJNILIB)
	$(AM_V_at)$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) $(java_libobjects) $(JAVA_LDFLAGS) $(COVERAGEFLAGS)
	$(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
1096 1097 1098 1099

jclean:
	cd java;$(MAKE) clean;

1100
jtest: rocksdbjava
1101
	cd java;$(MAKE) sample;$(MAKE) test;
1102

1103 1104 1105
jdb_bench:
	cd java;$(MAKE) db_bench;

1106 1107
commit-prereq:
	$(MAKE) clean && $(MAKE) all check;
1108
	$(MAKE) clean && $(MAKE) jclean && $(MAKE) rocksdbjava;
1109
	$(MAKE) clean && USE_CLANG=1 $(MAKE) all;
1110
	$(MAKE) clean && OPT=-DROCKSDB_LITE $(MAKE) static_lib;
1111

V
Venkatesh Radhakrishnan 已提交
1112 1113 1114 1115 1116 1117 1118
xfunc:
	for xftest in $(XFUNC_TESTS); do \
		echo "===== Running xftest $$xftest"; \
		make check ROCKSDB_XFUNC_TEST="$$xftest" tests-regexp="DBTest" ;\
	done


1119 1120 1121
# ---------------------------------------------------------------------------
#  	Platform-specific compilation
# ---------------------------------------------------------------------------
J
Jim Paton 已提交
1122

1123 1124 1125
ifeq ($(PLATFORM), IOS)
# For iOS, create universal object files to be used on both the simulator and
# a device.
H
heyongqiang 已提交
1126 1127 1128
PLATFORMSROOT=/Applications/Xcode.app/Contents/Developer/Platforms
SIMULATORROOT=$(PLATFORMSROOT)/iPhoneSimulator.platform/Developer
DEVICEROOT=$(PLATFORMSROOT)/iPhoneOS.platform/Developer
I
Igor Canadi 已提交
1129
IOSVERSION=$(shell defaults read $(PLATFORMSROOT)/iPhoneOS.platform/version CFBundleShortVersionString)
1130

1131 1132
.cc.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
1133
	$(CXX) $(CXXFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
1134
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
1135
	xcrun -sdk iphoneos $(CXX) $(CXXFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
1136
	lipo ios-x86/$@ ios-arm/$@ -create -output $@
1137 1138 1139

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

1145
else
J
jorlow@chromium.org 已提交
1146
.cc.o:
1147
	$(AM_V_CC)$(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
1148 1149

.c.o:
1150
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
1151
endif
1152

1153 1154 1155 1156
# ---------------------------------------------------------------------------
#  	Source files dependencies detection
# ---------------------------------------------------------------------------

1157 1158 1159
all_sources = $(LIB_SOURCES) $(TEST_BENCH_SOURCES) $(MOCK_SOURCES)
DEPFILES = $(all_sources:.cc=.d)

1160 1161 1162 1163 1164
# 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.
1165
$(DEPFILES): %.d: %.cc
1166
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
1167
	  -MM -MT'$@' -MT'$(<:.cc=.o)' "$<" -o '$@'
1168 1169 1170

depend: $(DEPFILES)

1171 1172 1173 1174
# 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.
1175
ifneq ($(MAKECMDGOALS),clean)
1176
ifneq ($(MAKECMDGOALS),format)
1177 1178
ifneq ($(MAKECMDGOALS),jclean)
ifneq ($(MAKECMDGOALS),jtest)
1179
ifneq ($(MAKECMDGOALS),package)
1180
ifneq ($(MAKECMDGOALS),analyze)
1181 1182
-include $(DEPFILES)
endif
1183
endif
1184 1185
endif
endif
1186
endif
1187
endif