Makefile 33.7 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 33 34 35 36 37 38 39
# 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
# with debug level 0. To compile with level 0, run `make shared_lib`, 
# `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 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194
date := $(shell date +%F)
git_sha := $(shell git describe HEAD 2>/dev/null)
gen_build_version =							\
  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__;'

# 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.
195
CLEAN_FILES += util/build_version.cc:
196 197 198 199 200 201 202
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
203

204
LIBOBJECTS = $(LIB_SOURCES:.cc=.o)
205
MOCKOBJECTS = $(MOCK_SOURCES:.cc=.o)
J
jorlow@chromium.org 已提交
206

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

214
VALGRIND_OPTS = --error-exitcode=$(VALGRIND_ERROR) --leak-check=full
215

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

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

290
TOOLS = \
I
Igor Canadi 已提交
291
	sst_dump \
I
Igor Canadi 已提交
292
	db_sanity_test \
I
Igor Canadi 已提交
293 294 295
	db_stress \
	ldb \
	db_repl_stress
J
jorlow@chromium.org 已提交
296

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

299 300
# The library name is configurable since we are maintaining libraries of both
# debug/release mode.
301 302 303
ifeq ($(LIBNAME),)
        LIBNAME=librocksdb
endif
304
LIBRARY = ${LIBNAME}.a
305

306 307 308
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)
309

310 311
default: all

312 313 314
#-----------------------------------------------
# Create platform independent shared libraries.
#-----------------------------------------------
315
ifneq ($(PLATFORM_SHARED_EXT),)
H
heyongqiang 已提交
316 317

ifneq ($(PLATFORM_SHARED_VERSIONED),true)
318
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
H
heyongqiang 已提交
319 320
SHARED2 = $(SHARED1)
SHARED3 = $(SHARED1)
321
SHARED4 = $(SHARED1)
H
heyongqiang 已提交
322 323
SHARED = $(SHARED1)
else
324 325
SHARED_MAJOR = $(ROCKSDB_MAJOR)
SHARED_MINOR = $(ROCKSDB_MINOR)
326
SHARED_PATCH = $(ROCKSDB_PATCH)
327
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
328 329
SHARED2 = $(SHARED1).$(SHARED_MAJOR)
SHARED3 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR)
330 331 332 333 334 335 336 337
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)
338 339
endif

340
$(SHARED4):
I
Igor Canadi 已提交
341
	$(CXX) $(PLATFORM_SHARED_LDFLAGS)$(SHARED3) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) $(LIB_SOURCES) $(LDFLAGS) -o $@
H
heyongqiang 已提交
342 343 344

endif  # PLATFORM_SHARED_EXT

345
.PHONY: blackbox_crash_test check clean coverage crash_test ldb_tests package \
I
Igor Canadi 已提交
346
	release tags valgrind_check whitebox_crash_test format static_lib shared_lib all \
I
Igor Canadi 已提交
347 348
	dbg rocksdbjavastatic rocksdbjava install install-static install-shared uninstall \
	analyze
349

I
Igor Canadi 已提交
350
all: $(LIBRARY) $(BENCHMARKS) $(TOOLS) $(TESTS)
351

I
Igor Canadi 已提交
352 353 354 355
static_lib: $(LIBRARY)

shared_lib: $(SHARED)

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

358
# creates static library and programs
359
release:
K
Kai Liu 已提交
360
	$(MAKE) clean
I
Igor Canadi 已提交
361
	OPT="-DNDEBUG -O2" $(MAKE) static_lib $(TOOLS) db_bench -j32
K
Kai Liu 已提交
362 363 364

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

370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404
# 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 已提交
405

406 407 408 409 410 411 412 413 414 415 416 417 418 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
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 已提交
465 466 467
# Use this regexp to select the subset of tests whose names match.
tests-regexp = .

468 469 470 471 472 473 474 475 476 477 478 479
.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 已提交
480
	  | grep -E '$(tests-regexp)'					\
481 482 483 484
	  | parallel -j$(J) --joblog=LOG $$eta --gnu '{} >& t/log-{/}'
endif

CLEAN_FILES += t LOG $(TMPD)
485

486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512
# 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)'

