Makefile 35.3 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 18 19 20 21 22 23
# Transform parallel LOG output into something more readable.
perl_command = perl -n \
  -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'
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 39
# `make install-shared`, `make static_lib`, `make install-static` or
# `make install`
DEBUG_LEVEL=1

ifeq ($(MAKECMDGOALS),dbg)
	DEBUG_LEVEL=2
40
endif
41 42

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

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

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

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

ifeq ($(MAKECMDGOALS),install)
59 60 61
	DEBUG_LEVEL=0
endif

62 63 64 65
ifeq ($(MAKECMDGOALS),rocksdbjavastatic)
	DEBUG_LEVEL=0
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
I
Igor Canadi 已提交
79 80
endif

81
#-----------------------------------------------
82
include src.mk
83

84 85 86 87 88 89
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 已提交
90 91 92 93
AM_V_at = $(am__v_at_$(V))
am__v_at_ = $(am__v_at_$(AM_DEFAULT_VERBOSITY))
am__v_at_0 = @
am__v_at_1 =
94 95 96 97 98 99 100 101 102 103 104

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 已提交
105 106 107 108
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 =
109

110 111
AM_LINK = $(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(COVERAGEFLAGS)

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

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

126
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
127 128 129 130 131
	# found
	CFLAGS += -fno-exceptions
	CXXFLAGS += -fno-exceptions
endif

I
Igor Canadi 已提交
132 133
# ASAN doesn't work well with jemalloc. If we're compiling with ASAN, we should use regular malloc.
ifdef COMPILE_WITH_ASAN
I
Igor Canadi 已提交
134
	DISABLE_JEMALLOC=1
I
Igor Canadi 已提交
135 136 137
	EXEC_LDFLAGS += -fsanitize=address
	PLATFORM_CCFLAGS += -fsanitize=address
	PLATFORM_CXXFLAGS += -fsanitize=address
I
Igor Canadi 已提交
138 139 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
	DISABLE_JEMALLOC=1
	EXEC_LDFLAGS += -fsanitize=thread -pie
144 145
	PLATFORM_CCFLAGS += -fsanitize=thread -fPIC -DROCKSDB_TSAN_RUN
	PLATFORM_CXXFLAGS += -fsanitize=thread -fPIC -DROCKSDB_TSAN_RUN
146 147 148 149 150
        # Turn off -pg when enabling TSAN testing, because that induces
        # a link failure.  TODO: find the root cause
	pg =
else
	pg = -pg
I
Igor Canadi 已提交
151 152 153
endif

ifndef DISABLE_JEMALLOC
I
Igor Canadi 已提交
154
	EXEC_LDFLAGS := $(JEMALLOC_LIB) $(EXEC_LDFLAGS)
155 156
	PLATFORM_CXXFLAGS += $(JEMALLOC_INCLUDE)
	PLATFORM_CCFLAGS += $(JEMALLOC_INCLUDE)
I
Igor Canadi 已提交
157 158
endif

I
Igor Sugak 已提交
159 160 161 162 163
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)

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

167
WARNING_FLAGS = -W -Wextra -Wall -Wsign-compare -Wshadow \
168 169
  -Wno-unused-parameter

170 171 172 173
ifndef DISABLE_WARNING_AS_ERROR
	WARNING_FLAGS += -Werror
endif

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

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

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

