From d78c6b28c452acad0666561c4daeac689042f7b3 Mon Sep 17 00:00:00 2001 From: David Bernard Date: Tue, 19 Jan 2016 04:45:21 +0000 Subject: [PATCH 1/5] Changes for build on solaris Makefile adjust paths for solaris build Makefile enable _GLIBCXX_USE_C99 so that std::to_string is available db_compaction_test.cc Initialise a variable to avoid a compilation error db_impl.cc Include db_test.cc Include Environment.java recognise solaris envrionment options_bulder.cc Make log unambiguous geodb_impl.cc Make log and floor unambiguous --- Makefile | 18 +++++++++++++++--- db/db_compaction_test.cc | 2 +- db/db_impl.cc | 1 + db/db_test.cc | 1 + .../java/org/rocksdb/util/Environment.java | 10 ++++++++-- util/options_builder.cc | 2 ++ utilities/geodb/geodb_impl.cc | 3 +++ 7 files changed, 31 insertions(+), 6 deletions(-) diff --git a/Makefile b/Makefile index 396b8e201..507f0948f 100644 --- a/Makefile +++ b/Makefile @@ -143,6 +143,9 @@ else OPT += -DNDEBUG endif +ifeq ($(PLATFORM), OS_SOLARIS) + PLATFORM_CXXFLAGS += -D _GLIBCXX_USE_C99 +endif ifneq ($(filter -DROCKSDB_LITE,$(OPT)),) # found CFLAGS += -fno-exceptions @@ -1036,7 +1039,11 @@ install: install-static # --------------------------------------------------------------------------- JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux -ARCH := $(shell getconf LONG_BIT) +ifeq ($(PLATFORM), OS_SOLARIS) + ARCH := $(shell isainfo -b) +else + ARCH := $(shell getconf LONG_BIT) +endif ROCKSDBJNILIB = librocksdbjni-linux$(ARCH).so ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH).jar ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar @@ -1044,14 +1051,19 @@ ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PA ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar ifeq ($(PLATFORM), OS_MACOSX) -ROCKSDBJNILIB = librocksdbjni-osx.jnilib -ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar + ROCKSDBJNILIB = librocksdbjni-osx.jnilib + ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar 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 endif +ifeq ($(PLATFORM), OS_SOLARIS) + ROCKSDBJNILIB = librocksdbjni-solaris$(ARCH).so + ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-solaris$(ARCH).jar + JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/solaris +endif libz.a: -rm -rf zlib-1.2.8 diff --git a/db/db_compaction_test.cc b/db/db_compaction_test.cc index e2925ba07..d29b50e7f 100644 --- a/db/db_compaction_test.cc +++ b/db/db_compaction_test.cc @@ -1898,7 +1898,7 @@ TEST_P(DBCompactionTestWithParam, DISABLED_CompactFilesOnLevelCompaction) { std::set overlapping_file_names; std::vector compaction_input_file_names; for (int f = 0; f < file_picked; ++f) { - int level; + int level = 0; auto file_meta = PickFileRandomly(cf_meta, &rnd, &level); compaction_input_file_names.push_back(file_meta->name); GetOverlappingFileNumbersForLevelCompaction( diff --git a/db/db_impl.cc b/db/db_impl.cc index 77dc9457d..fd667aa04 100644 --- a/db/db_impl.cc +++ b/db/db_impl.cc @@ -15,6 +15,7 @@ #include #include +#include #include #include diff --git a/db/db_test.cc b/db/db_test.cc index 34b94cfdf..442658b44 100644 --- a/db/db_test.cc +++ b/db/db_test.cc @@ -20,6 +20,7 @@ #ifndef OS_WIN #include #endif +#include #include "db/filename.h" #include "db/dbformat.h" diff --git a/java/src/main/java/org/rocksdb/util/Environment.java b/java/src/main/java/org/rocksdb/util/Environment.java index f65b92a0e..306eae093 100644 --- a/java/src/main/java/org/rocksdb/util/Environment.java +++ b/java/src/main/java/org/rocksdb/util/Environment.java @@ -18,6 +18,10 @@ public class Environment { OS.contains("aix")); } + public static boolean isSolaris() { + return OS.contains("sunos"); + } + public static boolean is64Bit() { return (ARCH.indexOf("64") > 0); } @@ -36,7 +40,9 @@ public class Environment { return String.format("%sjni-linux%s", name, arch); } else if (isMac()) { return String.format("%sjni-osx", name); - } + } else if (isSolaris()) { + return String.format("%sjni-solaris%d", name, is64Bit() ? 64 : 32); + } throw new UnsupportedOperationException(); } @@ -45,7 +51,7 @@ public class Environment { } private static String appendLibOsSuffix(final String libraryFileName, final boolean shared) { - if (isUnix()) { + if (isUnix() || isSolaris()) { return libraryFileName + ".so"; } else if (isMac()) { return libraryFileName + (shared ? ".dylib" : ".jnilib"); diff --git a/util/options_builder.cc b/util/options_builder.cc index 67fd268a9..72ea7a46d 100644 --- a/util/options_builder.cc +++ b/util/options_builder.cc @@ -7,6 +7,8 @@ #include #include "rocksdb/options.h" +using std::log; + namespace rocksdb { namespace { diff --git a/utilities/geodb/geodb_impl.cc b/utilities/geodb/geodb_impl.cc index b30dd6333..e134dd62c 100644 --- a/utilities/geodb/geodb_impl.cc +++ b/utilities/geodb/geodb_impl.cc @@ -19,6 +19,9 @@ #include "util/coding.h" #include "util/string_util.h" +using std::log; +using std::floor; + // // There are two types of keys. The first type of key-values // maps a geo location to the set of object ids and their values. From eaa563756860fd752f40d0bc17e9e58a99aba483 Mon Sep 17 00:00:00 2001 From: David Bernard Date: Tue, 19 Jan 2016 04:59:39 +0000 Subject: [PATCH 2/5] Change notification email for travis --- .travis.yml | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/.travis.yml b/.travis.yml index b6fa63c5d..c73983d58 100644 --- a/.travis.yml +++ b/.travis.yml @@ -38,6 +38,4 @@ script: notifications: email: - - leveldb@fb.com - webhooks: - - https://buildtimetrend.herokuapp.com/travis + - davidbernard@optushome.com.au From 3f12e16f27f32ad6e245ba54c2c09e42c45b3337 Mon Sep 17 00:00:00 2001 From: David Bernard Date: Tue, 19 Jan 2016 06:17:31 +0000 Subject: [PATCH 3/5] Make alloca.h optional --- db/db_impl.cc | 2 ++ db/db_test.cc | 2 ++ 2 files changed, 4 insertions(+) diff --git a/db/db_impl.cc b/db/db_impl.cc index fd667aa04..8f9c0168e 100644 --- a/db/db_impl.cc +++ b/db/db_impl.cc @@ -15,7 +15,9 @@ #include #include +#ifdef OS_SOLARIS #include +#endif #include #include diff --git a/db/db_test.cc b/db/db_test.cc index 442658b44..e692caedb 100644 --- a/db/db_test.cc +++ b/db/db_test.cc @@ -20,7 +20,9 @@ #ifndef OS_WIN #include #endif +#ifdef OS_SOLARIS #include +#endif #include "db/filename.h" #include "db/dbformat.h" From 12809b44b4318d51e989a573b422a132630ed2a0 Mon Sep 17 00:00:00 2001 From: David Bernard Date: Tue, 19 Jan 2016 22:46:39 +0000 Subject: [PATCH 4/5] Revert "Change notification email for travis" This reverts commit eaa563756860fd752f40d0bc17e9e58a99aba483. --- .travis.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index c73983d58..b6fa63c5d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -38,4 +38,6 @@ script: notifications: email: - - davidbernard@optushome.com.au + - leveldb@fb.com + webhooks: + - https://buildtimetrend.herokuapp.com/travis From df7c2f3b59e87e6f2f57dec255ae33fb6fbf27ad Mon Sep 17 00:00:00 2001 From: David Bernard Date: Wed, 20 Jan 2016 00:27:29 +0000 Subject: [PATCH 5/5] As per google coding standard replace "using" in option_builder.cc and geodb_impl.cc --- util/options_builder.cc | 8 +++----- utilities/geodb/geodb_impl.cc | 16 +++++++--------- 2 files changed, 10 insertions(+), 14 deletions(-) diff --git a/util/options_builder.cc b/util/options_builder.cc index 72ea7a46d..1b480f22b 100644 --- a/util/options_builder.cc +++ b/util/options_builder.cc @@ -7,8 +7,6 @@ #include #include "rocksdb/options.h" -using std::log; - namespace rocksdb { namespace { @@ -28,7 +26,7 @@ CompactionStyle PickCompactionStyle(size_t write_buffer_size, // Otherwise, calculate a score based on threshold and expected value of // two styles, weighing reads 4X important than writes. int expected_levels = static_cast(ceil( - ::log(target_db_size / write_buffer_size) / ::log(kBytesForLevelMultiplier))); + std::log(target_db_size / write_buffer_size) / std::log(kBytesForLevelMultiplier))); int expected_max_files_universal = static_cast(ceil(log2(target_db_size / write_buffer_size))); @@ -119,8 +117,8 @@ void OptimizeForLevel(int read_amplification_threshold, int write_amplification_threshold, uint64_t target_db_size, Options* options) { int expected_levels_one_level0_file = - static_cast(ceil(::log(target_db_size / options->write_buffer_size) / - ::log(kBytesForLevelMultiplier))); + static_cast(ceil(std::log(target_db_size / options->write_buffer_size) / + std::log(kBytesForLevelMultiplier))); int level0_stop_writes_trigger = read_amplification_threshold - expected_levels_one_level0_file; diff --git a/utilities/geodb/geodb_impl.cc b/utilities/geodb/geodb_impl.cc index e134dd62c..7fb76f36b 100644 --- a/utilities/geodb/geodb_impl.cc +++ b/utilities/geodb/geodb_impl.cc @@ -19,8 +19,6 @@ #include "util/coding.h" #include "util/string_util.h" -using std::log; -using std::floor; // // There are two types of keys. The first type of key-values @@ -355,8 +353,8 @@ Status GeoDBImpl::searchQuadIds(const GeoPosition& position, Pixel bottomRight = PositionToPixel(bottomRightPos, Detail); // how many level of details to look for - int numberOfTilesAtMaxDepth = static_cast(floor((bottomRight.x - topLeft.x) / 256)); - int zoomLevelsToRise = static_cast(floor(::log(numberOfTilesAtMaxDepth) / ::log(2))); + int numberOfTilesAtMaxDepth = static_cast(std::floor((bottomRight.x - topLeft.x) / 256)); + int zoomLevelsToRise = static_cast(std::floor(std::log(numberOfTilesAtMaxDepth) / std::log(2))); zoomLevelsToRise++; int levels = std::max(0, Detail - zoomLevelsToRise); @@ -393,10 +391,10 @@ GeoDBImpl::Pixel GeoDBImpl::PositionToPixel(const GeoPosition& pos, double latitude = clip(pos.latitude, MinLatitude, MaxLatitude); double x = (pos.longitude + 180) / 360; double sinLatitude = sin(latitude * PI / 180); - double y = 0.5 - ::log((1 + sinLatitude) / (1 - sinLatitude)) / (4 * PI); + double y = 0.5 - std::log((1 + sinLatitude) / (1 - sinLatitude)) / (4 * PI); double mapSize = MapSize(levelOfDetail); - double X = floor(clip(x * mapSize + 0.5, 0, mapSize - 1)); - double Y = floor(clip(y * mapSize + 0.5, 0, mapSize - 1)); + double X = std::floor(clip(x * mapSize + 0.5, 0, mapSize - 1)); + double Y = std::floor(clip(y * mapSize + 0.5, 0, mapSize - 1)); return Pixel((unsigned int)X, (unsigned int)Y); } @@ -411,8 +409,8 @@ GeoPosition GeoDBImpl::PixelToPosition(const Pixel& pixel, int levelOfDetail) { // Converts a Pixel to a Tile GeoDBImpl::Tile GeoDBImpl::PixelToTile(const Pixel& pixel) { - unsigned int tileX = static_cast(floor(pixel.x / 256)); - unsigned int tileY = static_cast(floor(pixel.y / 256)); + unsigned int tileX = static_cast(std::floor(pixel.x / 256)); + unsigned int tileY = static_cast(std::floor(pixel.y / 256)); return Tile(tileX, tileY); }