# If GNU parallel is installed, run the tests in parallel,
# via the check_0 rule above.  Otherwise, run them sequentially.
check: all
	$(AM_V_GEN)case $$(parallel --gnu --help 2>/dev/null) in	\
	  *'GNU Parallel'*)						\
	    t=$$($(test_names));					\
	    $(MAKE) T="$$t" TMPD=$(TMPD) check_0;;			\
	  *)								\
	    for t in $(TESTS); do					\
	      echo "===== Running $$t"; ./$$t || exit 1; done;;		\
	esac
	rm -rf $(TMPD)

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

.PHONY: ldb_tests
513
ldb_tests: ldb
514 515
	python tools/ldb_test.py

I
Igor Canadi 已提交
516
crash_test: whitebox_crash_test blackbox_crash_test
517 518

blackbox_crash_test: db_stress
519
	python -u tools/db_crashtest.py
520 521

whitebox_crash_test: db_stress
522
	python -u tools/db_crashtest2.py
523

I
Igor Canadi 已提交
524 525 526
asan_check:
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) check -j32
527 528 529 530
	$(MAKE) clean

asan_crash_test:
	$(MAKE) clean
I
Igor Canadi 已提交
531
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test
I
Igor Canadi 已提交
532 533
	$(MAKE) clean

I
Igor Canadi 已提交
534
valgrind_check: $(TESTS)
535
	mkdir -p $(VALGRIND_DIR)
536 537 538 539
	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'`; \
540
		$(VALGRIND_VER) $(VALGRIND_OPTS) ./$$t; \
541 542 543 544 545 546
		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
547

548 549 550 551 552
analyze: clean
	$(CLANG_SCAN_BUILD) --use-analyzer=$(CLANG_ANALYZER) \
		--use-c++=$(CXX) --use-cc=$(CC) --status-bugs \
		-o $(CURDIR)/scan_build_report \
		$(MAKE) dbg
553

554 555
CLEAN_FILES += unity.cc
unity.cc: Makefile
I
Igor Sugak 已提交
556 557 558 559 560 561 562
	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 已提交
563

564
unity: unity.o
565
	$(AM_LINK)
M
miguelportilla 已提交
566

J
jorlow@chromium.org 已提交
567
clean:
568 569
	rm -f $(BENCHMARKS) $(TOOLS) $(TESTS) $(LIBRARY) $(SHARED)
	rm -rf $(CLEAN_FILES) ios-x86 ios-arm scan_build_report
I
Igor Canadi 已提交
570
	find . -name "*.[oda]" -exec rm -f {} \;
571
	find . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
572
	rm -rf bzip2* snappy* zlib* lz4*
573

574 575 576
tags:
	ctags * -R
	cscope -b `find . -name '*.cc'` `find . -name '*.h'`
577

578 579 580
format:
	build_tools/format-diff.sh

581 582 583
package:
	bash build_tools/make_package.sh $(SHARED_MAJOR).$(SHARED_MINOR)

584 585 586
# ---------------------------------------------------------------------------
# 	Unit tests and tools
# ---------------------------------------------------------------------------
587
$(LIBRARY): $(LIBOBJECTS)
J
Jim Meyering 已提交
588 589
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(LIBOBJECTS)
J
jorlow@chromium.org 已提交
590

591
db_bench: db/db_bench.o $(LIBOBJECTS) $(TESTUTIL)
592
	$(AM_LINK)
J
jorlow@chromium.org 已提交
593

F
Feng Zhu 已提交
594
cache_bench: util/cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
595
	$(AM_LINK)
J
jorlow@chromium.org 已提交
596

A
Ameya Gupte 已提交
597
memtablerep_bench: db/memtablerep_bench.o $(LIBOBJECTS) $(TESTUTIL)
598
	$(AM_LINK)
A
Ameya Gupte 已提交
599

K
kailiu 已提交
600
block_hash_index_test: table/block_hash_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
601
	$(AM_LINK)
K
kailiu 已提交
602

603
db_stress: tools/db_stress.o $(LIBOBJECTS) $(TESTUTIL)
604
	$(AM_LINK)
605

I
Igor Canadi 已提交
606
db_sanity_test: tools/db_sanity_test.o $(LIBOBJECTS) $(TESTUTIL)
607
	$(AM_LINK)