# 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.
199
CLEAN_FILES += util/build_version.cc:
200 201 202 203 204 205 206
FORCE:
util/build_version.cc: FORCE
	$(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
207

208
LIBOBJECTS = $(LIB_SOURCES:.cc=.o)
209
MOCKOBJECTS = $(MOCK_SOURCES:.cc=.o)
J
jorlow@chromium.org 已提交
210

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

218
VALGRIND_OPTS = --error-exitcode=$(VALGRIND_ERROR) --leak-check=full
219

J
jorlow@chromium.org 已提交
220
TESTS = \
221
	db_test \
S
Stanislau Hlebik 已提交
222
	db_iter_test \
223
	db_log_iter_test \
224
	db_dynamic_level_test \
225
	db_tailing_iter_test \
K
kailiu 已提交
226
	block_hash_index_test \
227
	autovector_test \
228
	column_family_test \
K
kailiu 已提交
229
	table_properties_collector_test \
J
jorlow@chromium.org 已提交
230
	arena_test \
J
Jim Paton 已提交
231 232
	auto_roll_logger_test \
	block_test \
S
Sanjay Ghemawat 已提交
233
	bloom_test \
234
	dynamic_bloom_test \
235
	c_test \
J
jorlow@chromium.org 已提交
236
	cache_test \
237
	checkpoint_test \
J
jorlow@chromium.org 已提交
238 239 240
	coding_test \
	corruption_test \
	crc32c_test \
241
	slice_transform_test \
J
jorlow@chromium.org 已提交
242 243
	dbformat_test \
	env_test \
244
	fault_injection_test \
J
Jim Paton 已提交
245
	filelock_test \
J
jorlow@chromium.org 已提交
246
	filename_test \
247 248
	block_based_filter_block_test \
	full_filter_block_test \
J
Jim Paton 已提交
249
	histogram_test \
J
jorlow@chromium.org 已提交
250
	log_test \
J
Jim Paton 已提交
251
	manual_compaction_test \
H
Hans Wennborg 已提交
252
	memenv_test \
253
	mock_env_test \
A
agiardullo 已提交
254
	memtable_list_test \
J
Jim Paton 已提交
255
	merge_test \
I
Igor Canadi 已提交
256
	merger_test \
J
Jim Paton 已提交
257 258
	redis_test \
	reduce_levels_test \
S
Siying Dong 已提交
259
	plain_table_db_test \
260
	comparator_db_test \
I
Igor Canadi 已提交
261
	prefix_test \
J
jorlow@chromium.org 已提交
262
	skiplist_test \
J
Jim Paton 已提交
263
	stringappend_test \
264
	ttl_test \
I
Igor Canadi 已提交
265
	backupable_db_test \
I
Igor Canadi 已提交
266
	document_db_test \
I
Igor Canadi 已提交
267
	json_document_test \
I
Igor Canadi 已提交
268
	spatial_db_test \
J
jorlow@chromium.org 已提交
269
	version_edit_test \
270
	version_set_test \
L
Lei Jin 已提交
271
	compaction_picker_test \
S
sdong 已提交
272
	version_builder_test \
273
	file_indexer_test \
274
	write_batch_test \
I
Igor Canadi 已提交
275
	write_batch_with_index_test \
276
	write_controller_test\
K
kailiu 已提交
277
	deletefile_test \
L
Lei Jin 已提交
278
	table_test \
279
	thread_local_test \
280
	geodb_test \
L
Lei Jin 已提交
281
	rate_limiter_test \
282
	options_test \
I
Igor Canadi 已提交
283
	event_logger_test \
284 285
	cuckoo_table_builder_test \
	cuckoo_table_reader_test \
286
	cuckoo_table_db_test \
I
Igor Canadi 已提交
287
	flush_job_test \
288 289
	wal_manager_test \
	listener_test \
Y
Yueh-Hsuan Chiang 已提交
290
	compaction_job_test \
291
	thread_list_test \
292
	sst_dump_test \
I
Igor Canadi 已提交
293
	compact_files_test \
A
agiardullo 已提交
294 295
	perf_context_test \
	optimistic_transaction_test \
296 297
	write_callback_test \
	compaction_job_stats_test
298

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

301
TOOLS = \
I
Igor Canadi 已提交
302
	sst_dump \
I
Igor Canadi 已提交
303
	db_sanity_test \
I
Igor Canadi 已提交
304 305
	db_stress \
	ldb \
306 307 308
	db_repl_stress \
	rocksdb_dump \
	rocksdb_undump
J
jorlow@chromium.org 已提交
309

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

312 313
# The library name is configurable since we are maintaining libraries of both
# debug/release mode.
314 315 316
ifeq ($(LIBNAME),)
        LIBNAME=librocksdb
endif
317
LIBRARY = ${LIBNAME}.a
318

319 320 321
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)
322

323 324
default: all

325 326 327
#-----------------------------------------------
# Create platform independent shared libraries.
#-----------------------------------------------
328
ifneq ($(PLATFORM_SHARED_EXT),)
H
heyongqiang 已提交
329 330

ifneq ($(PLATFORM_SHARED_VERSIONED),true)
331
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
H
heyongqiang 已提交
332 333
SHARED2 = $(SHARED1)
SHARED3 = $(SHARED1)
334
SHARED4 = $(SHARED1)
H
heyongqiang 已提交
335 336
SHARED = $(SHARED1)
else
337 338
SHARED_MAJOR = $(ROCKSDB_MAJOR)
SHARED_MINOR = $(ROCKSDB_MINOR)
339
SHARED_PATCH = $(ROCKSDB_PATCH)
340
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
341 342
SHARED2 = $(SHARED1).$(SHARED_MAJOR)
SHARED3 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR)
343 344 345 346 347 348 349 350
SHARED4 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR).$(SHARED_PATCH)
SHARED = $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4)
$(SHARED1): $(SHARED4)
	ln -fs $(SHARED4) $(SHARED1)
