2011-06-29 00:30:50 +00:00
|
|
|
#!/bin/sh
|
2012-03-21 10:28:03 -07:00
|
|
|
#
|
2012-04-17 08:36:46 -07:00
|
|
|
# Detects OS we're compiling on and outputs a file specified by the first
|
|
|
|
# argument, which in turn gets read while processing Makefile.
|
2012-03-21 10:28:03 -07:00
|
|
|
#
|
2012-04-17 08:36:46 -07:00
|
|
|
# The output will set the following variables:
|
2012-08-26 23:45:35 -07:00
|
|
|
# CC C Compiler path
|
|
|
|
# CXX C++ Compiler path
|
2012-03-21 10:28:03 -07:00
|
|
|
# PLATFORM_LDFLAGS Linker flags
|
2012-03-30 13:15:49 -07:00
|
|
|
# PLATFORM_SHARED_EXT Extension for shared libraries
|
|
|
|
# PLATFORM_SHARED_LDFLAGS Flags for building shared library
|
|
|
|
# PLATFORM_SHARED_CFLAGS Flags for compiling objects for shared library
|
2012-03-21 10:28:03 -07:00
|
|
|
# PLATFORM_CCFLAGS C compiler flags
|
|
|
|
# PLATFORM_CXXFLAGS C++ compiler flags. Will contain:
|
2012-08-26 23:45:35 -07:00
|
|
|
# PLATFORM_SHARED_VERSIONED Set to 'true' if platform supports versioned
|
|
|
|
# shared libraries, empty otherwise.
|
|
|
|
#
|
|
|
|
# The PLATFORM_CCFLAGS and PLATFORM_CXXFLAGS might include the following:
|
|
|
|
#
|
2012-03-21 10:28:03 -07:00
|
|
|
# -DLEVELDB_PLATFORM_POSIX if cstdatomic is present
|
|
|
|
# -DLEVELDB_PLATFORM_NOATOMIC if it is not
|
2012-08-26 23:45:35 -07:00
|
|
|
# -DSNAPPY if the Snappy library is present
|
|
|
|
#
|
2012-03-21 10:28:03 -07:00
|
|
|
|
2012-04-17 08:36:46 -07:00
|
|
|
OUTPUT=$1
|
|
|
|
if test -z "$OUTPUT"; then
|
2012-08-26 23:45:35 -07:00
|
|
|
echo "usage: $0 <output-filename>" >&2
|
2012-04-17 08:36:46 -07:00
|
|
|
exit 1
|
|
|
|
fi
|
2011-06-29 00:30:50 +00:00
|
|
|
|
2013-01-14 12:39:24 -08:00
|
|
|
# Default to fbcode gcc on internal fb machines
|
|
|
|
if [ -d /mnt/gvfs/third-party -a -z "$CXX" ]; then
|
2013-01-14 18:37:01 -08:00
|
|
|
if [ -z "$USE_CLANG" ]; then
|
2013-08-22 14:53:51 -07:00
|
|
|
source $PWD/build_tools/fbcode.gcc471.sh
|
2013-01-14 18:37:01 -08:00
|
|
|
else
|
2013-08-22 14:53:51 -07:00
|
|
|
source $PWD/build_tools/fbcode.clang31.sh
|
2013-01-14 18:37:01 -08:00
|
|
|
fi
|
2013-01-14 12:39:24 -08:00
|
|
|
fi
|
|
|
|
|
2012-04-17 08:36:46 -07:00
|
|
|
# Delete existing output, if it exists
|
|
|
|
rm -f $OUTPUT
|
|
|
|
touch $OUTPUT
|
2011-06-29 00:30:50 +00:00
|
|
|
|
2012-08-26 23:45:35 -07:00
|
|
|
if test -z "$CC"; then
|
|
|
|
CC=cc
|
|
|
|
fi
|
|
|
|
|
2011-11-30 10:59:40 +00:00
|
|
|
if test -z "$CXX"; then
|
|
|
|
CXX=g++
|
|
|
|
fi
|
|
|
|
|
2011-06-29 00:30:50 +00:00
|
|
|
# Detect OS
|
2012-03-21 10:28:03 -07:00
|
|
|
if test -z "$TARGET_OS"; then
|
|
|
|
TARGET_OS=`uname -s`
|
|
|
|
fi
|
|
|
|
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="${CFLAGS}"
|
2012-08-26 23:45:35 -07:00
|
|
|
CROSS_COMPILE=
|
2012-03-21 10:28:03 -07:00
|
|
|
PLATFORM_CCFLAGS=
|
2013-01-14 18:37:01 -08:00
|
|
|
PLATFORM_CXXFLAGS="${CXXFLAGS}"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS"
|
2012-03-30 13:15:49 -07:00
|
|
|
PLATFORM_SHARED_EXT="so"
|
2013-01-14 12:39:24 -08:00
|
|
|
PLATFORM_SHARED_LDFLAGS="${EXEC_LDFLAGS_SHARED} -shared -Wl,-soname -Wl,"
|
2012-03-30 13:15:49 -07:00
|
|
|
PLATFORM_SHARED_CFLAGS="-fPIC"
|
2012-08-26 23:45:35 -07:00
|
|
|
PLATFORM_SHARED_VERSIONED=true
|
2012-03-21 10:28:03 -07:00
|
|
|
|
2013-04-11 10:54:35 -07:00
|
|
|
# generic port files (working on all platform by #ifdef) go directly in /port
|
2013-08-22 14:53:51 -07:00
|
|
|
GENERIC_PORT_FILES=`find $ROCKSDB_ROOT/port -name '*.cc' | tr "\n" " "`
|
2013-04-11 10:54:35 -07:00
|
|
|
|
2012-03-21 10:28:03 -07:00
|
|
|
# On GCC, we pick libc's memcmp over GCC's memcmp via -fno-builtin-memcmp
|
|
|
|
case "$TARGET_OS" in
|
2011-06-29 00:30:50 +00:00
|
|
|
Darwin)
|
|
|
|
PLATFORM=OS_MACOSX
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -DOS_MACOSX"
|
2012-03-30 13:15:49 -07:00
|
|
|
PLATFORM_SHARED_EXT=dylib
|
|
|
|
PLATFORM_SHARED_LDFLAGS="-dynamiclib -install_name "
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/darwin/darwin_specific.cc
|
2011-06-29 00:30:50 +00:00
|
|
|
;;
|
|
|
|
Linux)
|
|
|
|
PLATFORM=OS_LINUX
|
2013-08-15 20:53:21 -07:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -DOS_LINUX"
|
2013-01-14 18:37:01 -08:00
|
|
|
if [ -z "$USE_CLANG" ]; then
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp"
|
|
|
|
fi
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lpthread"
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/linux/linux_specific.cc
|
2011-06-29 00:30:50 +00:00
|
|
|
;;
|
|
|
|
SunOS)
|
|
|
|
PLATFORM=OS_SOLARIS
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -D_REENTRANT -DOS_SOLARIS"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lpthread -lrt"
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/sunos/sunos_specific.cc
|
2011-06-29 00:30:50 +00:00
|
|
|
;;
|
2011-07-27 01:46:25 +00:00
|
|
|
FreeBSD)
|
|
|
|
PLATFORM=OS_FREEBSD
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -D_REENTRANT -DOS_FREEBSD"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lpthread"
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/freebsd/freebsd_specific.cc
|
2011-07-27 01:46:25 +00:00
|
|
|
;;
|
2012-03-05 10:35:46 -08:00
|
|
|
NetBSD)
|
|
|
|
PLATFORM=OS_NETBSD
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -D_REENTRANT -DOS_NETBSD"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lpthread -lgcc_s"
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/netbsd/netbsd_specific.cc
|
2012-03-05 10:35:46 -08:00
|
|
|
;;
|
|
|
|
OpenBSD)
|
|
|
|
PLATFORM=OS_OPENBSD
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -D_REENTRANT -DOS_OPENBSD"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -pthread"
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/openbsd/openbsd_specific.cc
|
2012-03-05 10:35:46 -08:00
|
|
|
;;
|
|
|
|
DragonFly)
|
|
|
|
PLATFORM=OS_DRAGONFLYBSD
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -D_REENTRANT -DOS_DRAGONFLYBSD"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lpthread"
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/dragonfly/dragonfly_specific.cc
|
2012-03-21 10:28:03 -07:00
|
|
|
;;
|
|
|
|
OS_ANDROID_CROSSCOMPILE)
|
2012-08-26 23:45:35 -07:00
|
|
|
PLATFORM=OS_ANDROID
|
2013-01-14 12:39:24 -08:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -fno-builtin-memcmp -D_REENTRANT -DOS_ANDROID -DLEVELDB_PLATFORM_POSIX"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS " # All pthread features are in the Android C library
|
2013-04-11 10:54:35 -07:00
|
|
|
# PORT_FILES=port/android/android.cc
|
2012-08-26 23:45:35 -07:00
|
|
|
CROSS_COMPILE=true
|
2012-03-05 10:35:46 -08:00
|
|
|
;;
|
2011-06-29 00:30:50 +00:00
|
|
|
*)
|
2012-08-26 23:45:35 -07:00
|
|
|
echo "Unknown platform!" >&2
|
2011-06-29 00:30:50 +00:00
|
|
|
exit 1
|
|
|
|
esac
|
|
|
|
|
2013-08-22 14:53:51 -07:00
|
|
|
$PWD/build_tools/build_detect_version
|
2012-08-21 00:33:21 -07:00
|
|
|
|
2012-03-21 10:28:03 -07:00
|
|
|
# We want to make a list of all cc files within util, db, table, and helpers
|
|
|
|
# except for the test and benchmark files. By default, find will output a list
|
|
|
|
# of all files matching either rule, so we need to append -print to make the
|
|
|
|
# prune take effect.
|
Timestamp and TTL Wrapper for rocksdb
Summary:
When opened with DBTimestamp::Open call, timestamps are prepended to and stripped from the value during subsequent Put and Get calls respectively. The Timestamp is used to discard values in Get and custom compaction filter which have exceeded their TTL which is specified during Open.
Have made a temporary change to Makefile to let us test with the temporary file TestTime.cc. Have also changed the private members of db_impl.h to protected to let them be inherited by the new class DBTimestamp
Test Plan: make db_timestamp; TestTime.cc(will not check it in) shows how to use the apis currently, but I will write unit-tests shortly
Reviewers: dhruba, vamsi, haobo, sheki, heyongqiang, vkrest
Reviewed By: vamsi
CC: zshao, xjin, vkrest, MarkCallaghan
Differential Revision: https://reviews.facebook.net/D10311
2013-04-15 13:33:13 -07:00
|
|
|
DIRS="util db table utilities"
|
2012-07-02 22:45:59 -07:00
|
|
|
if test "$USE_THRIFT"; then
|
2012-10-26 12:52:46 -07:00
|
|
|
DIRS="$DIRS thrift/server_utils.cpp thrift/gen-cpp "
|
2012-07-02 22:45:59 -07:00
|
|
|
THRIFTSERVER=leveldb_server
|
|
|
|
fi
|
2012-08-14 15:20:36 -07:00
|
|
|
|
|
|
|
if test "$USE_SCRIBE"; then
|
2012-10-26 12:52:46 -07:00
|
|
|
DIRS="$DIRS scribe "
|
2012-08-14 15:20:36 -07:00
|
|
|
fi
|
|
|
|
|
2012-11-13 16:16:21 -08:00
|
|
|
set -f # temporarily disable globbing so that our patterns arent expanded
|
2012-03-21 10:28:03 -07:00
|
|
|
PRUNE_TEST="-name *test*.cc -prune"
|
|
|
|
PRUNE_BENCH="-name *_bench.cc -prune"
|
2013-08-14 13:29:05 -07:00
|
|
|
PORTABLE_FILES=`cd $ROCKSDB_ROOT; find $DIRS $PRUNE_TEST -o $PRUNE_BENCH -o -name '*.cc' -print | sort | tr "\n" " "`
|
|
|
|
PORTABLE_CPP=`cd $ROCKSDB_ROOT; find $DIRS $PRUNE_TEST -o $PRUNE_BENCH -o -name '*.cpp' -print | sort | tr "\n" " "`
|
2012-03-21 10:28:03 -07:00
|
|
|
set +f # re-enable globbing
|
2011-06-29 00:30:50 +00:00
|
|
|
|
2012-03-21 10:28:03 -07:00
|
|
|
# The sources consist of the portable files, plus the platform-specific port
|
|
|
|
# file.
|
2013-04-11 10:54:35 -07:00
|
|
|
echo "SOURCES=$PORTABLE_FILES $GENERIC_PORT_FILES $PORT_FILES" >> $OUTPUT
|
2012-07-02 22:45:59 -07:00
|
|
|
echo "SOURCESCPP=$PORTABLE_CPP" >> $OUTPUT
|
2012-04-17 08:36:46 -07:00
|
|
|
echo "MEMENV_SOURCES=helpers/memenv/memenv.cc" >> $OUTPUT
|
2011-06-29 00:30:50 +00:00
|
|
|
|
2012-08-26 23:45:35 -07:00
|
|
|
if [ "$CROSS_COMPILE" = "true" ]; then
|
2012-03-21 10:28:03 -07:00
|
|
|
# Cross-compiling; do not try any compilation tests.
|
|
|
|
true
|
2011-06-29 00:30:50 +00:00
|
|
|
else
|
2012-03-21 10:28:03 -07:00
|
|
|
# If -std=c++0x works, use <cstdatomic>. Otherwise use port_posix.h.
|
|
|
|
$CXX $CFLAGS -std=c++0x -x c++ - -o /dev/null 2>/dev/null <<EOF
|
|
|
|
#include <cstdatomic>
|
|
|
|
int main() {}
|
|
|
|
EOF
|
|
|
|
if [ "$?" = 0 ]; then
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -DLEVELDB_PLATFORM_POSIX -DLEVELDB_CSTDATOMIC_PRESENT"
|
|
|
|
PLATFORM_CXXFLAGS="-std=c++0x"
|
|
|
|
else
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -DLEVELDB_PLATFORM_POSIX"
|
|
|
|
fi
|
2011-06-29 00:30:50 +00:00
|
|
|
|
2012-03-21 10:28:03 -07:00
|
|
|
# Test whether Snappy library is installed
|
|
|
|
# http://code.google.com/p/snappy/
|
|
|
|
$CXX $CFLAGS -x c++ - -o /dev/null 2>/dev/null <<EOF
|
|
|
|
#include <snappy.h>
|
|
|
|
int main() {}
|
2011-06-29 00:30:50 +00:00
|
|
|
EOF
|
2012-03-21 10:28:03 -07:00
|
|
|
if [ "$?" = 0 ]; then
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -DSNAPPY"
|
2012-11-20 16:14:04 -08:00
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS ${SNAPPY_LDFLAGS:-./snappy/libs/libsnappy.a}"
|
2012-03-21 10:28:03 -07:00
|
|
|
fi
|
|
|
|
|
2012-06-27 23:41:33 -07:00
|
|
|
# Test whether zlib library is installed
|
|
|
|
$CXX $CFLAGS $COMMON_FLAGS -x c++ - -o /dev/null 2>/dev/null <<EOF
|
|
|
|
#include <zlib.h>
|
|
|
|
int main() {}
|
|
|
|
EOF
|
|
|
|
if [ "$?" = 0 ]; then
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -DZLIB"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lz"
|
|
|
|
fi
|
|
|
|
|
2012-06-28 19:26:43 -07:00
|
|
|
# Test whether bzip library is installed
|
|
|
|
$CXX $CFLAGS $COMMON_FLAGS -x c++ - -o /dev/null 2>/dev/null <<EOF
|
|
|
|
#include <bzlib.h>
|
|
|
|
int main() {}
|
|
|
|
EOF
|
|
|
|
if [ "$?" = 0 ]; then
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS -DBZIP2"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -lbz2"
|
|
|
|
fi
|
|
|
|
|
2012-03-21 10:28:03 -07:00
|
|
|
# Test whether tcmalloc is available
|
|
|
|
$CXX $CFLAGS -x c++ - -o /dev/null -ltcmalloc 2>/dev/null <<EOF
|
|
|
|
int main() {}
|
|
|
|
EOF
|
|
|
|
if [ "$?" = 0 ]; then
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS -ltcmalloc"
|
|
|
|
fi
|
2011-06-29 00:30:50 +00:00
|
|
|
fi
|
|
|
|
|
2012-06-08 01:11:14 -07:00
|
|
|
# shall we use HDFS?
|
|
|
|
|
|
|
|
if test "$USE_HDFS"; then
|
|
|
|
if test -z "$JAVA_HOME"; then
|
|
|
|
echo "JAVA_HOME has to be set for HDFS usage."
|
|
|
|
exit 1
|
|
|
|
fi
|
2012-10-26 12:52:46 -07:00
|
|
|
HDFS_CCFLAGS="$HDFS_CCFLAGS -I$JAVA_HOME/include -I$JAVA_HOME/include/linux -DUSE_HDFS"
|
|
|
|
HDFS_LDFLAGS="$HDFS_LDFLAGS -Wl,--no-whole-archive hdfs/libhdfs.a -L$JAVA_HOME/jre/lib/amd64"
|
|
|
|
HDFS_LDFLAGS="$HDFS_LDFLAGS -L$JAVA_HOME/jre/lib/amd64/server -L$GLIBC_RUNTIME_PATH/lib"
|
|
|
|
HDFS_LDFLAGS="$HDFS_LDFLAGS -ldl -lverify -ljava -ljvm"
|
|
|
|
COMMON_FLAGS="$COMMON_FLAGS $HDFS_CCFLAGS"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS $HDFS_LDFLAGS"
|
2012-06-08 01:11:14 -07:00
|
|
|
fi
|
|
|
|
|
2012-09-04 16:49:09 -07:00
|
|
|
# shall we build thrift server or scribe logger
|
|
|
|
if test "$USE_THRIFT" || test "$USE_SCRIBE" ; then
|
|
|
|
THRIFT_CCFLAGS=" -I./thrift -I./thrift/gen-cpp -I./thrift/lib/cpp -I/usr/include -std=gnu++0x"
|
|
|
|
THRIFT_LDFLAGS=" -lexample -lserver -lthrift_base -ltransport -lthrift_exception -lutil -L./thrift/libs "
|
2012-10-26 12:52:46 -07:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS $THRIFT_CCFLAGS"
|
|
|
|
PLATFORM_LDFLAGS="$PLATFORM_LDFLAGS $THRIFT_LDFLAGS"
|
2012-08-14 15:20:36 -07:00
|
|
|
fi
|
|
|
|
|
2012-10-17 11:59:44 -07:00
|
|
|
# if Intel SSE instruction set is supported, set USE_SSE=" -msse -msse4.2 "
|
2012-10-26 12:52:46 -07:00
|
|
|
COMMON_FLAGS="$COMMON_FLAGS $USE_SSE"
|
2012-10-17 11:59:44 -07:00
|
|
|
|
2012-03-21 10:28:03 -07:00
|
|
|
PLATFORM_CCFLAGS="$PLATFORM_CCFLAGS $COMMON_FLAGS"
|
|
|
|
PLATFORM_CXXFLAGS="$PLATFORM_CXXFLAGS $COMMON_FLAGS"
|
|
|
|
|
2013-03-07 11:11:30 -08:00
|
|
|
VALGRIND_VER="$VALGRIND_VER"
|
|
|
|
|
2012-08-26 23:45:35 -07:00
|
|
|
echo "CC=$CC" >> $OUTPUT
|
|
|
|
echo "CXX=$CXX" >> $OUTPUT
|
2012-04-17 08:36:46 -07:00
|
|
|
echo "PLATFORM=$PLATFORM" >> $OUTPUT
|
|
|
|
echo "PLATFORM_LDFLAGS=$PLATFORM_LDFLAGS" >> $OUTPUT
|
2013-03-07 11:11:30 -08:00
|
|
|
echo "VALGRIND_VER=$VALGRIND_VER" >> $OUTPUT
|
2012-04-17 08:36:46 -07:00
|
|
|
echo "PLATFORM_CCFLAGS=$PLATFORM_CCFLAGS" >> $OUTPUT
|
|
|
|
echo "PLATFORM_CXXFLAGS=$PLATFORM_CXXFLAGS" >> $OUTPUT
|
|
|
|
echo "PLATFORM_SHARED_CFLAGS=$PLATFORM_SHARED_CFLAGS" >> $OUTPUT
|
|
|
|
echo "PLATFORM_SHARED_EXT=$PLATFORM_SHARED_EXT" >> $OUTPUT
|
|
|
|
echo "PLATFORM_SHARED_LDFLAGS=$PLATFORM_SHARED_LDFLAGS" >> $OUTPUT
|
2012-08-29 12:29:43 -07:00
|
|
|
echo "PLATFORM_SHARED_VERSIONED=$PLATFORM_SHARED_VERSIONED" >> $OUTPUT
|
2012-07-02 22:45:59 -07:00
|
|
|
echo "THRIFTSERVER=$THRIFTSERVER" >> $OUTPUT
|
2013-01-14 12:39:24 -08:00
|
|
|
echo "EXEC_LDFLAGS=$EXEC_LDFLAGS" >> $OUTPUT
|