608

609
db_repl_stress: tools/db_repl_stress.o $(LIBOBJECTS) $(TESTUTIL)
610
	$(AM_LINK)
611

J
jorlow@chromium.org 已提交
612
arena_test: util/arena_test.o $(LIBOBJECTS) $(TESTHARNESS)
613
	$(AM_LINK)
J
jorlow@chromium.org 已提交
614

K
kailiu 已提交
615
autovector_test: util/autovector_test.o $(LIBOBJECTS) $(TESTHARNESS)
616
	$(AM_LINK)
K
kailiu 已提交
617

618
column_family_test: db/column_family_test.o $(LIBOBJECTS) $(TESTHARNESS)
619
	$(AM_LINK)
620

K
kailiu 已提交
621
table_properties_collector_test: db/table_properties_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
622
	$(AM_LINK)
623

S
Sanjay Ghemawat 已提交
624
bloom_test: util/bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
625
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
626

627
dynamic_bloom_test: util/dynamic_bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
628
	$(AM_LINK)
629

630
c_test: db/c_test.o $(LIBOBJECTS) $(TESTHARNESS)
631
	$(AM_LINK)
632

J
jorlow@chromium.org 已提交
633
cache_test: util/cache_test.o $(LIBOBJECTS) $(TESTHARNESS)
634
	$(AM_LINK)
J
jorlow@chromium.org 已提交
635 636

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

639
stringappend_test: utilities/merge_operators/string_append/stringappend_test.o $(LIBOBJECTS) $(TESTHARNESS)
640
	$(AM_LINK)
641

642
redis_test: utilities/redis/redis_lists_test.o $(LIBOBJECTS) $(TESTHARNESS)
643
	$(AM_LINK)
644

A
Abhishek Kona 已提交
645
histogram_test: util/histogram_test.o $(LIBOBJECTS) $(TESTHARNESS)
646
	$(AM_LINK)
A
Abhishek Kona 已提交
647

L
Lei Jin 已提交
648
thread_local_test: util/thread_local_test.o $(LIBOBJECTS) $(TESTHARNESS)
649
	$(AM_LINK)
L
Lei Jin 已提交
650

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

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

657
slice_transform_test: util/slice_transform_test.o $(LIBOBJECTS) $(TESTHARNESS)
658
	$(AM_LINK)
659 660


J
jorlow@chromium.org 已提交
661
db_test: db/db_test.o $(LIBOBJECTS) $(TESTHARNESS)
662
	$(AM_LINK)
J
jorlow@chromium.org 已提交
663

S
Stanislau Hlebik 已提交
664
db_iter_test: db/db_iter_test.o $(LIBOBJECTS) $(TESTHARNESS)
665
	$(AM_LINK)
S
Stanislau Hlebik 已提交
666

667
log_write_bench: util/log_write_bench.o $(LIBOBJECTS) $(TESTHARNESS)
668
	$(AM_LINK) $(pg)
669

S
Siying Dong 已提交
670
plain_table_db_test: db/plain_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
671
	$(AM_LINK)
S
Siying Dong 已提交
672

673
comparator_db_test: db/comparator_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
674
	$(AM_LINK)
675

676
table_reader_bench: table/table_reader_bench.o $(LIBOBJECTS) $(TESTHARNESS)
677
	$(AM_LINK) $(pg)
678

679
perf_context_test: db/perf_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
680
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)
681

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

I
Igor Canadi 已提交
685
backupable_db_test: utilities/backupable/backupable_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
686
	$(AM_LINK)
I
Igor Canadi 已提交
687

I
Igor Canadi 已提交
688
document_db_test: utilities/document/document_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
689
	$(AM_LINK)
I
Igor Canadi 已提交
690

I
Igor Canadi 已提交
691
json_document_test: utilities/document/json_document_test.o $(LIBOBJECTS) $(TESTHARNESS)
692
	$(AM_LINK)
I
Igor Canadi 已提交
693

I
Igor Canadi 已提交
694
spatial_db_test: utilities/spatialdb/spatial_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
695
	$(AM_LINK)
I
Igor Canadi 已提交
696