$(SHARED2): $(SHARED4)
	ln -fs $(SHARED4) $(SHARED2)
$(SHARED3): $(SHARED4)
	ln -fs $(SHARED4) $(SHARED3)
351 352
endif

353
$(SHARED4):
354
	$(CXX) $(PLATFORM_SHARED_LDFLAGS)$(SHARED3) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) $(LIB_SOURCES) \
355
		$(LDFLAGS) -o $@
H
heyongqiang 已提交
356 357 358

endif  # PLATFORM_SHARED_EXT

359
.PHONY: blackbox_crash_test check clean coverage crash_test ldb_tests package \
I
Igor Canadi 已提交
360
	release tags valgrind_check whitebox_crash_test format static_lib shared_lib all \
I
Igor Canadi 已提交
361 362
	dbg rocksdbjavastatic rocksdbjava install install-static install-shared uninstall \
	analyze
363

I
Igor Canadi 已提交
364
all: $(LIBRARY) $(BENCHMARKS) $(TOOLS) $(TESTS)
365

I
Igor Canadi 已提交
366 367 368 369
static_lib: $(LIBRARY)

shared_lib: $(SHARED)

I
Igor Canadi 已提交
370
dbg: $(LIBRARY) $(BENCHMARKS) $(TOOLS) $(TESTS)
K
Kai Liu 已提交
371

372
# creates static library and programs
373
release:
K
Kai Liu 已提交
374
	$(MAKE) clean
375
	OPT="-DNDEBUG -O2" $(MAKE) static_lib $(TOOLS) db_bench
K
Kai Liu 已提交
376 377 378

coverage:
	$(MAKE) clean
379
	COVERAGEFLAGS="-fprofile-arcs -ftest-coverage" LDFLAGS+="-lgcov" $(MAKE) all check
380 381
	cd coverage && ./coverage_test.sh
        # Delete intermediate files
382
	find . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
J
jorlow@chromium.org 已提交
383

384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418
# 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 = \
  ./db_test --gtest_list_tests						\
    | perl -n								\
      -e 's/ *\#.*//;'							\
      -e '/^(\s*)(\S+)/; !$$1 and do {$$p=$$2; break};'			\
      -e 'print qq! $$p$$2!'

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;			\
  perl -le 'use File::Temp "tempdir";'					\
    -e 'print tempdir("'$$f'/rocksdb.XXXX", CLEANUP => 0)')
endif
endif
J
jorlow@chromium.org 已提交
419

