[dev-db/mongodb] add newer
This commit is contained in:
parent
6d67032b2b
commit
3ef1c19c85
dev-db/mongodb
Manifest
files
mongodb-4.2.0-fix-scons.patchmongodb-4.2.15-no-compass.patchmongodb-4.2.17-boost-1.79.patchmongodb-4.4.1-boost.patchmongodb-4.4.1-fix-scons.patchmongodb-4.4.1-gcc11.patchmongodb-4.4.10-boost-1.79.patchmongodb-4.4.10-boost-1.81.patchmongodb-4.4.10-no-force-lld.patchmongodb-4.4.8-gcc-13.patchmongodb-4.4.8-no-compass.patchmongodb-5.0.2-boost-1.79.patchmongodb-5.0.2-fix-scons.patchmongodb-5.0.2-glibc-2.34.patchmongodb-5.0.2-no-compass.patchmongodb-5.0.2-skip-no-exceptions.patchmongodb-5.0.2-skip-reqs-check.patchmongodb-5.0.5-boost-1.81-extra.patchmongodb-5.0.5-no-force-lld.patchmongodb.conf-r3mongodb.confd-r3mongodb.initd-r3mongodb.logrotatemongodb.servicemongodb.service-r1mongos.conf-r2mongos.confd-r3mongos.initd-r3
metadata.xmlmongodb-4.4.19.ebuildmongodb-5.0.15.ebuild
2
dev-db/mongodb/Manifest
Normal file
2
dev-db/mongodb/Manifest
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
DIST mongodb-src-r4.4.19.tar.gz 50865489 BLAKE2B 082956a1c64daca2ac1c8c59e5a2a14a773e2cdf9ca076589d4afd3914584e68bbae0101d05d90a6c51b10aa8cd07c96c589c13f5374948ad80c2db0838625a5 SHA512 70310d74072077c9470f1bf99389c14a21e8631374df2dae16e4a7e8d6d9ebcf260d4ce21d34174e1cca13d58802a5cc3990c3b2511c76de6d0e12e57d06bb6a
|
||||||
|
DIST mongodb-src-r5.0.15.tar.gz 56141122 BLAKE2B a1ac106b046499cd643fcbed6173a2a2c366be4e20b1a80e7ff604a192b35ce6f294f589c5c18b68c2b04b257d28eaf97366516f6e83a717da2e2b7c9615945d SHA512 1f3298bb92ebdeab3894257cf9d98e1a61601d418f0a30e3fada621dfcb530e642a861c8297b0d698cebef6e5027ea7bd07bfa5297d9a9b679a3580f2a365308
|
30
dev-db/mongodb/files/mongodb-4.2.0-fix-scons.patch
Normal file
30
dev-db/mongodb/files/mongodb-4.2.0-fix-scons.patch
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
--- a/SConstruct 2019-08-21 09:25:00.980260318 +0200
|
||||||
|
+++ b/SConstruct 2019-08-21 09:27:53.653601283 +0200
|
||||||
|
@@ -1858,7 +1858,6 @@
|
||||||
|
# -Winvalid-pch Warn if a precompiled header (see Precompiled Headers) is found in the search path but can't be used.
|
||||||
|
env.Append( CCFLAGS=["-fno-omit-frame-pointer",
|
||||||
|
"-fno-strict-aliasing",
|
||||||
|
- "-ggdb" if not env.TargetOSIs('emscripten') else "-g",
|
||||||
|
"-pthread",
|
||||||
|
"-Wall",
|
||||||
|
"-Wsign-compare",
|
||||||
|
@@ -1870,6 +1869,8 @@
|
||||||
|
env.Append( CCFLAGS=["-Werror"] )
|
||||||
|
|
||||||
|
env.Append( CXXFLAGS=["-Woverloaded-virtual"] )
|
||||||
|
+ env.Append( CXXFLAGS=os.environ['CXXFLAGS'] )
|
||||||
|
+ env.Append( LINKFLAGS=os.environ['LDFLAGS'] )
|
||||||
|
if env.ToolchainIs('clang'):
|
||||||
|
env.Append( CXXFLAGS=['-Werror=unused-result'] )
|
||||||
|
|
||||||
|
@@ -1890,8 +1891,8 @@
|
||||||
|
|
||||||
|
env.Append( LIBS=[] )
|
||||||
|
|
||||||
|
- #make scons colorgcc friendly
|
||||||
|
- for key in ('HOME', 'TERM'):
|
||||||
|
+ #make scons colorgcc, distcc, ccache friendly
|
||||||
|
+ for key in ('HOME', 'PATH', 'TERM'):
|
||||||
|
try:
|
||||||
|
env['ENV'][key] = os.environ[key]
|
||||||
|
except KeyError:
|
45
dev-db/mongodb/files/mongodb-4.2.15-no-compass.patch
Normal file
45
dev-db/mongodb/files/mongodb-4.2.15-no-compass.patch
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
diff --git a/src/mongo/SConscript b/src/mongo/SConscript
|
||||||
|
index 0379fcb0..1aabddba 100644
|
||||||
|
--- a/src/mongo/SConscript
|
||||||
|
+++ b/src/mongo/SConscript
|
||||||
|
@@ -808,32 +808,6 @@ for full_dir, archive_dir in list(env["ARCHIVE_ADDITION_DIR_MAP"].items()):
|
||||||
|
for target in env["DIST_BINARIES"]:
|
||||||
|
installBinary(env, "db/modules/" + target)
|
||||||
|
|
||||||
|
-compass_script = "install_compass"
|
||||||
|
-if env.TargetOSIs('windows'):
|
||||||
|
- # On windows the .in needs to be explicitly added to the file.
|
||||||
|
- compass_script = "Install-Compass.ps1"
|
||||||
|
-
|
||||||
|
-compass_installer = f"#/src/mongo/installer/compass/{compass_script}"
|
||||||
|
-
|
||||||
|
-distBinaries.append(compass_installer)
|
||||||
|
-
|
||||||
|
-if not hygienic:
|
||||||
|
- compass_script_installer = env.Install("$INSTALL_DIR/bin", compass_installer)
|
||||||
|
-else:
|
||||||
|
- compass_script_installer = env.AutoInstall(
|
||||||
|
- 'bin',
|
||||||
|
- source=[
|
||||||
|
- compass_installer,
|
||||||
|
- ],
|
||||||
|
- INSTALL_ALIAS=[
|
||||||
|
- 'tools',
|
||||||
|
- ],
|
||||||
|
- )
|
||||||
|
-
|
||||||
|
-if env.TargetOSIs('posix'):
|
||||||
|
- env.AddPostAction( compass_script_installer, 'chmod 755 $TARGET' )
|
||||||
|
- env.AddPostAction( compass_installer, 'chmod 755 $TARGET' )
|
||||||
|
-
|
||||||
|
# "dist" target is valid only when --use-new-tools is specified
|
||||||
|
# Attempts to build release artifacts without tools must fail
|
||||||
|
if has_option("use-new-tools"):
|
||||||
|
@@ -851,7 +825,6 @@ if has_option("use-new-tools"):
|
||||||
|
'--transform $BUILD_DIR/mongo=$SERVER_DIST_BASENAME/bin',
|
||||||
|
'--transform $BUILD_DIR/mongo/stripped/src/mongo-tools=$SERVER_DIST_BASENAME/bin',
|
||||||
|
'--transform src/mongo-tools=$SERVER_DIST_BASENAME/bin',
|
||||||
|
- '--transform src/mongo/installer/compass=$SERVER_DIST_BASENAME/bin',
|
||||||
|
'${TEMPFILE(SOURCES[1:])}'
|
||||||
|
],
|
||||||
|
),
|
41
dev-db/mongodb/files/mongodb-4.2.17-boost-1.79.patch
Normal file
41
dev-db/mongodb/files/mongodb-4.2.17-boost-1.79.patch
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
https://bugs.gentoo.org/844235
|
||||||
|
--- a/src/mongo/util/processinfo_linux.cpp
|
||||||
|
+++ b/src/mongo/util/processinfo_linux.cpp
|
||||||
|
@@ -51,6 +51,7 @@
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/none.hpp>
|
||||||
|
#include <boost/optional.hpp>
|
||||||
|
#include <fmt/format.h>
|
||||||
|
--- a/src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp
|
||||||
|
+++ b/src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include "mongo/base/simple_string_data_comparator.h"
|
||||||
|
--- a/src/mongo/shell/shell_utils_extended.cpp
|
||||||
|
+++ b/src/mongo/shell/shell_utils_extended.cpp
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <fstream>
|
||||||
|
|
||||||
|
#include "mongo/scripting/engine.h"
|
||||||
|
--- a/src/mongo/db/storage/storage_repair_observer.cpp
|
||||||
|
+++ b/src/mongo/db/storage/storage_repair_observer.cpp
|
||||||
|
@@ -41,6 +41,7 @@
|
||||||
|
#include <sys/types.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include "mongo/db/dbhelpers.h"
|
21
dev-db/mongodb/files/mongodb-4.4.1-boost.patch
Normal file
21
dev-db/mongodb/files/mongodb-4.4.1-boost.patch
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -3511,17 +3511,11 @@ def doConfigure(myenv):
|
||||||
|
"BOOST_LOG_NO_SHORTHAND_NAMES",
|
||||||
|
"BOOST_LOG_USE_NATIVE_SYSLOG",
|
||||||
|
"BOOST_LOG_WITHOUT_THREAD_ATTR",
|
||||||
|
+ "BOOST_LOG_DYN_LINK",
|
||||||
|
"ABSL_FORCE_ALIGNED_ACCESS",
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
- if link_model.startswith("dynamic") and not link_model == 'dynamic-sdk':
|
||||||
|
- conf.env.AppendUnique(
|
||||||
|
- CPPDEFINES=[
|
||||||
|
- "BOOST_LOG_DYN_LINK",
|
||||||
|
- ]
|
||||||
|
- )
|
||||||
|
-
|
||||||
|
if use_system_version_of_library("boost"):
|
||||||
|
if not conf.CheckCXXHeader( "boost/filesystem/operations.hpp" ):
|
||||||
|
myenv.ConfError("can't find boost headers")
|
33
dev-db/mongodb/files/mongodb-4.4.1-fix-scons.patch
Normal file
33
dev-db/mongodb/files/mongodb-4.4.1-fix-scons.patch
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
diff --git a/SConstruct b/SConstruct
|
||||||
|
index 89c044ab..a6d02072 100644
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -2064,7 +2064,6 @@ if env.TargetOSIs('posix'):
|
||||||
|
env.Append( CCFLAGS=["-fno-omit-frame-pointer",
|
||||||
|
"-fno-strict-aliasing",
|
||||||
|
"-fasynchronous-unwind-tables",
|
||||||
|
- "-ggdb" if not env.TargetOSIs('emscripten') else "-g",
|
||||||
|
"-pthread",
|
||||||
|
"-Wall",
|
||||||
|
"-Wsign-compare",
|
||||||
|
@@ -2076,6 +2075,9 @@ if env.TargetOSIs('posix'):
|
||||||
|
env.Append( CCFLAGS=["-Werror"] )
|
||||||
|
|
||||||
|
env.Append( CXXFLAGS=["-Woverloaded-virtual"] )
|
||||||
|
+ env.Append( CXXFLAGS=os.environ['CXXFLAGS'] )
|
||||||
|
+ env.Append( LINKFLAGS=os.environ['LDFLAGS'] )
|
||||||
|
+
|
||||||
|
if env.ToolchainIs('clang'):
|
||||||
|
env.Append( CXXFLAGS=['-Werror=unused-result'] )
|
||||||
|
|
||||||
|
@@ -2096,8 +2098,8 @@ if env.TargetOSIs('posix'):
|
||||||
|
|
||||||
|
env.Append( LIBS=[] )
|
||||||
|
|
||||||
|
- #make scons colorgcc friendly
|
||||||
|
- for key in ('HOME', 'TERM'):
|
||||||
|
+ #make scons colorgcc, distcc, ccache friendly
|
||||||
|
+ for key in ('HOME', 'PATH', 'TERM'):
|
||||||
|
try:
|
||||||
|
env['ENV'][key] = os.environ[key]
|
||||||
|
except KeyError:
|
12
dev-db/mongodb/files/mongodb-4.4.1-gcc11.patch
Normal file
12
dev-db/mongodb/files/mongodb-4.4.1-gcc11.patch
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
https://bugs.gentoo.org/768339
|
||||||
|
|
||||||
|
--- a/src/mongo/db/exec/plan_stats.h
|
||||||
|
+++ b/src/mongo/db/exec/plan_stats.h
|
||||||
|
@@ -33,6 +33,7 @@
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
+#include <optional>
|
||||||
|
|
||||||
|
#include "mongo/db/index/multikey_paths.h"
|
||||||
|
|
71
dev-db/mongodb/files/mongodb-4.4.10-boost-1.79.patch
Normal file
71
dev-db/mongodb/files/mongodb-4.4.10-boost-1.79.patch
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
https://bugs.gentoo.org/844235
|
||||||
|
--- a/src/mongo/db/auth/security_key_test.cpp
|
||||||
|
+++ b/src/mongo/db/auth/security_key_test.cpp
|
||||||
|
@@ -30,6 +30,7 @@
|
||||||
|
#include "mongo/platform/basic.h"
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
|
||||||
|
#include "mongo/base/string_data.h"
|
||||||
|
#include "mongo/db/auth/authorization_manager.h"
|
||||||
|
--- a/src/mongo/db/storage/storage_repair_observer.cpp
|
||||||
|
+++ b/src/mongo/db/storage/storage_repair_observer.cpp
|
||||||
|
@@ -41,6 +41,7 @@
|
||||||
|
#include <sys/types.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include "mongo/db/dbhelpers.h"
|
||||||
|
--- a/src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine_test.cpp
|
||||||
|
+++ b/src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine_test.cpp
|
||||||
|
@@ -34,6 +34,7 @@
|
||||||
|
#include "mongo/db/storage/kv/kv_engine_test_harness.h"
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
--- a/src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp
|
||||||
|
+++ b/src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include "mongo/base/simple_string_data_comparator.h"
|
||||||
|
--- a/src/mongo/shell/shell_utils_extended.cpp
|
||||||
|
+++ b/src/mongo/shell/shell_utils_extended.cpp
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <fstream>
|
||||||
|
|
||||||
|
#include "mongo/bson/bson_validate.h"
|
||||||
|
--- a/src/mongo/util/processinfo_linux.cpp
|
||||||
|
+++ b/src/mongo/util/processinfo_linux.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <iostream>
|
||||||
|
#include <malloc.h>
|
||||||
|
#include <pcrecpp.h>
|
||||||
|
+#include <fstream>
|
||||||
|
#include <sched.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
|
--- a/src/mongo/util/stacktrace_threads.cpp
|
||||||
|
+++ b/src/mongo/util/stacktrace_threads.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <array>
|
||||||
|
#include <atomic>
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <cctype>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <cstdlib>
|
317
dev-db/mongodb/files/mongodb-4.4.10-boost-1.81.patch
Normal file
317
dev-db/mongodb/files/mongodb-4.4.10-boost-1.81.patch
Normal file
@ -0,0 +1,317 @@
|
|||||||
|
https://bugs.gentoo.org/887037
|
||||||
|
|
||||||
|
Workaround https://github.com/boostorg/container/commit/99091420ae553b27345e04279fd19fe24fb684c1
|
||||||
|
in Boost 1.81.
|
||||||
|
|
||||||
|
Upstream s2 (as in real upstream, not MongoDB) has deviated substantially
|
||||||
|
from the version vendored.
|
||||||
|
--- a/src/third_party/s2/base/stl_decl_msvc.h
|
||||||
|
+++ b/src/third_party/s2/base/stl_decl_msvc.h
|
||||||
|
@@ -118,8 +118,8 @@ namespace msvchash {
|
||||||
|
class hash_multimap;
|
||||||
|
} // end namespace msvchash
|
||||||
|
|
||||||
|
-using msvchash::hash_set;
|
||||||
|
-using msvchash::hash_map;
|
||||||
|
+using msvchash::hash_set = my_hash_set;
|
||||||
|
+using msvchash::hash_map = my_hash_map;
|
||||||
|
using msvchash::hash;
|
||||||
|
using msvchash::hash_multimap;
|
||||||
|
using msvchash::hash_multiset;
|
||||||
|
--- a/src/third_party/s2/base/stl_decl_osx.h
|
||||||
|
+++ b/src/third_party/s2/base/stl_decl_osx.h
|
||||||
|
@@ -68,8 +68,8 @@ using std::string;
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using __gnu_cxx::hash;
|
||||||
|
-using __gnu_cxx::hash_set;
|
||||||
|
-using __gnu_cxx::hash_map;
|
||||||
|
+using __gnu_cxx::hash_set = my_hash_set;
|
||||||
|
+using __gnu_cxx::hash_map = my_hash_map;
|
||||||
|
using __gnu_cxx::select1st;
|
||||||
|
|
||||||
|
/* On Linux (and gdrive on OSX), this comes from places like
|
||||||
|
--- a/src/third_party/s2/hash.h
|
||||||
|
+++ b/src/third_party/s2/hash.h
|
||||||
|
@@ -2,10 +2,10 @@
|
||||||
|
#define THIRD_PARTY_S2_HASH_H_
|
||||||
|
|
||||||
|
#include <unordered_map>
|
||||||
|
-#define hash_map std::unordered_map
|
||||||
|
+#define my_hash_map std::unordered_map
|
||||||
|
|
||||||
|
#include <unordered_set>
|
||||||
|
-#define hash_set std::unordered_set
|
||||||
|
+#define my_hash_set std::unordered_set
|
||||||
|
|
||||||
|
#define HASH_NAMESPACE_START namespace std {
|
||||||
|
#define HASH_NAMESPACE_END }
|
||||||
|
--- a/src/third_party/s2/s2_test.cc
|
||||||
|
+++ b/src/third_party/s2/s2_test.cc
|
||||||
|
@@ -10,7 +10,7 @@ using std::reverse;
|
||||||
|
|
||||||
|
#include <hash_set>
|
||||||
|
#include <hash_map>
|
||||||
|
-using __gnu_cxx::hash_set;
|
||||||
|
+using __gnu_cxx::hash_set = my_hash_map;
|
||||||
|
|
||||||
|
#include "s2.h"
|
||||||
|
#include "base/logging.h"
|
||||||
|
@@ -709,8 +709,8 @@ TEST(S2, Frames) {
|
||||||
|
#if 0
|
||||||
|
TEST(S2, S2PointHashSpreads) {
|
||||||
|
int kTestPoints = 1 << 16;
|
||||||
|
- hash_set<size_t> set;
|
||||||
|
- hash_set<S2Point> points;
|
||||||
|
+ my_hash_set<size_t> set;
|
||||||
|
+ my_hash_set<S2Point> points;
|
||||||
|
hash<S2Point> hasher;
|
||||||
|
S2Point base = S2Point(1, 1, 1);
|
||||||
|
for (int i = 0; i < kTestPoints; ++i) {
|
||||||
|
@@ -733,7 +733,7 @@ TEST(S2, S2PointHashCollapsesZero) {
|
||||||
|
double minus_zero = -zero;
|
||||||
|
EXPECT_NE(*reinterpret_cast<uint64 const*>(&zero),
|
||||||
|
*reinterpret_cast<uint64 const*>(&minus_zero));
|
||||||
|
- hash_map<S2Point, int> map;
|
||||||
|
+ my_hash_map<S2Point, int> map;
|
||||||
|
S2Point zero_pt(zero, zero, zero);
|
||||||
|
S2Point minus_zero_pt(minus_zero, minus_zero, minus_zero);
|
||||||
|
|
||||||
|
--- a/src/third_party/s2/s2cellid_test.cc
|
||||||
|
+++ b/src/third_party/s2/s2cellid_test.cc
|
||||||
|
@@ -10,7 +10,7 @@ using std::reverse;
|
||||||
|
|
||||||
|
#include <cstdio>
|
||||||
|
#include <hash_map>
|
||||||
|
-using __gnu_cxx::hash_map;
|
||||||
|
+using __gnu_cxx::hash_map = my_hash_map;
|
||||||
|
|
||||||
|
#include <sstream>
|
||||||
|
#include <vector>
|
||||||
|
@@ -170,7 +170,7 @@ TEST(S2CellId, Tokens) {
|
||||||
|
static const int kMaxExpandLevel = 3;
|
||||||
|
|
||||||
|
static void ExpandCell(S2CellId const& parent, vector<S2CellId>* cells,
|
||||||
|
- hash_map<S2CellId, S2CellId>* parent_map) {
|
||||||
|
+ my_hash_map<S2CellId, S2CellId>* parent_map) {
|
||||||
|
cells->push_back(parent);
|
||||||
|
if (parent.level() == kMaxExpandLevel) return;
|
||||||
|
int i, j, orientation;
|
||||||
|
@@ -194,7 +194,7 @@ static void ExpandCell(S2CellId const& parent, vector<S2CellId>* cells,
|
||||||
|
|
||||||
|
TEST(S2CellId, Containment) {
|
||||||
|
// Test contains() and intersects().
|
||||||
|
- hash_map<S2CellId, S2CellId> parent_map;
|
||||||
|
+ my_hash_map<S2CellId, S2CellId> parent_map;
|
||||||
|
vector<S2CellId> cells;
|
||||||
|
for (int face = 0; face < 6; ++face) {
|
||||||
|
ExpandCell(S2CellId::FromFacePosLevel(face, 0, 0), &cells, &parent_map);
|
||||||
|
--- a/src/third_party/s2/s2loop.cc
|
||||||
|
+++ b/src/third_party/s2/s2loop.cc
|
||||||
|
@@ -120,7 +120,7 @@ bool S2Loop::IsValid(string* err) const {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Loops are not allowed to have any duplicate vertices.
|
||||||
|
- hash_map<S2Point, int> vmap;
|
||||||
|
+ my_hash_map<S2Point, int> vmap;
|
||||||
|
for (int i = 0; i < num_vertices(); ++i) {
|
||||||
|
if (!vmap.insert(make_pair(vertex(i), i)).second) {
|
||||||
|
VLOG(2) << "Duplicate vertices: " << vmap[vertex(i)] << " and " << i;
|
||||||
|
--- a/src/third_party/s2/s2polygon.cc
|
||||||
|
+++ b/src/third_party/s2/s2polygon.cc
|
||||||
|
@@ -117,7 +117,7 @@ HASH_NAMESPACE_END
|
||||||
|
bool S2Polygon::IsValid(const vector<S2Loop*>& loops, string* err) {
|
||||||
|
// If a loop contains an edge AB, then no other loop may contain AB or BA.
|
||||||
|
if (loops.size() > 1) {
|
||||||
|
- hash_map<S2PointPair, pair<int, int> > edges;
|
||||||
|
+ my_hash_map<S2PointPair, pair<int, int> > edges;
|
||||||
|
for (size_t i = 0; i < loops.size(); ++i) {
|
||||||
|
S2Loop* lp = loops[i];
|
||||||
|
for (int j = 0; j < lp->num_vertices(); ++j) {
|
||||||
|
--- a/src/third_party/s2/s2polygonbuilder.cc
|
||||||
|
+++ b/src/third_party/s2/s2polygonbuilder.cc
|
||||||
|
@@ -175,7 +175,7 @@ S2Loop* S2PolygonBuilder::AssembleLoop(S2Point const& v0, S2Point const& v1,
|
||||||
|
// This ensures that only CCW loops are constructed when possible.
|
||||||
|
|
||||||
|
vector<S2Point> path; // The path so far.
|
||||||
|
- hash_map<S2Point, int> index; // Maps a vertex to its index in "path".
|
||||||
|
+ my_hash_map<S2Point, int> index; // Maps a vertex to its index in "path".
|
||||||
|
path.push_back(v0);
|
||||||
|
path.push_back(v1);
|
||||||
|
index[v1] = 1;
|
||||||
|
@@ -361,7 +361,7 @@ void S2PolygonBuilder::BuildMergeMap(PointIndex* index, MergeMap* merge_map) {
|
||||||
|
|
||||||
|
// First, we build the set of all the distinct vertices in the input.
|
||||||
|
// We need to include the source and destination of every edge.
|
||||||
|
- hash_set<S2Point> vertices;
|
||||||
|
+ my_hash_set<S2Point> vertices;
|
||||||
|
for (EdgeSet::const_iterator i = edges_->begin(); i != edges_->end(); ++i) {
|
||||||
|
vertices.insert(i->first);
|
||||||
|
VertexSet const& vset = i->second;
|
||||||
|
@@ -370,7 +370,7 @@ void S2PolygonBuilder::BuildMergeMap(PointIndex* index, MergeMap* merge_map) {
|
||||||
|
}
|
||||||
|
|
||||||
|
// Build a spatial index containing all the distinct vertices.
|
||||||
|
- for (hash_set<S2Point>::const_iterator i = vertices.begin();
|
||||||
|
+ for (my_hash_set<S2Point>::const_iterator i = vertices.begin();
|
||||||
|
i != vertices.end(); ++i) {
|
||||||
|
index->Insert(*i);
|
||||||
|
}
|
||||||
|
@@ -378,7 +378,7 @@ void S2PolygonBuilder::BuildMergeMap(PointIndex* index, MergeMap* merge_map) {
|
||||||
|
// Next, we loop through all the vertices and attempt to grow a maximial
|
||||||
|
// mergeable group starting from each vertex.
|
||||||
|
vector<S2Point> frontier, mergeable;
|
||||||
|
- for (hash_set<S2Point>::const_iterator vstart = vertices.begin();
|
||||||
|
+ for (my_hash_set<S2Point>::const_iterator vstart = vertices.begin();
|
||||||
|
vstart != vertices.end(); ++vstart) {
|
||||||
|
// Skip any vertices that have already been merged with another vertex.
|
||||||
|
if (merge_map->find(*vstart) != merge_map->end()) continue;
|
||||||
|
--- a/src/third_party/s2/s2polygonbuilder.h
|
||||||
|
+++ b/src/third_party/s2/s2polygonbuilder.h
|
||||||
|
@@ -262,7 +262,7 @@ class S2PolygonBuilder {
|
||||||
|
// current position to a new position, and also returns a spatial index
|
||||||
|
// containing all of the vertices that do not need to be moved.
|
||||||
|
class PointIndex;
|
||||||
|
- typedef hash_map<S2Point, S2Point> MergeMap;
|
||||||
|
+ typedef my_hash_map<S2Point, S2Point> MergeMap;
|
||||||
|
void BuildMergeMap(PointIndex* index, MergeMap* merge_map);
|
||||||
|
|
||||||
|
// Moves a set of vertices from old to new positions.
|
||||||
|
@@ -282,7 +282,7 @@ class S2PolygonBuilder {
|
||||||
|
// once. We could have also used a multiset<pair<S2Point, S2Point> >,
|
||||||
|
// but this representation is a bit more convenient.
|
||||||
|
typedef multiset<S2Point> VertexSet;
|
||||||
|
- typedef hash_map<S2Point, VertexSet> EdgeSet;
|
||||||
|
+ typedef my_hash_map<S2Point, VertexSet> EdgeSet;
|
||||||
|
scoped_ptr<EdgeSet> edges_;
|
||||||
|
|
||||||
|
// Unique collection of the starting (first) vertex of all edges,
|
||||||
|
--- a/src/third_party/s2/s2regioncoverer.cc
|
||||||
|
+++ b/src/third_party/s2/s2regioncoverer.cc
|
||||||
|
@@ -321,7 +321,7 @@ void S2RegionCoverer::GetInteriorCellUnion(S2Region const& region,
|
||||||
|
|
||||||
|
void S2RegionCoverer::FloodFill(
|
||||||
|
S2Region const& region, S2CellId const& start, vector<S2CellId>* output) {
|
||||||
|
- hash_set<S2CellId> all;
|
||||||
|
+ my_hash_set<S2CellId> all;
|
||||||
|
vector<S2CellId> frontier;
|
||||||
|
output->clear();
|
||||||
|
all.insert(start);
|
||||||
|
--- a/src/third_party/s2/s2regioncoverer_test.cc
|
||||||
|
+++ b/src/third_party/s2/s2regioncoverer_test.cc
|
||||||
|
@@ -11,7 +11,7 @@ using std::swap;
|
||||||
|
using std::reverse;
|
||||||
|
|
||||||
|
#include <hash_map>
|
||||||
|
-using __gnu_cxx::hash_map;
|
||||||
|
+using __gnu_cxx::hash_map = my_hash_map;
|
||||||
|
|
||||||
|
#include <queue>
|
||||||
|
using std::priority_queue;
|
||||||
|
@@ -65,7 +65,7 @@ static void CheckCovering(S2RegionCoverer const& coverer,
|
||||||
|
vector<S2CellId> const& covering,
|
||||||
|
bool interior) {
|
||||||
|
// Keep track of how many cells have the same coverer.min_level() ancestor.
|
||||||
|
- hash_map<S2CellId, int> min_level_cells;
|
||||||
|
+ my_hash_map<S2CellId, int> min_level_cells;
|
||||||
|
for (int i = 0; i < covering.size(); ++i) {
|
||||||
|
int level = covering[i].level();
|
||||||
|
EXPECT_GE(level, coverer.min_level());
|
||||||
|
@@ -76,7 +76,7 @@ static void CheckCovering(S2RegionCoverer const& coverer,
|
||||||
|
if (covering.size() > coverer.max_cells()) {
|
||||||
|
// If the covering has more than the requested number of cells, then check
|
||||||
|
// that the cell count cannot be reduced by using the parent of some cell.
|
||||||
|
- for (hash_map<S2CellId, int>::const_iterator i = min_level_cells.begin();
|
||||||
|
+ for (my_hash_map<S2CellId, int>::const_iterator i = min_level_cells.begin();
|
||||||
|
i != min_level_cells.end(); ++i) {
|
||||||
|
EXPECT_EQ(i->second, 1);
|
||||||
|
}
|
||||||
|
--- a/src/third_party/s2/strings/split.cc
|
||||||
|
+++ b/src/third_party/s2/strings/split.cc
|
||||||
|
@@ -156,7 +156,7 @@ struct simple_insert_iterator {
|
||||||
|
// SplitStringToIterator{Using|AllowEmpty}().
|
||||||
|
template <typename T>
|
||||||
|
struct simple_hash_map_iterator {
|
||||||
|
- typedef hash_map<T, T> hashmap;
|
||||||
|
+ typedef my_hash_map<T, T> hashmap;
|
||||||
|
hashmap* t;
|
||||||
|
bool even;
|
||||||
|
typename hashmap::iterator curr;
|
||||||
|
@@ -246,8 +246,8 @@ void SplitStringAllowEmpty(const string& full, const char* delim,
|
||||||
|
}
|
||||||
|
|
||||||
|
void SplitStringToHashsetAllowEmpty(const string& full, const char* delim,
|
||||||
|
- hash_set<string>* result) {
|
||||||
|
- simple_insert_iterator<hash_set<string> > it(result);
|
||||||
|
+ my_hash_set<string>* result) {
|
||||||
|
+ simple_insert_iterator<my_hash_set<string> > it(result);
|
||||||
|
SplitStringToIteratorAllowEmpty(full, delim, 0, it);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -258,7 +258,7 @@ void SplitStringToSetAllowEmpty(const string& full, const char* delim,
|
||||||
|
}
|
||||||
|
|
||||||
|
void SplitStringToHashmapAllowEmpty(const string& full, const char* delim,
|
||||||
|
- hash_map<string, string>* result) {
|
||||||
|
+ my_hash_map<string, string>* result) {
|
||||||
|
simple_hash_map_iterator<string> it(result);
|
||||||
|
SplitStringToIteratorAllowEmpty(full, delim, 0, it);
|
||||||
|
}
|
||||||
|
@@ -352,8 +352,8 @@ void SplitStringUsing(const string& full,
|
||||||
|
}
|
||||||
|
|
||||||
|
void SplitStringToHashsetUsing(const string& full, const char* delim,
|
||||||
|
- hash_set<string>* result) {
|
||||||
|
- simple_insert_iterator<hash_set<string> > it(result);
|
||||||
|
+ my_hash_set<string>* result) {
|
||||||
|
+ simple_insert_iterator<my_hash_set<string> > it(result);
|
||||||
|
SplitStringToIteratorUsing(full, delim, it);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -364,7 +364,7 @@ void SplitStringToSetUsing(const string& full, const char* delim,
|
||||||
|
}
|
||||||
|
|
||||||
|
void SplitStringToHashmapUsing(const string& full, const char* delim,
|
||||||
|
- hash_map<string, string>* result) {
|
||||||
|
+ my_hash_map<string, string>* result) {
|
||||||
|
simple_hash_map_iterator<string> it(result);
|
||||||
|
SplitStringToIteratorUsing(full, delim, it);
|
||||||
|
}
|
||||||
|
--- a/src/third_party/s2/strings/split.h
|
||||||
|
+++ b/src/third_party/s2/strings/split.h
|
||||||
|
@@ -41,7 +41,7 @@ using namespace std;
|
||||||
|
void SplitStringAllowEmpty(const string& full, const char* delim,
|
||||||
|
vector<string>* res);
|
||||||
|
void SplitStringToHashsetAllowEmpty(const string& full, const char* delim,
|
||||||
|
- hash_set<string>* res);
|
||||||
|
+ my_hash_set<string>* res);
|
||||||
|
void SplitStringToSetAllowEmpty(const string& full, const char* delim,
|
||||||
|
set<string>* res);
|
||||||
|
// The even-positioned (0-based) components become the keys for the
|
||||||
|
@@ -50,7 +50,7 @@ void SplitStringToSetAllowEmpty(const string& full, const char* delim,
|
||||||
|
// if the key was already present in the hash table, or will be the
|
||||||
|
// empty string if the key is a newly inserted key.
|
||||||
|
void SplitStringToHashmapAllowEmpty(const string& full, const char* delim,
|
||||||
|
- hash_map<string, string>* result);
|
||||||
|
+ my_hash_map<string, string>* result);
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
// SplitStringUsing()
|
||||||
|
@@ -66,7 +66,7 @@ void SplitStringToHashmapAllowEmpty(const string& full, const char* delim,
|
||||||
|
void SplitStringUsing(const string& full, const char* delim,
|
||||||
|
vector<string>* res);
|
||||||
|
void SplitStringToHashsetUsing(const string& full, const char* delim,
|
||||||
|
- hash_set<string>* res);
|
||||||
|
+ my_hash_set<string>* res);
|
||||||
|
void SplitStringToSetUsing(const string& full, const char* delim,
|
||||||
|
set<string>* res);
|
||||||
|
// The even-positioned (0-based) components become the keys for the
|
||||||
|
@@ -75,7 +75,7 @@ void SplitStringToSetUsing(const string& full, const char* delim,
|
||||||
|
// if the key was already present in the hash table, or will be the
|
||||||
|
// empty string if the key is a newly inserted key.
|
||||||
|
void SplitStringToHashmapUsing(const string& full, const char* delim,
|
||||||
|
- hash_map<string, string>* result);
|
||||||
|
+ my_hash_map<string, string>* result);
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
// SplitOneIntToken()
|
29
dev-db/mongodb/files/mongodb-4.4.10-no-force-lld.patch
Normal file
29
dev-db/mongodb/files/mongodb-4.4.10-no-force-lld.patch
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
Don't automagically force lld > gold > bfd. Leave it up to the user.
|
||||||
|
|
||||||
|
In particular, avoids issues with LTO enabled (via the flag/scons option)
|
||||||
|
where using GCC as compiler, as lld can't do LTO with GCC.
|
||||||
|
|
||||||
|
https://bugs.gentoo.org/769986
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -3109,20 +3109,6 @@ def doConfigure(myenv):
|
||||||
|
myenv.Append( CCFLAGS=["/Zc:inline"])
|
||||||
|
|
||||||
|
if myenv.ToolchainIs('gcc', 'clang'):
|
||||||
|
- # This tells clang/gcc to use the gold linker if it is available - we prefer the gold linker
|
||||||
|
- # because it is much faster. Don't use it if the user has already configured another linker
|
||||||
|
- # selection manually.
|
||||||
|
- if not any(flag.startswith('-fuse-ld=') for flag in env['LINKFLAGS']):
|
||||||
|
-
|
||||||
|
- # lld has problems with separate debug info on some platforms. See:
|
||||||
|
- # - https://bugzilla.mozilla.org/show_bug.cgi?id=1485556
|
||||||
|
- # - https://bugzilla.mozilla.org/show_bug.cgi?id=1485556
|
||||||
|
- if get_option('separate-debug') == 'off':
|
||||||
|
- if not AddToLINKFLAGSIfSupported(myenv, '-fuse-ld=lld'):
|
||||||
|
- AddToLINKFLAGSIfSupported(myenv, '-fuse-ld=gold')
|
||||||
|
- else:
|
||||||
|
- AddToLINKFLAGSIfSupported(myenv, '-fuse-ld=gold')
|
||||||
|
-
|
||||||
|
# Usually, --gdb-index is too expensive in big static binaries, but for dynamic
|
||||||
|
# builds it works well.
|
||||||
|
if link_model.startswith("dynamic"):
|
25
dev-db/mongodb/files/mongodb-4.4.8-gcc-13.patch
Normal file
25
dev-db/mongodb/files/mongodb-4.4.8-gcc-13.patch
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
https://cgit.openembedded.org/meta-openembedded-contrib/commit/?id=856c21b061e000640829e158b9bb9e978a974386
|
||||||
|
|
||||||
|
From 5d8218b8a1b5bc71e2a0cf543a000e194daba599 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Khem Raj <raj.khem@gmail.com>
|
||||||
|
Date: Sun, 29 Jan 2023 17:15:30 -0800
|
||||||
|
Subject: [PATCH] free_mon: Include missing <cstdint>
|
||||||
|
|
||||||
|
gcc 13 moved some includes around and as a result <cstdint> is no
|
||||||
|
longer transitively included [1]. Explicitly include it
|
||||||
|
for uintXX_t.
|
||||||
|
|
||||||
|
[1] https://gcc.gnu.org/gcc-13/porting_to.html#header-dep-changes
|
||||||
|
|
||||||
|
Signed-off-by: Khem Raj <raj.khem@gmail.com>
|
||||||
|
--- a/src/mongo/db/free_mon/free_mon_options.h
|
||||||
|
+++ b/src/mongo/db/free_mon/free_mon_options.h
|
||||||
|
@@ -29,6 +29,7 @@
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
+#include <cstdint>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
|
43
dev-db/mongodb/files/mongodb-4.4.8-no-compass.patch
Normal file
43
dev-db/mongodb/files/mongodb-4.4.8-no-compass.patch
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
diff --git a/src/mongo/SConscript b/src/mongo/SConscript
|
||||||
|
index 62fbfc02..5be336f7 100644
|
||||||
|
--- a/src/mongo/SConscript
|
||||||
|
+++ b/src/mongo/SConscript
|
||||||
|
@@ -841,30 +841,6 @@ for full_dir, archive_dir in list(env["ARCHIVE_ADDITION_DIR_MAP"].items()):
|
||||||
|
for target in env["DIST_BINARIES"]:
|
||||||
|
installBinary(env, "db/modules/" + target)
|
||||||
|
|
||||||
|
-compass_script = "install_compass"
|
||||||
|
-if env.TargetOSIs('windows'):
|
||||||
|
- compass_script = "Install-Compass.ps1"
|
||||||
|
-
|
||||||
|
-compass_installer = f"$BUILD_DIR/mongo/installer/compass/{compass_script}"
|
||||||
|
-
|
||||||
|
-distBinaries.append(compass_installer)
|
||||||
|
-
|
||||||
|
-if not hygienic:
|
||||||
|
- compass_script_installer = env.Install("$DESTDIR/bin", compass_installer)
|
||||||
|
-else:
|
||||||
|
- compass_script_installer = env.AutoInstall(
|
||||||
|
- target='$PREFIX_BINDIR',
|
||||||
|
- source=[
|
||||||
|
- compass_installer,
|
||||||
|
- ],
|
||||||
|
- AIB_COMPONENT='dist',
|
||||||
|
- AIB_ROLE='runtime',
|
||||||
|
- )
|
||||||
|
-
|
||||||
|
-if env.TargetOSIs('posix'):
|
||||||
|
- env.AddPostAction( compass_script_installer, 'chmod 755 $TARGET' )
|
||||||
|
- env.AddPostAction( compass_installer, 'chmod 755 $TARGET' )
|
||||||
|
-
|
||||||
|
if not hygienic:
|
||||||
|
server_archive = env.Command(
|
||||||
|
target='#/${SERVER_ARCHIVE}',
|
||||||
|
@@ -878,7 +854,6 @@ if not hygienic:
|
||||||
|
'--transform $BUILD_DIR/mongo/stripped/db/modules/enterprise=$SERVER_DIST_BASENAME/bin',
|
||||||
|
'--transform $BUILD_DIR/mongo/stripped=$SERVER_DIST_BASENAME/bin',
|
||||||
|
'--transform $BUILD_DIR/mongo=$SERVER_DIST_BASENAME/bin',
|
||||||
|
- '--transform src/mongo/installer/compass=$SERVER_DIST_BASENAME/bin',
|
||||||
|
'${TEMPFILE(SOURCES[1:])}'
|
||||||
|
],
|
||||||
|
),
|
71
dev-db/mongodb/files/mongodb-5.0.2-boost-1.79.patch
Normal file
71
dev-db/mongodb/files/mongodb-5.0.2-boost-1.79.patch
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
https://bugs.gentoo.org/844235
|
||||||
|
--- a/src/mongo/db/auth/security_key_test.cpp
|
||||||
|
+++ b/src/mongo/db/auth/security_key_test.cpp
|
||||||
|
@@ -30,6 +30,7 @@
|
||||||
|
#include "mongo/platform/basic.h"
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
|
||||||
|
#include "mongo/base/string_data.h"
|
||||||
|
#include "mongo/db/auth/authorization_manager.h"
|
||||||
|
--- a/src/mongo/db/storage/storage_repair_observer.cpp
|
||||||
|
+++ b/src/mongo/db/storage/storage_repair_observer.cpp
|
||||||
|
@@ -41,6 +41,7 @@
|
||||||
|
#include <sys/types.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include "mongo/db/dbhelpers.h"
|
||||||
|
--- a/src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine_test.cpp
|
||||||
|
+++ b/src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine_test.cpp
|
||||||
|
@@ -34,6 +34,7 @@
|
||||||
|
#include "mongo/db/storage/kv/kv_engine_test_harness.h"
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
--- a/src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp
|
||||||
|
+++ b/src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include "mongo/base/simple_string_data_comparator.h"
|
||||||
|
--- a/src/mongo/shell/shell_utils_extended.cpp
|
||||||
|
+++ b/src/mongo/shell/shell_utils_extended.cpp
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <fmt/format.h>
|
||||||
|
#include <fstream>
|
||||||
|
|
||||||
|
--- a/src/mongo/util/stacktrace_threads.cpp
|
||||||
|
+++ b/src/mongo/util/stacktrace_threads.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <array>
|
||||||
|
#include <atomic>
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
+#include <boost/filesystem/fstream.hpp>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <dirent.h>
|
||||||
|
--- a/src/mongo/util/processinfo_linux.cpp
|
||||||
|
+++ b/src/mongo/util/processinfo_linux.cpp
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include <iostream>
|
||||||
|
#include <malloc.h>
|
||||||
|
#include <pcrecpp.h>
|
||||||
|
+#include <fstream>
|
||||||
|
#include <sched.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/mman.h>
|
32
dev-db/mongodb/files/mongodb-5.0.2-fix-scons.patch
Normal file
32
dev-db/mongodb/files/mongodb-5.0.2-fix-scons.patch
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
diff --git a/SConstruct b/SConstruct
|
||||||
|
index 115de78a..613110b7 100644
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -2366,7 +2366,6 @@ if env.TargetOSIs('posix'):
|
||||||
|
|
||||||
|
# -Winvalid-pch Warn if a precompiled header (see Precompiled Headers) is found in the search path but can't be used.
|
||||||
|
env.Append( CCFLAGS=["-fasynchronous-unwind-tables",
|
||||||
|
- "-ggdb" if not env.TargetOSIs('emscripten') else "-g",
|
||||||
|
"-Wall",
|
||||||
|
"-Wsign-compare",
|
||||||
|
"-Wno-unknown-pragmas",
|
||||||
|
@@ -2422,6 +2421,8 @@ if env.TargetOSIs('posix'):
|
||||||
|
|
||||||
|
# env.Append( " -Wconversion" ) TODO: this doesn't really work yet
|
||||||
|
env.Append( CXXFLAGS=["-Woverloaded-virtual"] )
|
||||||
|
+ env.Append( CXXFLAGS=os.environ['CXXFLAGS'] )
|
||||||
|
+ env.Append( LINKFLAGS=os.environ['LDFLAGS'] )
|
||||||
|
|
||||||
|
# On OS X, clang doesn't want the pthread flag at link time, or it
|
||||||
|
# issues warnings which make it impossible for us to declare link
|
||||||
|
@@ -2473,8 +2474,8 @@ if env.TargetOSIs('posix'):
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
- #make scons colorgcc friendly
|
||||||
|
- for key in ('HOME', 'TERM'):
|
||||||
|
+ #make scons colorgcc, distcc, ccache friendly
|
||||||
|
+ for key in ('HOME', 'PATH', 'TERM'):
|
||||||
|
try:
|
||||||
|
env['ENV'][key] = os.environ[key]
|
||||||
|
except KeyError:
|
16
dev-db/mongodb/files/mongodb-5.0.2-glibc-2.34.patch
Normal file
16
dev-db/mongodb/files/mongodb-5.0.2-glibc-2.34.patch
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
diff --git a/src/mongo/stdx/thread.h b/src/mongo/stdx/thread.h
|
||||||
|
index 7b15bb56..4d8f73ad 100644
|
||||||
|
--- a/src/mongo/stdx/thread.h
|
||||||
|
+++ b/src/mongo/stdx/thread.h
|
||||||
|
@@ -105,10 +105,7 @@ private:
|
||||||
|
// . N Y : 4,344 | 13,048 | 7,352
|
||||||
|
// . Y Y : 4,424 | 13,672 | 8,392
|
||||||
|
// ( https://jira.mongodb.org/secure/attachment/233569/233569_stacktrace-writeup.txt )
|
||||||
|
- static constexpr std::size_t kMongoMinSignalStackSize = std::size_t{64} << 10;
|
||||||
|
-
|
||||||
|
- static constexpr std::size_t kStackSize =
|
||||||
|
- std::max(kMongoMinSignalStackSize, std::size_t{MINSIGSTKSZ});
|
||||||
|
+ static constexpr std::size_t kStackSize = std::size_t{64} << 10;
|
||||||
|
std::unique_ptr<std::byte[]> _stackStorage = std::make_unique<std::byte[]>(kStackSize);
|
||||||
|
|
||||||
|
#else // !MONGO_HAS_SIGALTSTACK
|
12
dev-db/mongodb/files/mongodb-5.0.2-no-compass.patch
Normal file
12
dev-db/mongodb/files/mongodb-5.0.2-no-compass.patch
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
diff --git a/src/mongo/installer/SConscript b/src/mongo/installer/SConscript
|
||||||
|
index 5bd89fe9..489e70ac 100644
|
||||||
|
--- a/src/mongo/installer/SConscript
|
||||||
|
+++ b/src/mongo/installer/SConscript
|
||||||
|
@@ -7,7 +7,6 @@ env = env.Clone()
|
||||||
|
|
||||||
|
env.SConscript(
|
||||||
|
dirs=[
|
||||||
|
- 'compass',
|
||||||
|
'msi',
|
||||||
|
],
|
||||||
|
exports=[
|
13
dev-db/mongodb/files/mongodb-5.0.2-skip-no-exceptions.patch
Normal file
13
dev-db/mongodb/files/mongodb-5.0.2-skip-no-exceptions.patch
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
diff --git a/SConstruct b/SConstruct
|
||||||
|
index 613110b7..4987e24e 100644
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -2958,7 +2958,7 @@ def doConfigure(myenv):
|
||||||
|
|
||||||
|
# This warning was added in clang-5 and incorrectly flags our implementation of
|
||||||
|
# exceptionToStatus(). See https://bugs.llvm.org/show_bug.cgi?id=34804
|
||||||
|
- AddToCCFLAGSIfSupported(myenv, "-Wno-exceptions")
|
||||||
|
+ #AddToCCFLAGSIfSupported(myenv, "-Wno-exceptions")
|
||||||
|
|
||||||
|
# Enable sized deallocation support.
|
||||||
|
AddToCXXFLAGSIfSupported(myenv, '-fsized-deallocation')
|
24
dev-db/mongodb/files/mongodb-5.0.2-skip-reqs-check.patch
Normal file
24
dev-db/mongodb/files/mongodb-5.0.2-skip-reqs-check.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
diff --git a/buildscripts/scons.py b/buildscripts/scons.py
|
||||||
|
index 534fca32..c38f64df 100755
|
||||||
|
--- a/buildscripts/scons.py
|
||||||
|
+++ b/buildscripts/scons.py
|
||||||
|
@@ -19,13 +19,13 @@ SITE_TOOLS_DIR = os.path.join(MONGODB_ROOT, 'site_scons')
|
||||||
|
sys.path = [SCONS_DIR, SITE_TOOLS_DIR] + sys.path
|
||||||
|
|
||||||
|
# pylint: disable=C0413
|
||||||
|
-from mongo.pip_requirements import verify_requirements, MissingRequirements
|
||||||
|
+#from mongo.pip_requirements import verify_requirements, MissingRequirements
|
||||||
|
|
||||||
|
-try:
|
||||||
|
- verify_requirements('etc/pip/compile-requirements.txt')
|
||||||
|
-except MissingRequirements as ex:
|
||||||
|
- print(ex)
|
||||||
|
- sys.exit(1)
|
||||||
|
+#try:
|
||||||
|
+# verify_requirements('etc/pip/compile-requirements.txt')
|
||||||
|
+#except MissingRequirements as ex:
|
||||||
|
+# print(ex)
|
||||||
|
+# sys.exit(1)
|
||||||
|
|
||||||
|
try:
|
||||||
|
import SCons.Script
|
11
dev-db/mongodb/files/mongodb-5.0.5-boost-1.81-extra.patch
Normal file
11
dev-db/mongodb/files/mongodb-5.0.5-boost-1.81-extra.patch
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
https://bugs.gentoo.org/889020
|
||||||
|
--- a/src/mongo/util/boost_assert_shim.cpp
|
||||||
|
+++ b/src/mongo/util/boost_assert_shim.cpp
|
||||||
|
@@ -31,6 +31,7 @@
|
||||||
|
|
||||||
|
#if defined(BOOST_ENABLE_ASSERT_DEBUG_HANDLER) && !defined(NDEBUG)
|
||||||
|
|
||||||
|
+#include <exception>
|
||||||
|
#include <boost/assert.hpp>
|
||||||
|
|
||||||
|
namespace mongo {
|
49
dev-db/mongodb/files/mongodb-5.0.5-no-force-lld.patch
Normal file
49
dev-db/mongodb/files/mongodb-5.0.5-no-force-lld.patch
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
Don't automagically force lld > gold > bfd. Leave it up to the user.
|
||||||
|
|
||||||
|
In particular, avoids issues with LTO enabled (via the flag/scons option)
|
||||||
|
where using GCC as compiler, as lld can't do LTO with GCC.
|
||||||
|
|
||||||
|
https://bugs.gentoo.org/769986
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -2824,40 +2824,6 @@ def doConfigure(myenv):
|
||||||
|
def AddToSHLINKFLAGSIfSupported(env, flag):
|
||||||
|
return AddFlagIfSupported(env, 'C', '.c', flag, True, SHLINKFLAGS=[flag])
|
||||||
|
|
||||||
|
- if myenv.ToolchainIs('gcc', 'clang'):
|
||||||
|
- # This tells clang/gcc to use the gold linker if it is available - we prefer the gold linker
|
||||||
|
- # because it is much faster. Don't use it if the user has already configured another linker
|
||||||
|
- # selection manually.
|
||||||
|
- if any(flag.startswith('-fuse-ld=') for flag in env['LINKFLAGS']):
|
||||||
|
- myenv.FatalError(f"Use the '--linker' option instead of modifying the LINKFLAGS directly.")
|
||||||
|
-
|
||||||
|
- linker_ld = get_option('linker')
|
||||||
|
- if linker_ld == 'auto':
|
||||||
|
- # lld has problems with separate debug info on some platforms. See:
|
||||||
|
- # - https://bugzilla.mozilla.org/show_bug.cgi?id=1485556
|
||||||
|
- # - https://bugzilla.mozilla.org/show_bug.cgi?id=1485556
|
||||||
|
- #
|
||||||
|
- # lld also apparently has problems with symbol resolution
|
||||||
|
- # in some esoteric configurations that apply for us when
|
||||||
|
- # using --link-model=dynamic mode, so disable lld there
|
||||||
|
- # too. See:
|
||||||
|
- # - https://bugs.llvm.org/show_bug.cgi?id=46676
|
||||||
|
- #
|
||||||
|
- # We should revisit all of these issues the next time we upgrade our clang minimum.
|
||||||
|
- if get_option('separate-debug') == 'off' and get_option('link-model') != 'dynamic':
|
||||||
|
- if not AddToLINKFLAGSIfSupported(myenv, '-fuse-ld=lld'):
|
||||||
|
- AddToLINKFLAGSIfSupported(myenv, '-fuse-ld=gold')
|
||||||
|
- else:
|
||||||
|
- AddToLINKFLAGSIfSupported(myenv, '-fuse-ld=gold')
|
||||||
|
- elif link_model.startswith("dynamic") and linker_ld == 'bfd':
|
||||||
|
- # BFD is not supported due to issues with it causing warnings from some of
|
||||||
|
- # the third party libraries that mongodb is linked with:
|
||||||
|
- # https://jira.mongodb.org/browse/SERVER-49465
|
||||||
|
- myenv.FatalError(f"Linker {linker_ld} is not supported with dynamic link model builds.")
|
||||||
|
- else:
|
||||||
|
- if not AddToLINKFLAGSIfSupported(myenv, f'-fuse-ld={linker_ld}'):
|
||||||
|
- myenv.FatalError(f"Linker {linker_ld} could not be configured.")
|
||||||
|
-
|
||||||
|
detectCompiler = Configure(myenv, help=False, custom_tests = {
|
||||||
|
'CheckForCXXLink': CheckForCXXLink,
|
||||||
|
})
|
34
dev-db/mongodb/files/mongodb.conf-r3
Normal file
34
dev-db/mongodb/files/mongodb.conf-r3
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
# !! IMPORTANT !!
|
||||||
|
#
|
||||||
|
# This file uses the YAML format as described in the documentation:
|
||||||
|
# http://docs.mongodb.org/manual/reference/configuration-options/
|
||||||
|
|
||||||
|
storage:
|
||||||
|
dbPath: "/var/lib/mongodb"
|
||||||
|
#engine: wiredTiger
|
||||||
|
|
||||||
|
systemLog:
|
||||||
|
destination: file
|
||||||
|
path: "/var/log/mongodb/mongodb.log"
|
||||||
|
quiet: true
|
||||||
|
logAppend: true
|
||||||
|
|
||||||
|
net:
|
||||||
|
port: 27017
|
||||||
|
bindIp: 127.0.0.1
|
||||||
|
#ssl:
|
||||||
|
# mode: disabled
|
||||||
|
|
||||||
|
#security:
|
||||||
|
#keyFile:
|
||||||
|
#clusterAuthMode:
|
||||||
|
|
||||||
|
#replication:
|
||||||
|
#replSetName:
|
||||||
|
|
||||||
|
# Specifies one of the MongoDB parameters described here:
|
||||||
|
# http://docs.mongodb.org/manual/reference/parameters/
|
||||||
|
#
|
||||||
|
# You can specify multiple setParameter fields such as:
|
||||||
|
# setParameter: {enableTestCommands: 1}
|
||||||
|
#setParameter:
|
11
dev-db/mongodb/files/mongodb.confd-r3
Normal file
11
dev-db/mongodb/files/mongodb.confd-r3
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
# !! IMPORTANT !!
|
||||||
|
#
|
||||||
|
# This file is ONLY used to override some of the init script configuration.
|
||||||
|
#
|
||||||
|
# You should NOT use this file to configure your mongodb instance,
|
||||||
|
# see the /etc/mongodb.conf file instead.
|
||||||
|
#
|
||||||
|
# Available init script modifiers :
|
||||||
|
# - config_file : the configuration file to use (default : /etc/mongodb.conf)
|
||||||
|
# - user : the user used to run your mongodb instance (default : mongodb)
|
||||||
|
# - group : the group used to run your mongodb instance (default : mongodb)
|
19
dev-db/mongodb/files/mongodb.initd-r3
Normal file
19
dev-db/mongodb/files/mongodb.initd-r3
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
#!/sbin/openrc-run
|
||||||
|
# Copyright 1999-2019 Gentoo Authors
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
: ${config_file:="/etc/${RC_SVCNAME}.conf"}
|
||||||
|
: ${user:=mongodb}
|
||||||
|
: ${group:=mongodb}
|
||||||
|
|
||||||
|
command="/usr/bin/mongod"
|
||||||
|
command_args="--config ${config_file}"
|
||||||
|
command_background="true"
|
||||||
|
pidfile="/run/${RC_SVCNAME}.pid"
|
||||||
|
command_user="${user}:${group}"
|
||||||
|
required_files="${config_file}"
|
||||||
|
retry="SIGTERM/30"
|
||||||
|
|
||||||
|
depend() {
|
||||||
|
use net
|
||||||
|
}
|
13
dev-db/mongodb/files/mongodb.logrotate
Normal file
13
dev-db/mongodb/files/mongodb.logrotate
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# Default log rotation / compression keeps 1 year of logs.
|
||||||
|
/var/log/mongodb/*.log {
|
||||||
|
daily
|
||||||
|
rotate 365
|
||||||
|
dateext
|
||||||
|
copytruncate
|
||||||
|
delaycompress
|
||||||
|
compress
|
||||||
|
notifempty
|
||||||
|
extension gz
|
||||||
|
sharedscripts
|
||||||
|
missingok
|
||||||
|
}
|
10
dev-db/mongodb/files/mongodb.service
Normal file
10
dev-db/mongodb/files/mongodb.service
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=High-performance, schema-free document-oriented database
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=mongodb
|
||||||
|
ExecStart=/usr/bin/mongod --quiet --config /etc/mongodb.conf
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
12
dev-db/mongodb/files/mongodb.service-r1
Normal file
12
dev-db/mongodb/files/mongodb.service-r1
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=High-performance, schema-free document-oriented database
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=mongodb
|
||||||
|
ExecStart=/usr/bin/mongod --quiet --config /etc/mongodb.conf
|
||||||
|
LimitNOFILE=65536
|
||||||
|
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
30
dev-db/mongodb/files/mongos.conf-r2
Normal file
30
dev-db/mongodb/files/mongos.conf-r2
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# !! IMPORTANT !!
|
||||||
|
#
|
||||||
|
# This file uses the YAML format as described in the documentation:
|
||||||
|
# http://docs.mongodb.org/manual/reference/configuration-options/
|
||||||
|
|
||||||
|
systemLog:
|
||||||
|
destination: file
|
||||||
|
path: "/var/log/mongodb/mongos.log"
|
||||||
|
quiet: true
|
||||||
|
logAppend: true
|
||||||
|
|
||||||
|
net:
|
||||||
|
port: 27017
|
||||||
|
bindIp: 127.0.0.1
|
||||||
|
ssl:
|
||||||
|
mode: disabled
|
||||||
|
|
||||||
|
#security:
|
||||||
|
#keyFile:
|
||||||
|
#clusterAuthMode:
|
||||||
|
|
||||||
|
#sharding:
|
||||||
|
#configDB:
|
||||||
|
|
||||||
|
# Specifies one of the MongoDB parameters described here:
|
||||||
|
# http://docs.mongodb.org/manual/reference/parameters/
|
||||||
|
#
|
||||||
|
# You can specify multiple setParameter fields such as:
|
||||||
|
# setParameter: {enableTestCommands: 1}
|
||||||
|
#setParameter:
|
11
dev-db/mongodb/files/mongos.confd-r3
Normal file
11
dev-db/mongodb/files/mongos.confd-r3
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
# !! IMPORTANT !!
|
||||||
|
#
|
||||||
|
# This file is ONLY used to override some of the init script configuration.
|
||||||
|
#
|
||||||
|
# You should NOT use this file to configure your mongos instance,
|
||||||
|
# see the /etc/mongos.conf file instead.
|
||||||
|
#
|
||||||
|
# Available init script modifiers :
|
||||||
|
# - config_file : the configuration file to use (default : /etc/mongos.conf)
|
||||||
|
# - user : the user used to run your mongodb instance (default : mongodb)
|
||||||
|
# - group : the group used to run your mongodb instance (default : mongodb)
|
18
dev-db/mongodb/files/mongos.initd-r3
Normal file
18
dev-db/mongodb/files/mongos.initd-r3
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#!/sbin/openrc-run
|
||||||
|
# Copyright 1999-2017 Gentoo Foundation
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
: ${config_file:="/etc/${RC_SVCNAME}.conf"}
|
||||||
|
: ${user:=mongodb}
|
||||||
|
: ${group:=mongodb}
|
||||||
|
|
||||||
|
command="/usr/bin/mongos"
|
||||||
|
command_args="--config ${config_file}"
|
||||||
|
command_background="true"
|
||||||
|
pidfile="/run/${RC_SVCNAME}.pid"
|
||||||
|
command_user="${user}:${group}"
|
||||||
|
required_files="${config_file}"
|
||||||
|
|
||||||
|
depend() {
|
||||||
|
use net
|
||||||
|
}
|
21
dev-db/mongodb/metadata.xml
Normal file
21
dev-db/mongodb/metadata.xml
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
|
||||||
|
<pkgmetadata>
|
||||||
|
<maintainer type="person">
|
||||||
|
<email>ultrabug@gentoo.org</email>
|
||||||
|
<name>Alexys Jacob</name>
|
||||||
|
</maintainer>
|
||||||
|
<longdescription lang="en">
|
||||||
|
MongoDB (from "humongous") is a scalable, high-performance, open source,
|
||||||
|
schema-free, document-oriented database. Written in C++, MongoDB features:
|
||||||
|
|
||||||
|
MongoDB bridges the gap between key-value stores (which are fast and highly
|
||||||
|
scalable) and traditional RDBMS systems (which provide structured schemas
|
||||||
|
and powerful queries).
|
||||||
|
</longdescription>
|
||||||
|
<use>
|
||||||
|
<flag name="lto">Adds support for link time optimization</flag>
|
||||||
|
<flag name="mongosh">Install the MongoDB shell from <pkg>app-admin/mongosh-bin</pkg></flag>
|
||||||
|
<flag name="tools">Install the MongoDB tools (mongoimport, mongodump...) from <pkg>app-admin/mongo-tools</pkg></flag>
|
||||||
|
</use>
|
||||||
|
</pkgmetadata>
|
184
dev-db/mongodb/mongodb-4.4.19.ebuild
Normal file
184
dev-db/mongodb/mongodb-4.4.19.ebuild
Normal file
@ -0,0 +1,184 @@
|
|||||||
|
# Copyright 1999-2023 Gentoo Authors
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
EAPI=8
|
||||||
|
|
||||||
|
PYTHON_COMPAT=( python3_{9..11} )
|
||||||
|
|
||||||
|
SCONS_MIN_VERSION="3.3.1"
|
||||||
|
CHECKREQS_DISK_BUILD="2400M"
|
||||||
|
CHECKREQS_DISK_USR="512M"
|
||||||
|
CHECKREQS_MEMORY="1024M"
|
||||||
|
|
||||||
|
inherit check-reqs flag-o-matic multiprocessing pax-utils python-any-r1 scons-utils systemd toolchain-funcs
|
||||||
|
|
||||||
|
MY_P=${PN}-src-r${PV/_rc/-rc}
|
||||||
|
|
||||||
|
DESCRIPTION="A high-performance, open source, schema-free document-oriented database"
|
||||||
|
HOMEPAGE="https://www.mongodb.com"
|
||||||
|
SRC_URI="https://fastdl.mongodb.org/src/${MY_P}.tar.gz"
|
||||||
|
|
||||||
|
LICENSE="Apache-2.0 SSPL-1"
|
||||||
|
SLOT="0"
|
||||||
|
KEYWORDS="~amd64 ~arm64 -riscv"
|
||||||
|
IUSE="debug kerberos lto ssl test +tools"
|
||||||
|
RESTRICT="!test? ( test )"
|
||||||
|
|
||||||
|
RDEPEND="acct-group/mongodb
|
||||||
|
acct-user/mongodb
|
||||||
|
>=app-arch/snappy-1.1.3:=
|
||||||
|
>=dev-cpp/yaml-cpp-0.6.2:=
|
||||||
|
dev-libs/boost:=[nls]
|
||||||
|
>=dev-libs/libpcre-8.42[cxx]
|
||||||
|
app-arch/zstd:=
|
||||||
|
dev-libs/snowball-stemmer:=
|
||||||
|
net-misc/curl
|
||||||
|
>=sys-libs/zlib-1.2.11:=
|
||||||
|
kerberos? ( dev-libs/cyrus-sasl[kerberos] )
|
||||||
|
ssl? (
|
||||||
|
>=dev-libs/openssl-1.0.1g:0=
|
||||||
|
)"
|
||||||
|
DEPEND="${RDEPEND}
|
||||||
|
${PYTHON_DEPS}
|
||||||
|
sys-libs/ncurses:0=
|
||||||
|
sys-libs/readline:0=
|
||||||
|
debug? ( dev-util/valgrind )"
|
||||||
|
BDEPEND="
|
||||||
|
$(python_gen_any_dep '
|
||||||
|
test? ( dev-python/pymongo[${PYTHON_USEDEP}] dev-python/requests[${PYTHON_USEDEP}] )
|
||||||
|
>=dev-util/scons-3.1.1[${PYTHON_USEDEP}]
|
||||||
|
dev-python/cheetah3[${PYTHON_USEDEP}]
|
||||||
|
dev-python/psutil[${PYTHON_USEDEP}]
|
||||||
|
dev-python/pyyaml[${PYTHON_USEDEP}]
|
||||||
|
')
|
||||||
|
"
|
||||||
|
PDEPEND="tools? ( >=app-admin/mongo-tools-100 )"
|
||||||
|
|
||||||
|
PATCHES=(
|
||||||
|
"${FILESDIR}/${PN}-4.4.1-fix-scons.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.8-no-compass.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.1-boost.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.1-gcc11.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.8-gcc-13.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.10-boost-1.79.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.10-no-force-lld.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.10-boost-1.81.patch"
|
||||||
|
)
|
||||||
|
|
||||||
|
S="${WORKDIR}/${MY_P}"
|
||||||
|
|
||||||
|
python_check_deps() {
|
||||||
|
if use test; then
|
||||||
|
python_has_version "dev-python/pymongo[${PYTHON_USEDEP}]" || return 1
|
||||||
|
python_has_version "dev-python/requests[${PYTHON_USEDEP}]" || return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
python_has_version ">=dev-util/scons-3.1.1[${PYTHON_USEDEP}]" &&
|
||||||
|
python_has_version "dev-python/cheetah3[${PYTHON_USEDEP}]" &&
|
||||||
|
python_has_version "dev-python/psutil[${PYTHON_USEDEP}]" &&
|
||||||
|
python_has_version "dev-python/pyyaml[${PYTHON_USEDEP}]"
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_pretend() {
|
||||||
|
if [[ -n ${REPLACING_VERSIONS} ]]; then
|
||||||
|
if ver_test "$REPLACING_VERSIONS" -lt 4.2; then
|
||||||
|
ewarn "To upgrade from a version earlier than the 4.2-series, you must"
|
||||||
|
ewarn "successively upgrade major releases until you have upgraded"
|
||||||
|
ewarn "to 4.2-series. Then upgrade to 4.4 series."
|
||||||
|
else
|
||||||
|
ewarn "Be sure to set featureCompatibilityVersion to 4.2 before upgrading."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
src_prepare() {
|
||||||
|
default
|
||||||
|
|
||||||
|
# remove bundled libs
|
||||||
|
rm -r src/third_party/{boost-*,pcre-*,scons-*,snappy-*,yaml-cpp-*,zlib-*} || die
|
||||||
|
|
||||||
|
# remove compass
|
||||||
|
rm -r src/mongo/installer/compass || die
|
||||||
|
}
|
||||||
|
|
||||||
|
src_configure() {
|
||||||
|
# https://github.com/mongodb/mongo/wiki/Build-Mongodb-From-Source
|
||||||
|
# --use-system-icu fails tests
|
||||||
|
# --use-system-tcmalloc is strongly NOT recommended:
|
||||||
|
scons_opts=(
|
||||||
|
AR="$(tc-getAR)"
|
||||||
|
CC="$(tc-getCC)"
|
||||||
|
CXX="$(tc-getCXX)"
|
||||||
|
|
||||||
|
--disable-warnings-as-errors
|
||||||
|
--use-system-boost
|
||||||
|
--use-system-pcre
|
||||||
|
--use-system-snappy
|
||||||
|
--use-system-stemmer
|
||||||
|
--use-system-yaml
|
||||||
|
--use-system-zlib
|
||||||
|
--use-system-zstd
|
||||||
|
)
|
||||||
|
|
||||||
|
use arm64 && scons_opts+=( --use-hardware-crc32=off ) # Bug 701300
|
||||||
|
use debug && scons_opts+=( --dbg=on )
|
||||||
|
use kerberos && scons_opts+=( --use-sasl-client )
|
||||||
|
use lto && scons_opts+=( --lto=on )
|
||||||
|
use ssl && scons_opts+=( --ssl )
|
||||||
|
|
||||||
|
# Needed to avoid forcing FORTIFY_SOURCE
|
||||||
|
# Gentoo's toolchain applies these anyway
|
||||||
|
scons_opts+=( --runtime-hardening=off )
|
||||||
|
|
||||||
|
# respect mongoDB upstream's basic recommendations
|
||||||
|
# see bug #536688 and #526114
|
||||||
|
if ! use debug; then
|
||||||
|
filter-flags '-m*'
|
||||||
|
filter-flags '-O?'
|
||||||
|
fi
|
||||||
|
|
||||||
|
default
|
||||||
|
}
|
||||||
|
|
||||||
|
src_compile() {
|
||||||
|
PREFIX="${EPREFIX}/usr" escons "${scons_opts[@]}" --nostrip install-core
|
||||||
|
}
|
||||||
|
|
||||||
|
# FEATURES="test -usersandbox" emerge dev-db/mongodb
|
||||||
|
src_test() {
|
||||||
|
ewarn "Tests may hang with FEATURES=usersandbox"
|
||||||
|
"${EPYTHON}" ./buildscripts/resmoke.py run --dbpathPrefix=test --suites core --jobs=$(makeopts_jobs) || die "Tests failed with ${EPYTHON}"
|
||||||
|
}
|
||||||
|
|
||||||
|
src_install() {
|
||||||
|
dobin build/install/bin/{mongo,mongod,mongos}
|
||||||
|
|
||||||
|
doman debian/mongo*.1
|
||||||
|
dodoc README docs/building.md
|
||||||
|
|
||||||
|
newinitd "${FILESDIR}/${PN}.initd-r3" ${PN}
|
||||||
|
newconfd "${FILESDIR}/${PN}.confd-r3" ${PN}
|
||||||
|
newinitd "${FILESDIR}/mongos.initd-r3" mongos
|
||||||
|
newconfd "${FILESDIR}/mongos.confd-r3" mongos
|
||||||
|
|
||||||
|
insinto /etc
|
||||||
|
newins "${FILESDIR}/${PN}.conf-r3" ${PN}.conf
|
||||||
|
newins "${FILESDIR}/mongos.conf-r2" mongos.conf
|
||||||
|
|
||||||
|
systemd_newunit "${FILESDIR}/${PN}.service-r1" "${PN}.service"
|
||||||
|
|
||||||
|
insinto /etc/logrotate.d/
|
||||||
|
newins "${FILESDIR}/${PN}.logrotate" ${PN}
|
||||||
|
|
||||||
|
# see bug #526114
|
||||||
|
pax-mark emr "${ED}"/usr/bin/{mongo,mongod,mongos}
|
||||||
|
|
||||||
|
diropts -m0750 -o mongodb -g mongodb
|
||||||
|
keepdir /var/log/${PN}
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_postinst() {
|
||||||
|
ewarn "Make sure to read the release notes and follow the upgrade process:"
|
||||||
|
ewarn " https://docs.mongodb.com/manual/release-notes/$(ver_cut 1-2)/"
|
||||||
|
ewarn " https://docs.mongodb.com/manual/release-notes/$(ver_cut 1-2)/#upgrade-procedures"
|
||||||
|
}
|
197
dev-db/mongodb/mongodb-5.0.15.ebuild
Normal file
197
dev-db/mongodb/mongodb-5.0.15.ebuild
Normal file
@ -0,0 +1,197 @@
|
|||||||
|
# Copyright 1999-2023 Gentoo Authors
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
EAPI=8
|
||||||
|
|
||||||
|
PYTHON_COMPAT=( python3_{9..11} )
|
||||||
|
|
||||||
|
SCONS_MIN_VERSION="3.3.1"
|
||||||
|
CHECKREQS_DISK_BUILD="2400M"
|
||||||
|
CHECKREQS_DISK_USR="512M"
|
||||||
|
CHECKREQS_MEMORY="1024M"
|
||||||
|
|
||||||
|
inherit check-reqs flag-o-matic multiprocessing pax-utils python-any-r1 scons-utils systemd toolchain-funcs
|
||||||
|
|
||||||
|
MY_P=${PN}-src-r${PV/_rc/-rc}
|
||||||
|
|
||||||
|
DESCRIPTION="A high-performance, open source, schema-free document-oriented database"
|
||||||
|
HOMEPAGE="https://www.mongodb.com"
|
||||||
|
SRC_URI="https://fastdl.mongodb.org/src/${MY_P}.tar.gz"
|
||||||
|
|
||||||
|
LICENSE="Apache-2.0 SSPL-1"
|
||||||
|
SLOT="0"
|
||||||
|
KEYWORDS="~amd64 ~arm64 -riscv"
|
||||||
|
CPU_FLAGS="cpu_flags_x86_avx"
|
||||||
|
IUSE="debug kerberos lto mongosh ssl +tools ${CPU_FLAGS}"
|
||||||
|
|
||||||
|
# https://github.com/mongodb/mongo/wiki/Test-The-Mongodb-Server
|
||||||
|
# resmoke needs python packages not yet present in Gentoo
|
||||||
|
RESTRICT="test"
|
||||||
|
|
||||||
|
RDEPEND="acct-group/mongodb
|
||||||
|
acct-user/mongodb
|
||||||
|
>=app-arch/snappy-1.1.7:=
|
||||||
|
>=dev-cpp/yaml-cpp-0.6.2:=
|
||||||
|
dev-libs/boost:=[nls]
|
||||||
|
>=dev-libs/libpcre-8.42[cxx]
|
||||||
|
app-arch/zstd:=
|
||||||
|
dev-libs/snowball-stemmer:=
|
||||||
|
>=sys-libs/zlib-1.2.12:=
|
||||||
|
kerberos? ( dev-libs/cyrus-sasl[kerberos] )
|
||||||
|
ssl? (
|
||||||
|
>=dev-libs/openssl-1.0.1g:0=
|
||||||
|
)"
|
||||||
|
DEPEND="${RDEPEND}
|
||||||
|
${PYTHON_DEPS}
|
||||||
|
sys-libs/ncurses:0=
|
||||||
|
sys-libs/readline:0=
|
||||||
|
debug? ( dev-util/valgrind )"
|
||||||
|
BDEPEND="
|
||||||
|
$(python_gen_any_dep '
|
||||||
|
>=dev-util/scons-3.1.1[${PYTHON_USEDEP}]
|
||||||
|
dev-python/cheetah3[${PYTHON_USEDEP}]
|
||||||
|
dev-python/psutil[${PYTHON_USEDEP}]
|
||||||
|
dev-python/pyyaml[${PYTHON_USEDEP}]
|
||||||
|
')
|
||||||
|
"
|
||||||
|
PDEPEND="
|
||||||
|
mongosh? ( app-admin/mongosh-bin )
|
||||||
|
tools? ( >=app-admin/mongo-tools-100 )
|
||||||
|
"
|
||||||
|
|
||||||
|
PATCHES=(
|
||||||
|
"${FILESDIR}/${PN}-4.4.1-boost.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.1-gcc11.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.2-fix-scons.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.2-no-compass.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.2-skip-no-exceptions.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.2-skip-reqs-check.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.2-boost-1.79.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.5-no-force-lld.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.10-boost-1.81.patch"
|
||||||
|
"${FILESDIR}/${PN}-5.0.5-boost-1.81-extra.patch"
|
||||||
|
"${FILESDIR}/${PN}-4.4.8-gcc-13.patch"
|
||||||
|
)
|
||||||
|
|
||||||
|
S="${WORKDIR}/${MY_P}"
|
||||||
|
|
||||||
|
python_check_deps() {
|
||||||
|
python_has_version ">=dev-util/scons-3.1.1[${PYTHON_USEDEP}]" &&
|
||||||
|
python_has_version "dev-python/cheetah3[${PYTHON_USEDEP}]" &&
|
||||||
|
python_has_version "dev-python/psutil[${PYTHON_USEDEP}]" &&
|
||||||
|
python_has_version "dev-python/pyyaml[${PYTHON_USEDEP}]"
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_pretend() {
|
||||||
|
# Bug 809692
|
||||||
|
if use amd64 && ! use cpu_flags_x86_avx; then
|
||||||
|
eerror "MongoDB 5.0 requires use of the AVX instruction set"
|
||||||
|
eerror "https://docs.mongodb.com/v5.0/administration/production-notes/"
|
||||||
|
die "MongoDB requires AVX"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n ${REPLACING_VERSIONS} ]]; then
|
||||||
|
if ver_test "$REPLACING_VERSIONS" -lt 4.4; then
|
||||||
|
ewarn "To upgrade from a version earlier than the 4.4-series, you must"
|
||||||
|
ewarn "successively upgrade major releases until you have upgraded"
|
||||||
|
ewarn "to 4.4-series. Then upgrade to 5.0 series."
|
||||||
|
else
|
||||||
|
ewarn "Be sure to set featureCompatibilityVersion to 4.4 before upgrading."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
src_prepare() {
|
||||||
|
default
|
||||||
|
|
||||||
|
# remove bundled libs
|
||||||
|
rm -r src/third_party/{boost,pcre-*,snappy-*,yaml-cpp,zlib-*} || die
|
||||||
|
|
||||||
|
# remove compass
|
||||||
|
rm -r src/mongo/installer/compass || die
|
||||||
|
}
|
||||||
|
|
||||||
|
src_configure() {
|
||||||
|
# https://github.com/mongodb/mongo/wiki/Build-Mongodb-From-Source
|
||||||
|
# --use-system-icu fails tests
|
||||||
|
# --use-system-tcmalloc is strongly NOT recommended:
|
||||||
|
scons_opts=(
|
||||||
|
AR="$(tc-getAR)"
|
||||||
|
CC="$(tc-getCC)"
|
||||||
|
CXX="$(tc-getCXX)"
|
||||||
|
|
||||||
|
--disable-warnings-as-errors
|
||||||
|
--jobs="$(makeopts_jobs)"
|
||||||
|
--use-system-boost
|
||||||
|
--use-system-pcre
|
||||||
|
--use-system-snappy
|
||||||
|
--use-system-stemmer
|
||||||
|
--use-system-yaml
|
||||||
|
--use-system-zlib
|
||||||
|
--use-system-zstd
|
||||||
|
)
|
||||||
|
|
||||||
|
use arm64 && scons_opts+=( --use-hardware-crc32=off ) # Bug 701300
|
||||||
|
use debug && scons_opts+=( --dbg=on )
|
||||||
|
use kerberos && scons_opts+=( --use-sasl-client )
|
||||||
|
use lto && scons_opts+=( --lto=on )
|
||||||
|
|
||||||
|
scons_opts+=( --ssl=$(usex ssl on off) )
|
||||||
|
|
||||||
|
# Needed to avoid forcing FORTIFY_SOURCE
|
||||||
|
# Gentoo's toolchain applies these anyway
|
||||||
|
scons_opts+=( --runtime-hardening=off )
|
||||||
|
|
||||||
|
# gold is an option here but we don't really do that anymore
|
||||||
|
if tc-ld-is-lld; then
|
||||||
|
scons_opts+=( --linker=lld )
|
||||||
|
else
|
||||||
|
scons_opts+=( --linker=bfd )
|
||||||
|
fi
|
||||||
|
|
||||||
|
# respect mongoDB upstream's basic recommendations
|
||||||
|
# see bug #536688 and #526114
|
||||||
|
if ! use debug; then
|
||||||
|
filter-flags '-m*'
|
||||||
|
filter-flags '-O?'
|
||||||
|
fi
|
||||||
|
|
||||||
|
default
|
||||||
|
}
|
||||||
|
|
||||||
|
src_compile() {
|
||||||
|
PREFIX="${EPREFIX}/usr" ./buildscripts/scons.py "${scons_opts[@]}" install-core || die
|
||||||
|
}
|
||||||
|
|
||||||
|
src_install() {
|
||||||
|
dobin build/install/bin/{mongo,mongod,mongos}
|
||||||
|
|
||||||
|
doman debian/mongo*.1
|
||||||
|
dodoc README docs/building.md
|
||||||
|
|
||||||
|
newinitd "${FILESDIR}/${PN}.initd-r3" ${PN}
|
||||||
|
newconfd "${FILESDIR}/${PN}.confd-r3" ${PN}
|
||||||
|
newinitd "${FILESDIR}/mongos.initd-r3" mongos
|
||||||
|
newconfd "${FILESDIR}/mongos.confd-r3" mongos
|
||||||
|
|
||||||
|
insinto /etc
|
||||||
|
newins "${FILESDIR}/${PN}.conf-r3" ${PN}.conf
|
||||||
|
newins "${FILESDIR}/mongos.conf-r2" mongos.conf
|
||||||
|
|
||||||
|
systemd_newunit "${FILESDIR}/${PN}.service-r1" "${PN}.service"
|
||||||
|
|
||||||
|
insinto /etc/logrotate.d/
|
||||||
|
newins "${FILESDIR}/${PN}.logrotate" ${PN}
|
||||||
|
|
||||||
|
# see bug #526114
|
||||||
|
pax-mark emr "${ED}"/usr/bin/{mongo,mongod,mongos}
|
||||||
|
|
||||||
|
diropts -m0750 -o mongodb -g mongodb
|
||||||
|
keepdir /var/log/${PN}
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_postinst() {
|
||||||
|
ewarn "Make sure to read the release notes and follow the upgrade process:"
|
||||||
|
ewarn " https://docs.mongodb.com/manual/release-notes/$(ver_cut 1-2)/"
|
||||||
|
ewarn " https://docs.mongodb.com/manual/release-notes/$(ver_cut 1-2)/#upgrade-procedures"
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user