697
ttl_test: utilities/ttl/ttl_test.o $(LIBOBJECTS) $(TESTHARNESS)
698
	$(AM_LINK)
699

700
write_batch_with_index_test: utilities/write_batch_with_index/write_batch_with_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
701
	$(AM_LINK)
702

I
Igor Canadi 已提交
703
flush_job_test: db/flush_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
704
	$(AM_LINK)
I
Igor Canadi 已提交
705

I
Igor Canadi 已提交
706
compaction_job_test: db/compaction_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
707
	$(AM_LINK)
I
Igor Canadi 已提交
708

I
Igor Canadi 已提交
709
wal_manager_test: db/wal_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
710
	$(AM_LINK)
I
Igor Canadi 已提交
711

J
jorlow@chromium.org 已提交
712
dbformat_test: db/dbformat_test.o $(LIBOBJECTS) $(TESTHARNESS)
713
	$(AM_LINK)
J
jorlow@chromium.org 已提交
714 715

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

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

L
Lei Jin 已提交
721
rate_limiter_test: util/rate_limiter_test.o $(LIBOBJECTS) $(TESTHARNESS)
722
	$(AM_LINK)
L
Lei Jin 已提交
723

J
jorlow@chromium.org 已提交
724
filename_test: db/filename_test.o $(LIBOBJECTS) $(TESTHARNESS)
725
	$(AM_LINK)
J
jorlow@chromium.org 已提交
726

727
block_based_filter_block_test: table/block_based_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
728
	$(AM_LINK)
729 730

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

J
jorlow@chromium.org 已提交
733
log_test: db/log_test.o $(LIBOBJECTS) $(TESTHARNESS)
734
	$(AM_LINK)
J
jorlow@chromium.org 已提交
735 736

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

D
Dhruba Borthakur 已提交
739
block_test: table/block_test.o $(LIBOBJECTS) $(TESTHARNESS)
740
	$(AM_LINK)
D
Dhruba Borthakur 已提交
741

J
jorlow@chromium.org 已提交
742
skiplist_test: db/skiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
743
	$(AM_LINK)
J
jorlow@chromium.org 已提交
744 745

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

748
version_set_test: db/version_set_test.o $(LIBOBJECTS) $(TESTHARNESS)
749
	$(AM_LINK)
750

S
sdong 已提交
751
compaction_picker_test: db/compaction_picker_test.o $(LIBOBJECTS) $(TESTHARNESS)
752
	$(AM_LINK)
S
sdong 已提交
753

S
sdong 已提交
754
version_builder_test: db/version_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
755
	$(AM_LINK)
S
sdong 已提交
756

757
file_indexer_test: db/file_indexer_test.o $(LIBOBJECTS) $(TESTHARNESS)
758
	$(AM_LINK)
759

760
reduce_levels_test: tools/reduce_levels_test.o $(LIBOBJECTS) $(TESTHARNESS)
761
	$(AM_LINK)
762

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

766
write_controller_test: db/write_controller_test.o $(LIBOBJECTS) $(TESTHARNESS)
767
	$(AM_LINK)
768

J
Jim Paton 已提交
769
merge_test: db/merge_test.o $(LIBOBJECTS) $(TESTHARNESS)
770
	$(AM_LINK)
J
jorlow@chromium.org 已提交
771

I
Igor Canadi 已提交
772
merger_test: table/merger_test.o $(LIBOBJECTS) $(TESTHARNESS)
773
	$(AM_LINK)
I
Igor Canadi 已提交
774

775
deletefile_test: db/deletefile_test.o $(LIBOBJECTS) $(TESTHARNESS)
776
	$(AM_LINK)
777

778
geodb_test: utilities/geodb/geodb_test.o $(LIBOBJECTS) $(TESTHARNESS)
779
	$(AM_LINK)
780

781
cuckoo_table_builder_test: table/cuckoo_table_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
782
	$(AM_LINK)
783

I
Igor Canadi 已提交
784
cuckoo_table_reader_test: table/cuckoo_table_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
785
	$(AM_LINK)
786

787
cuckoo_table_db_test: db/cuckoo_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
788
	$(AM_LINK)
789