420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478
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
	$(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 $@

# 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 = \
  ^t/DBTest\.(?:FileCreationRandomFailure|EncodeDecompressedBlockSizeTest)$$
prioritize_long_running_tests =						\
  perl -pe 's,($(slow_test_regexp)),100 $$1,'				\
    | sort -k1,1gr							\
    | sed 's/^[.0-9]* //'

# "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 已提交
479 480 481
# Use this regexp to select the subset of tests whose names match.
tests-regexp = .

482 483 484 485 486 487 488 489 490 491 492 493
.PHONY: check_0
check_0: $(t_run)
	$(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)				\
V
Venkatesh Radhakrishnan 已提交
494
	  | grep -E '$(tests-regexp)'					\
495 496 497 498
	  | parallel -j$(J) --joblog=LOG $$eta --gnu '{} >& t/log-{/}'
endif

CLEAN_FILES += t LOG $(TMPD)
499

500 501 502 503 504 505 506 507 508 509
# 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:
	watch --interval=0 'sort -k7,7nr -k4,4gr LOG|$(quoted_perl_command)'

I
Igor Canadi 已提交
510
# If J != 1 and GNU parallel is installed, run the tests in parallel,
511 512
# via the check_0 rule above.  Otherwise, run them sequentially.
check: all
I
Igor Canadi 已提交
513 514 515 516 517 518 519 520 521 522
	$(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
523
	rm -rf $(TMPD)
524
	python tools/ldb_test.py
525
	sh tools/rocksdb_dump_test.sh
526 527 528 529 530

check_some: $(SUBSET) ldb_tests
	for t in $(SUBSET); do echo "===== Running $$t"; ./$$t || exit 1; done

.PHONY: ldb_tests
531
ldb_tests: ldb
532 533
	python tools/ldb_test.py

I
Igor Canadi 已提交
534
crash_test: whitebox_crash_test blackbox_crash_test
535 536

blackbox_crash_test: db_stress
537
	python -u tools/db_crashtest.py
538 539

whitebox_crash_test: db_stress
540
	python -u tools/db_crashtest2.py
541

I
Igor Canadi 已提交
542 543 544
asan_check:
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) check -j32
545 546 547 548
	$(MAKE) clean

asan_crash_test:
	$(MAKE) clean
I
Igor Canadi 已提交
549
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test
I
Igor Canadi 已提交
550 551
	$(MAKE) clean

I
Igor Canadi 已提交
552
valgrind_check: $(TESTS)
553
	mkdir -p $(VALGRIND_DIR)
554 555 556 557
	echo TESTS THAT HAVE VALGRIND ERRORS > $(VALGRIND_DIR)/valgrind_failed_tests; \
	echo TIMES in seconds TAKEN BY TESTS ON VALGRIND > $(VALGRIND_DIR)/valgrind_tests_times; \
	for t in $(filter-out skiplist_test,$(TESTS)); do \
		stime=`date '+%s'`; \
558
		$(VALGRIND_VER) $(VALGRIND_OPTS) ./$$t; \
559 560 561 562 563 564
		if [ $$? -eq $(VALGRIND_ERROR) ] ; then \
			echo $$t >> $(VALGRIND_DIR)/valgrind_failed_tests; \
		fi; \
		etime=`date '+%s'`; \
		echo $$t $$((etime - stime)) >> $(VALGRIND_DIR)/valgrind_tests_times; \
	done
565

566 567 568 569 570
analyze: clean
	$(CLANG_SCAN_BUILD) --use-analyzer=$(CLANG_ANALYZER) \
		--use-c++=$(CXX) --use-cc=$(CC) --status-bugs \
		-o $(CURDIR)/scan_build_report \
		$(MAKE) dbg
571

572 573
CLEAN_FILES += unity.cc
unity.cc: Makefile
I
Igor Sugak 已提交
574 575 576 577 578 579 580
	rm -f $@ $@-t
	for source_file in $(LIB_SOURCES); do \
		echo "#include <$$source_file>" >> $@-t; \
	done
	echo 'int main(int argc, char** argv){ return 0; }' >> $@-t
	chmod a=r $@-t
	mv $@-t $@
M
miguelportilla 已提交
581

582
unity: unity.o
583
	$(AM_LINK)
M
miguelportilla 已提交
584

J
jorlow@chromium.org 已提交
585
clean:
586 587
	rm -f $(BENCHMARKS) $(TOOLS) $(TESTS) $(LIBRARY) $(SHARED)
	rm -rf $(CLEAN_FILES) ios-x86 ios-arm scan_build_report
I
Igor Canadi 已提交
588
	find . -name "*.[oda]" -exec rm -f {} \;
589
	find . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
590
	rm -rf bzip2* snappy* zlib* lz4*
591

592 593 594
tags:
	ctags * -R
	cscope -b `find . -name '*.cc'` `find . -name '*.h'`
595

596 597 598
format:
	build_tools/format-diff.sh

599 600 601
package:
	bash build_tools/make_package.sh $(SHARED_MAJOR).$(SHARED_MINOR)

602 603 604
# ---------------------------------------------------------------------------
# 	Unit tests and tools
# ---------------------------------------------------------------------------
605
$(LIBRARY): $(LIBOBJECTS)
J
Jim Meyering 已提交
606 607
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(LIBOBJECTS)
J
jorlow@chromium.org 已提交
608

609
db_bench: db/db_bench.o $(LIBOBJECTS) $(TESTUTIL)
610
	$(AM_LINK)
J
jorlow@chromium.org 已提交
611

F
Feng Zhu 已提交
612
cache_bench: util/cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
613
	$(AM_LINK)
J
jorlow@chromium.org 已提交
614

A
Ameya Gupte 已提交
615
memtablerep_bench: db/memtablerep_bench.o $(LIBOBJECTS) $(TESTUTIL)
616
	$(AM_LINK)
A
Ameya Gupte 已提交
617

K
kailiu 已提交
618
block_hash_index_test: table/block_hash_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
619
	$(AM_LINK)
K
kailiu 已提交
620

621
db_stress: tools/db_stress.o $(LIBOBJECTS) $(TESTUTIL)
622
	$(AM_LINK)
623

I
Igor Canadi 已提交
624
db_sanity_test: tools/db_sanity_test.o $(LIBOBJECTS) $(TESTUTIL)
625
	$(AM_LINK)
626

627
db_repl_stress: tools/db_repl_stress.o $(LIBOBJECTS) $(TESTUTIL)
628
	$(AM_LINK)
629

J
jorlow@chromium.org 已提交
630
arena_test: util/arena_test.o $(LIBOBJECTS) $(TESTHARNESS)
631
	$(AM_LINK)
J
jorlow@chromium.org 已提交
632

K
kailiu 已提交
633
autovector_test: util/autovector_test.o $(LIBOBJECTS) $(TESTHARNESS)
634
	$(AM_LINK)
K
kailiu 已提交
635

636
column_family_test: db/column_family_test.o $(LIBOBJECTS) $(TESTHARNESS)
637
	$(AM_LINK)
638

K
kailiu 已提交
639
table_properties_collector_test: db/table_properties_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
640
	$(AM_LINK)
641

S
Sanjay Ghemawat 已提交
642
bloom_test: util/bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
643
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
644

645
dynamic_bloom_test: util/dynamic_bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
646
	$(AM_LINK)
647

648
c_test: db/c_test.o $(LIBOBJECTS) $(TESTHARNESS)
649
	$(AM_LINK)
650

J
jorlow@chromium.org 已提交
651
cache_test: util/cache_test.o $(LIBOBJECTS) $(TESTHARNESS)
652
	$(AM_LINK)
J
jorlow@chromium.org 已提交
653 654

coding_test: util/coding_test.o $(LIBOBJECTS) $(TESTHARNESS)
655
	$(AM_LINK)
J
jorlow@chromium.org 已提交
656

657
stringappend_test: utilities/merge_operators/string_append/stringappend_test.o $(LIBOBJECTS) $(TESTHARNESS)
658
	$(AM_LINK)
659

660
redis_test: utilities/redis/redis_lists_test.o $(LIBOBJECTS) $(TESTHARNESS)
661
	$(AM_LINK)
662

A
Abhishek Kona 已提交
663
histogram_test: util/histogram_test.o $(LIBOBJECTS) $(TESTHARNESS)
664
	$(AM_LINK)
A
Abhishek Kona 已提交
665

L
Lei Jin 已提交
666
thread_local_test: util/thread_local_test.o $(LIBOBJECTS) $(TESTHARNESS)
667
	$(AM_LINK)
L
Lei Jin 已提交
668

J
jorlow@chromium.org 已提交
669
corruption_test: db/corruption_test.o $(LIBOBJECTS) $(TESTHARNESS)
670
	$(AM_LINK)
J
jorlow@chromium.org 已提交
671 672

crc32c_test: util/crc32c_test.o $(LIBOBJECTS) $(TESTHARNESS)
673
	$(AM_LINK)
J
jorlow@chromium.org 已提交
674

675
slice_transform_test: util/slice_transform_test.o $(LIBOBJECTS) $(TESTHARNESS)
676
	$(AM_LINK)
677

678
db_test: db/db_test.o util/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
679
	$(AM_LINK)
J
jorlow@chromium.org 已提交
680

681 682 683
db_log_iter_test: db/db_log_iter_test.o util/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

684 685 686
db_compaction_filter_test: db/db_compaction_filter_test.o util/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

687 688 689
db_dynamic_level_test: db/db_dynamic_level_test.o util/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

690 691 692
db_tailing_iter_test: db/db_tailing_iter_test.o util/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

S
Stanislau Hlebik 已提交
693
db_iter_test: db/db_iter_test.o $(LIBOBJECTS) $(TESTHARNESS)
694
	$(AM_LINK)
S
Stanislau Hlebik 已提交
695

696 697 698
db_universal_compaction_test: db/db_universal_compaction_test.o util/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

699
log_write_bench: util/log_write_bench.o $(LIBOBJECTS) $(TESTHARNESS)
700
	$(AM_LINK) $(pg)
701

S
Siying Dong 已提交
702
plain_table_db_test: db/plain_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
703
	$(AM_LINK)
S
Siying Dong 已提交
704

705
comparator_db_test: db/comparator_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
706
	$(AM_LINK)
707

708
table_reader_bench: table/table_reader_bench.o $(LIBOBJECTS) $(TESTHARNESS)
709
	$(AM_LINK) $(pg)
710

711
perf_context_test: db/perf_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
712
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)
713

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

