diff options
Diffstat (limited to 'testing/mongodb/mongodb-2.4.4-fix-sharedclient.patch')
-rw-r--r-- | testing/mongodb/mongodb-2.4.4-fix-sharedclient.patch | 132 |
1 files changed, 132 insertions, 0 deletions
diff --git a/testing/mongodb/mongodb-2.4.4-fix-sharedclient.patch b/testing/mongodb/mongodb-2.4.4-fix-sharedclient.patch new file mode 100644 index 0000000000..345b60222d --- /dev/null +++ b/testing/mongodb/mongodb-2.4.4-fix-sharedclient.patch @@ -0,0 +1,132 @@ +diff --git a/src/mongo/SConscript b/src/mongo/SConscript +index c026ce9..bbd900c 100644 +--- a/src/mongo/SConscript ++++ b/src/mongo/SConscript +@@ -452,7 +452,7 @@ + env.Library('stacktrace', 'util/stacktrace.cpp') + + env.Program('lame_stacktrace_test', 'util/lame_stacktrace_test.cpp', +- LIBDEPS=['stacktrace', ++ LIBDEPS=['stacktrace', 'foundation', 'mongocommon', 'alltools', + '$BUILD_DIR/mongo/base/base']) + + serverOnlyFiles += mmapFiles +@@ -654,10 +654,6 @@ + "defaultversion", + "gridfs", + "notmongodormongos"]) +-env.Library("allclient", "client/clientOnly.cpp", LIBDEPS=["clientandshell"]) +- +-if has_option( "sharedclient" ): +- sharedClientLibName = str( env.SharedLibrary( "mongoclient", [], LIBDEPS=["allclient"] )[0] ) + + # dbtests test binary + env.StaticLibrary('testframework', ['dbtests/framework.cpp'], LIBDEPS=['unittest/unittest']) +@@ -806,12 +802,6 @@ + env.Install( "$INSTALL_DIR/include/" + id, Glob( id + "*.h" ) ) + env.Install( "$INSTALL_DIR/include/" + id, Glob( id + "*.hpp" ) ) + +-#lib +-if installSetup.libraries: +- env.Install('$INSTALL_DIR/$NIX_LIB_DIR', '#${LIBPREFIX}mongoclient${LIBSUFFIX}') +- if has_option( "sharedclient" ): +- env.Install( "$INSTALL_DIR/$NIX_LIB_DIR", '#${SHLIBPREFIX}mongoclient${SHLIBSUFFIX}') +- + # Stage the top-level mongodb banners + distsrc = env.Dir('#distsrc') + env.Append(MODULE_BANNERS = [distsrc.File('README'), +@@ -842,8 +832,8 @@ + '#/${SERVER_ARCHIVE}', + ['#buildscripts/make_archive.py'] + env["MODULE_BANNERS"] + distBinaries, + ' '.join(['$PYTHON ${SOURCES[0]} -o $TARGET'] + module_banner_transforms + [ +- '--transform ${str(Dir(BUILD_DIR))}/mongo/stripped=$SERVER_DIST_BASENAME/bin', +- '--transform ${str(Dir(BUILD_DIR))}/mongo=$SERVER_DIST_BASENAME/bin', ++ '--transform "${str(Dir(BUILD_DIR))}/mongo/stripped=$SERVER_DIST_BASENAME/bin"', ++ '--transform "${str(Dir(BUILD_DIR))}/mongo=$SERVER_DIST_BASENAME/bin"', + '${TEMPFILE(SOURCES[1:])}'])) + + #final alias +diff --git a/src/SConscript.client b/src/SConscript.client +index b88a54f..a15bbb3 100644 +--- a/src/SConscript.client ++++ b/src/SConscript.client +@@ -4,6 +4,7 @@ + # programs. + + Import('env clientEnv') ++Import("has_option") + + env.Command(['mongo/base/error_codes.h', 'mongo/base/error_codes.cpp',], + ['mongo/base/generate_error_codes.py', 'mongo/base/error_codes.err'], +@@ -36,7 +37,6 @@ clientSourceBasic = [ + 'mongo/client/dbclient.cpp', + 'mongo/client/dbclient_rs.cpp', + 'mongo/client/dbclientcursor.cpp', +- 'mongo/client/distlock.cpp', + 'mongo/client/gridfs.cpp', + 'mongo/client/model.cpp', + 'mongo/client/sasl_client_authenticate.cpp', +@@ -83,7 +83,6 @@ clientSourceBasic = [ + 'mongo/util/timer.cpp', + 'mongo/util/trace.cpp', + 'mongo/util/util.cpp', +- 'mongo/util/version.cpp', + ] + + clientSourceSasl = ['mongo/client/sasl_client_authenticate_impl.cpp', +@@ -93,6 +92,7 @@ clientSourceAll = clientSourceBasic + clientSourceSasl + + if env['MONGO_BUILD_SASL_CLIENT']: + clientSource = clientSourceAll ++ env.Append(LIBS="sasl2") + else: + clientSource = clientSourceBasic + +@@ -133,16 +133,18 @@ for path in clientHeaderDirectories: + clientHeaders.extend(Glob('mongo/%s/*.h' % path)) + clientHeaders.extend(Glob('mongo/%s/*.hpp' % path)) + +-mongoclient_lib = env.Library('mongoclient', clientSource), +-mongoclient_install = env.Install('#/', [ +- mongoclient_lib, +- #env.SharedLibrary('mongoclient', clientSource), +- ]) ++ ++mongoclient_libs = [ env.Library('mongoclient', clientSource) ] ++if has_option( "sharedclient" ): ++ mongoclient_libs.append( env.SharedLibrary('mongoclient', clientSource) ) ++ ++mongoclient_install = env.Install('#/', mongoclient_libs) ++ + env.Alias('mongoclient', mongoclient_install) + + clientTests = clientEnv.Install('#/', [ + clientEnv.Program(target, +- [source, mongoclient_lib]) for (target, source) in exampleSourceMap]) ++ [source, mongoclient_libs[-1]]) for (target, source) in exampleSourceMap]) + + clientTests.append( + clientEnv.Install('#/', clientEnv.Program('bsondemo', 'mongo/bson/bsondemo/bsondemo.cpp'))) +@@ -168,16 +170,18 @@ + 'mongo/bson/bsondemo/bsondemo.cpp', + ], + '${PYTHON} ${SOURCES[0]} -o $TARGET ' +- '--transform ${str(Dir(BUILD_DIR))}/client_build=$CLIENT_DIST_BASENAME/src ' +- '--transform ${str(Dir(BUILD_DIR))}=$CLIENT_DIST_BASENAME/src ' +- '--transform distsrc/client=$CLIENT_DIST_BASENAME ' +- '--transform =$CLIENT_DIST_BASENAME/ ' ++ '--transform "${str(Dir(BUILD_DIR))}/client_build=$CLIENT_DIST_BASENAME/src" ' ++ '--transform "${str(Dir(BUILD_DIR))}=$CLIENT_DIST_BASENAME/src" ' ++ '--transform "distsrc/client=$CLIENT_DIST_BASENAME" ' ++ '--transform "=$CLIENT_DIST_BASENAME/" ' + '${TEMPFILE(SOURCES[1:])}')) + + # install + prefix = GetOption("prefix") + + env.Install(prefix + "/lib", '${LIBPREFIX}mongoclient${LIBSUFFIX}') ++if has_option( "sharedclient" ): ++ env.Install(prefix + "/lib", '${SHLIBPREFIX}mongoclient${SHLIBSUFFIX}') + + for x in clientHeaderDirectories: + inst = env.Install(prefix + "/include/mongo/" + x, |