790
listener_test: db/listener_test.o $(LIBOBJECTS) $(TESTHARNESS)
791
	$(AM_LINK)
792

Y
Yueh-Hsuan Chiang 已提交
793
thread_list_test: util/thread_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
794
	$(AM_LINK)
Y
Yueh-Hsuan Chiang 已提交
795

796
compactor_test: utilities/compaction/compactor_test.o $(LIBOBJECTS) $(TESTHARNESS)
797
	$(AM_LINK)
798

799 800 801
compact_files_test: db/compact_files_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

802
options_test: util/options_test.o $(LIBOBJECTS) $(TESTHARNESS)
803
	$(AM_LINK)
804

I
Igor Canadi 已提交
805 806 807
event_logger_test: util/event_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

808
sst_dump_test: util/sst_dump_test.o $(LIBOBJECTS) $(TESTHARNESS)
809
	$(AM_LINK)
810

811
memenv_test : util/memenv_test.o $(LIBOBJECTS) $(TESTHARNESS)
812
	$(AM_LINK)
H
Hans Wennborg 已提交
813

814
mock_env_test : util/mock_env_test.o $(LIBOBJECTS) $(TESTHARNESS)
815
	$(AM_LINK)
816

817
manual_compaction_test: util/manual_compaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
818
	$(AM_LINK)
819

820
filelock_test: util/filelock_test.o $(LIBOBJECTS) $(TESTHARNESS)
821
	$(AM_LINK)
K
Kai Liu 已提交
822 823

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

A
agiardullo 已提交
826 827 828
memtable_list_test: db/memtable_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

829
sst_dump: tools/sst_dump.o $(LIBOBJECTS)
830
	$(AM_LINK)
831

832
ldb: tools/ldb.o $(LIBOBJECTS)
833
	$(AM_LINK)
834

I
Igor Canadi 已提交
835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866
#-------------------------------------------------
# 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 已提交
867
	[ -e $(SHARED4) ] && $(MAKE) install-shared || :
I
Igor Canadi 已提交
868 869 870 871

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


872 873 874 875
# ---------------------------------------------------------------------------
# Jni stuff
# ---------------------------------------------------------------------------

876
JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux
877 878
ARCH := $(shell getconf LONG_BIT)
ROCKSDBJNILIB = librocksdbjni-linux$(ARCH).so
879
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH).jar
880
ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
C
Chris Riccomini 已提交
881
ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar
882
ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar
883 884

ifeq ($(PLATFORM), OS_MACOSX)
885
ROCKSDBJNILIB = librocksdbjni-osx.jnilib
886
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar
887 888 889 890 891
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
892 893
endif

N
Naveen 已提交
894 895
libz.a:
	-rm -rf zlib-1.2.8
N
Naveen 已提交
896 897 898
	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
899
	cp zlib-1.2.8/libz.a .
N
Naveen 已提交
900 901 902

libbz2.a:
	-rm -rf bzip2-1.0.6
903
	curl -O  http://www.bzip.org/1.0.6/bzip2-1.0.6.tar.gz
N
Naveen 已提交
904 905 906 907
	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 已提交
908 909
libsnappy.a:
	-rm -rf snappy-1.1.1
N
Naveen 已提交
910 911
	curl -O https://snappy.googlecode.com/files/snappy-1.1.1.tar.gz
	tar xvzf snappy-1.1.1.tar.gz
N
Naveen 已提交
912
	cd snappy-1.1.1 && ./configure --with-pic --enable-static
N
Naveen 已提交
913 914
	cd snappy-1.1.1 && make
	cp snappy-1.1.1/.libs/libsnappy.a .
915

916 917 918 919 920 921 922
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 已提交
923

924 925 926
# A version of each $(LIBOBJECTS) compiled with -fPIC
java_libobjects = $(patsubst %,jl/%,$(LIBOBJECTS))
CLEAN_FILES += jl
927

928 929 930 931 932
$(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 已提交
933
	cd java;$(MAKE) javalib;
934
	rm -f ./java/target/$(ROCKSDBJNILIB)
935 936 937 938
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC \
	  -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) \
	  $(java_libobjects) $(COVERAGEFLAGS) \
	  libz.a libbz2.a libsnappy.a liblz4.a