I
Igor Canadi 已提交
717
backupable_db_test: utilities/backupable/backupable_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
718
	$(AM_LINK)
I
Igor Canadi 已提交
719

720 721 722
checkpoint_test: utilities/checkpoint/checkpoint_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
723
document_db_test: utilities/document/document_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
724
	$(AM_LINK)
I
Igor Canadi 已提交
725

I
Igor Canadi 已提交
726
json_document_test: utilities/document/json_document_test.o $(LIBOBJECTS) $(TESTHARNESS)
727
	$(AM_LINK)
I
Igor Canadi 已提交
728

I
Igor Canadi 已提交
729
spatial_db_test: utilities/spatialdb/spatial_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
730
	$(AM_LINK)
I
Igor Canadi 已提交
731

732
ttl_test: utilities/ttl/ttl_test.o $(LIBOBJECTS) $(TESTHARNESS)
733
	$(AM_LINK)
734

735
write_batch_with_index_test: utilities/write_batch_with_index/write_batch_with_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
736
	$(AM_LINK)
737

I
Igor Canadi 已提交
738
flush_job_test: db/flush_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
739
	$(AM_LINK)
I
Igor Canadi 已提交
740

I
Igor Canadi 已提交
741
compaction_job_test: db/compaction_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
742
	$(AM_LINK)
I
Igor Canadi 已提交
743

744 745 746
compaction_job_stats_test: db/compaction_job_stats_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
747
wal_manager_test: db/wal_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
748
	$(AM_LINK)
I
Igor Canadi 已提交
749

J
jorlow@chromium.org 已提交
750
dbformat_test: db/dbformat_test.o $(LIBOBJECTS) $(TESTHARNESS)
751
	$(AM_LINK)
J
jorlow@chromium.org 已提交
752 753

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

756
fault_injection_test: db/fault_injection_test.o $(LIBOBJECTS) $(TESTHARNESS)
757
	$(AM_LINK)
758

L
Lei Jin 已提交
759
rate_limiter_test: util/rate_limiter_test.o $(LIBOBJECTS) $(TESTHARNESS)
760
	$(AM_LINK)
L
Lei Jin 已提交
761

J
jorlow@chromium.org 已提交
762
filename_test: db/filename_test.o $(LIBOBJECTS) $(TESTHARNESS)
763
	$(AM_LINK)
J
jorlow@chromium.org 已提交
764

765
block_based_filter_block_test: table/block_based_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
766
	$(AM_LINK)
767 768

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

J
jorlow@chromium.org 已提交
771
log_test: db/log_test.o $(LIBOBJECTS) $(TESTHARNESS)
772
	$(AM_LINK)
J
jorlow@chromium.org 已提交
773 774

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

D
Dhruba Borthakur 已提交
777
block_test: table/block_test.o $(LIBOBJECTS) $(TESTHARNESS)
778
	$(AM_LINK)
D
Dhruba Borthakur 已提交
779

J
jorlow@chromium.org 已提交
780
skiplist_test: db/skiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
781
	$(AM_LINK)
J
jorlow@chromium.org 已提交
782 783

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

786
version_set_test: db/version_set_test.o $(LIBOBJECTS) $(TESTHARNESS)
787
	$(AM_LINK)
788

S
sdong 已提交
789
compaction_picker_test: db/compaction_picker_test.o $(LIBOBJECTS) $(TESTHARNESS)
790
	$(AM_LINK)
S
sdong 已提交
791

S
sdong 已提交
792
version_builder_test: db/version_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
793
	$(AM_LINK)
S
sdong 已提交
794

795
file_indexer_test: db/file_indexer_test.o $(LIBOBJECTS) $(TESTHARNESS)
796
	$(AM_LINK)
797

798
reduce_levels_test: tools/reduce_levels_test.o $(LIBOBJECTS) $(TESTHARNESS)
799
	$(AM_LINK)
800

J
jorlow@chromium.org 已提交
801
write_batch_test: db/write_batch_test.o $(LIBOBJECTS) $(TESTHARNESS)
802
	$(AM_LINK)
803

804
write_controller_test: db/write_controller_test.o $(LIBOBJECTS) $(TESTHARNESS)
805
	$(AM_LINK)
806

J
Jim Paton 已提交
807
merge_test: db/merge_test.o $(LIBOBJECTS) $(TESTHARNESS)
808
	$(AM_LINK)
J
jorlow@chromium.org 已提交
809

I
Igor Canadi 已提交
810
merger_test: table/merger_test.o $(LIBOBJECTS) $(TESTHARNESS)
811
	$(AM_LINK)
I
Igor Canadi 已提交
812

813
deletefile_test: db/deletefile_test.o $(LIBOBJECTS) $(TESTHARNESS)
814
	$(AM_LINK)
815

816
geodb_test: utilities/geodb/geodb_test.o $(LIBOBJECTS) $(TESTHARNESS)
817
	$(AM_LINK)
818

819 820 821 822 823 824
rocksdb_dump: tools/dump/rocksdb_dump.o $(LIBOBJECTS)
	$(AM_LINK)

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

825
cuckoo_table_builder_test: table/cuckoo_table_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
826
	$(AM_LINK)
827

I
Igor Canadi 已提交
828
cuckoo_table_reader_test: table/cuckoo_table_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
829
	$(AM_LINK)
830

831
cuckoo_table_db_test: db/cuckoo_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
832
	$(AM_LINK)
833