939 940 941 942 943 944
	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 已提交
945

946
rocksdbjavastaticrelease: rocksdbjavastatic
947
	cd java/crossbuild && vagrant destroy -f && vagrant up linux32 && vagrant halt linux32 && vagrant up linux64 && vagrant halt linux64
948 949 950
	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
951

952
rocksdbjavastaticpublish: rocksdbjavastaticrelease
953 954 955 956 957 958
	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
959

960
rocksdbjava: $(java_libobjects)
F
fyrz 已提交
961
	cd java;$(MAKE) javalib;
962
	rm -f ./java/target/$(ROCKSDBJNILIB)
963
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) $(java_libobjects) $(JAVA_LDFLAGS) $(COVERAGEFLAGS)
964 965 966
	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
967 968 969 970 971

jclean:
	cd java;$(MAKE) clean;

jtest:
972
	cd java;$(MAKE) sample;$(MAKE) test;
973

974 975 976
jdb_bench:
	cd java;$(MAKE) db_bench;

977 978 979 980
commit-prereq:
	$(MAKE) clean && $(MAKE) all check;
	$(MAKE) clean && $(MAKE) rocksdbjava;
	$(MAKE) clean && USE_CLANG=1 $(MAKE) all;
981
	$(MAKE) clean && OPT=-DROCKSDB_LITE $(MAKE) static_lib;
982

V
Venkatesh Radhakrishnan 已提交
983 984 985 986 987 988 989
xfunc:
	for xftest in $(XFUNC_TESTS); do \
		echo "===== Running xftest $$xftest"; \
		make check ROCKSDB_XFUNC_TEST="$$xftest" tests-regexp="DBTest" ;\
	done


990 991 992
# ---------------------------------------------------------------------------
#  	Platform-specific compilation
# ---------------------------------------------------------------------------
J
Jim Paton 已提交
993

994 995 996
ifeq ($(PLATFORM), IOS)
# For iOS, create universal object files to be used on both the simulator and
# a device.
H
heyongqiang 已提交
997 998 999
PLATFORMSROOT=/Applications/Xcode.app/Contents/Developer/Platforms
SIMULATORROOT=$(PLATFORMSROOT)/iPhoneSimulator.platform/Developer
DEVICEROOT=$(PLATFORMSROOT)/iPhoneOS.platform/Developer
I
Igor Canadi 已提交
1000
IOSVERSION=$(shell defaults read $(PLATFORMSROOT)/iPhoneOS.platform/version CFBundleShortVersionString)
1001

1002 1003
.cc.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
1004
	$(CXX) $(CXXFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
1005
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
1006
	xcrun -sdk iphoneos $(CXX) $(CXXFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
1007
	lipo ios-x86/$@ ios-arm/$@ -create -output $@
1008 1009 1010

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

1016
else
J
jorlow@chromium.org 已提交
1017
.cc.o:
1018
	$(AM_V_CC)$(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
1019 1020

.c.o:
1021
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
1022
endif
1023

1024 1025 1026 1027
# ---------------------------------------------------------------------------
#  	Source files dependencies detection
# ---------------------------------------------------------------------------

1028 1029 1030
all_sources = $(LIB_SOURCES) $(TEST_BENCH_SOURCES) $(MOCK_SOURCES)
DEPFILES = $(all_sources:.cc=.d)

1031 1032 1033 1034 1035
# 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.
1036
$(DEPFILES): %.d: %.cc
1037
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
1038
	  -MM -MT'$@' -MT'$(<:.cc=.o)' "$<" -o '$@'
1039 1040 1041

depend: $(DEPFILES)

1042 1043 1044 1045
# 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.
1046
ifneq ($(MAKECMDGOALS),clean)
1047
ifneq ($(MAKECMDGOALS),format)
1048 1049
ifneq ($(MAKECMDGOALS),jclean)
ifneq ($(MAKECMDGOALS),jtest)
1050
ifneq ($(MAKECMDGOALS),package)
1051
ifneq ($(MAKECMDGOALS),analyze)
1052 1053
-include $(DEPFILES)
endif
1054
endif
1055 1056
endif
endif
1057
endif
1058
endif