834
listener_test: db/listener_test.o $(LIBOBJECTS) $(TESTHARNESS)
835
	$(AM_LINK)
836

Y
Yueh-Hsuan Chiang 已提交
837
thread_list_test: util/thread_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
838
	$(AM_LINK)
Y
Yueh-Hsuan Chiang 已提交
839

840 841 842
compact_files_test: db/compact_files_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

843
options_test: util/options_test.o $(LIBOBJECTS) $(TESTHARNESS)
844
	$(AM_LINK)
845

I
Igor Canadi 已提交
846 847 848
event_logger_test: util/event_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

849
sst_dump_test: util/sst_dump_test.o $(LIBOBJECTS) $(TESTHARNESS)
850
	$(AM_LINK)
851

852
memenv_test : util/memenv_test.o $(LIBOBJECTS) $(TESTHARNESS)
853
	$(AM_LINK)
H
Hans Wennborg 已提交
854

A
agiardullo 已提交
855 856 857
optimistic_transaction_test: utilities/transactions/optimistic_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

858
mock_env_test : util/mock_env_test.o $(LIBOBJECTS) $(TESTHARNESS)
859
	$(AM_LINK)
860

861
manual_compaction_test: util/manual_compaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
862
	$(AM_LINK)
863

864
filelock_test: util/filelock_test.o $(LIBOBJECTS) $(TESTHARNESS)
865
	$(AM_LINK)
K
Kai Liu 已提交
866 867

auto_roll_logger_test: util/auto_roll_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
868
	$(AM_LINK)
869

A
agiardullo 已提交
870 871 872
memtable_list_test: db/memtable_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
agiardullo 已提交
873 874 875
write_callback_test: db/write_callback_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

876
sst_dump: tools/sst_dump.o $(LIBOBJECTS)
877
	$(AM_LINK)
878

879
ldb: tools/ldb.o $(LIBOBJECTS)
880
	$(AM_LINK)
881

I
Igor Canadi 已提交
882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913
#-------------------------------------------------
# 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 已提交
914
	[ -e $(SHARED4) ] && $(MAKE) install-shared || :
I
Igor Canadi 已提交
915 916 917 918

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


919 920 921 922
# ---------------------------------------------------------------------------
# Jni stuff
# ---------------------------------------------------------------------------

923
JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux
924 925
ARCH := $(shell getconf LONG_BIT)
ROCKSDBJNILIB = librocksdbjni-linux$(ARCH).so
926
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH).jar
927
ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
C
Chris Riccomini 已提交
928
ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar
929
ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar
930 931

ifeq ($(PLATFORM), OS_MACOSX)
932
ROCKSDBJNILIB = librocksdbjni-osx.jnilib
933
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar
934 935 936 937 938
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
939 940
endif

N
Naveen 已提交
941 942
libz.a:
	-rm -rf zlib-1.2.8
N
Naveen 已提交
943 944 945
	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
946
	cp zlib-1.2.8/libz.a .
N
Naveen 已提交
947 948 949

libbz2.a:
	-rm -rf bzip2-1.0.6
950
	curl -O  http://www.bzip.org/1.0.6/bzip2-1.0.6.tar.gz
N
Naveen 已提交
951 952 953 954
	tar xvzf bzip2-1.0.6.tar.gz
	cd bzip2-1.0.6 && make CFLAGS='-fPIC -Wall -Winline -O2 -g -D_FILE_OFFSET_BITS=64'
	cp bzip2-1.0.6/libbz2.a .

N
Naveen 已提交
955 956
libsnappy.a:
	-rm -rf snappy-1.1.1
N
Naveen 已提交
957 958
	curl -O https://snappy.googlecode.com/files/snappy-1.1.1.tar.gz
	tar xvzf snappy-1.1.1.tar.gz
N
Naveen 已提交
959
	cd snappy-1.1.1 && ./configure --with-pic --enable-static
N
Naveen 已提交
960 961
	cd snappy-1.1.1 && make
	cp snappy-1.1.1/.libs/libsnappy.a .
962

963 964 965 966 967 968 969
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 已提交
970

971 972 973
# A version of each $(LIBOBJECTS) compiled with -fPIC
java_libobjects = $(patsubst %,jl/%,$(LIBOBJECTS))
CLEAN_FILES += jl
974

975 976 977 978 979
$(java_libobjects): jl/%.o: %.cc
	$(AM_V_CC)mkdir -p $(@D)
	@$(CXX) $(CXXFLAGS) -fPIC -c $< -o $@ $(COVERAGEFLAGS)

rocksdbjavastatic: $(java_libobjects) libz.a libbz2.a libsnappy.a liblz4.a
F
fyrz 已提交
980
	cd java;$(MAKE) javalib;
981
	rm -f ./java/target/$(ROCKSDBJNILIB)
982 983 984
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC \
	  -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) \
	  $(java_libobjects) $(COVERAGEFLAGS) \
D
DerekSchenk 已提交
985
	  libz.a libbz2.a libsnappy.a liblz4.a $(LDFLAGS)
986 987 988 989 990 991
	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 已提交
992

993
rocksdbjavastaticrelease: rocksdbjavastatic
994
	cd java/crossbuild && vagrant destroy -f && vagrant up linux32 && vagrant halt linux32 && vagrant up linux64 && vagrant halt linux64
995 996 997
	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
998

999
rocksdbjavastaticpublish: rocksdbjavastaticrelease
1000 1001 1002 1003 1004 1005
	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
1006

1007
rocksdbjava: $(java_libobjects)
F
fyrz 已提交
1008
	cd java;$(MAKE) javalib;
1009
	rm -f ./java/target/$(ROCKSDBJNILIB)
1010
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) $(java_libobjects) $(JAVA_LDFLAGS) $(COVERAGEFLAGS)
1011 1012 1013
	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
1014 1015 1016 1017 1018

jclean:
	cd java;$(MAKE) clean;

jtest:
1019
	cd java;$(MAKE) sample;$(MAKE) test;
1020

1021 1022 1023
jdb_bench:
	cd java;$(MAKE) db_bench;

1024 1025 1026 1027
commit-prereq:
	$(MAKE) clean && $(MAKE) all check;
	$(MAKE) clean && $(MAKE) rocksdbjava;
	$(MAKE) clean && USE_CLANG=1 $(MAKE) all;
1028
	$(MAKE) clean && OPT=-DROCKSDB_LITE $(MAKE) static_lib;
1029

V
Venkatesh Radhakrishnan 已提交
1030 1031 1032 1033 1034 1035 1036
xfunc:
	for xftest in $(XFUNC_TESTS); do \
		echo "===== Running xftest $$xftest"; \
		make check ROCKSDB_XFUNC_TEST="$$xftest" tests-regexp="DBTest" ;\
	done


1037 1038 1039
# ---------------------------------------------------------------------------
#  	Platform-specific compilation
# ---------------------------------------------------------------------------
J
Jim Paton 已提交
1040

1041 1042 1043
ifeq ($(PLATFORM), IOS)
# For iOS, create universal object files to be used on both the simulator and
# a device.
H
heyongqiang 已提交
1044 1045 1046
PLATFORMSROOT=/Applications/Xcode.app/Contents/Developer/Platforms
SIMULATORROOT=$(PLATFORMSROOT)/iPhoneSimulator.platform/Developer
DEVICEROOT=$(PLATFORMSROOT)/iPhoneOS.platform/Developer
I
Igor Canadi 已提交
1047
IOSVERSION=$(shell defaults read $(PLATFORMSROOT)/iPhoneOS.platform/version CFBundleShortVersionString)
1048

1049 1050
.cc.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
1051
	$(CXX) $(CXXFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
1052
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
1053
	xcrun -sdk iphoneos $(CXX) $(CXXFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
1054
	lipo ios-x86/$@ ios-arm/$@ -create -output $@
1055 1056 1057

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

1063
else
J
jorlow@chromium.org 已提交
1064
.cc.o:
1065
	$(AM_V_CC)$(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
1066 1067

.c.o:
1068
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
1069
endif
1070

1071 1072 1073 1074
# ---------------------------------------------------------------------------
#  	Source files dependencies detection
# ---------------------------------------------------------------------------

1075 1076 1077
all_sources = $(LIB_SOURCES) $(TEST_BENCH_SOURCES) $(MOCK_SOURCES)
DEPFILES = $(all_sources:.cc=.d)

1078 1079 1080 1081 1082
# 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.
1083
$(DEPFILES): %.d: %.cc
1084
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
1085
	  -MM -MT'$@' -MT'$(<:.cc=.o)' "$<" -o '$@'
1086 1087 1088

depend: $(DEPFILES)

1089 1090 1091 1092
# 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.
1093
ifneq ($(MAKECMDGOALS),clean)
1094
ifneq ($(MAKECMDGOALS),format)
1095 1096
ifneq ($(MAKECMDGOALS),jclean)
ifneq ($(MAKECMDGOALS),jtest)
1097
ifneq ($(MAKECMDGOALS),package)
1098
ifneq ($(MAKECMDGOALS),analyze)
1099 1100
-include $(DEPFILES)
endif
1101
endif
1102 1103
endif
endif
1104
endif
1105
endif