mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-20 05:08:21 +08:00
mdbx++: add to mdbx::env
overloads with const char*
pathname parameter.
This commit is contained in:
parent
9bbf09b5c4
commit
69b495d559
31
mdbx.h++
31
mdbx.h++
@ -3228,6 +3228,8 @@ public:
|
|||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
env ©(const ::std::string &destination, bool compactify,
|
env ©(const ::std::string &destination, bool compactify,
|
||||||
bool force_dynamic_size = false);
|
bool force_dynamic_size = false);
|
||||||
|
env ©(const char *destination, bool compactify,
|
||||||
|
bool force_dynamic_size = false);
|
||||||
|
|
||||||
/// \brief Copy an environment to the specified file descriptor.
|
/// \brief Copy an environment to the specified file descriptor.
|
||||||
env ©(filehandle fd, bool compactify, bool force_dynamic_size = false);
|
env ©(filehandle fd, bool compactify, bool force_dynamic_size = false);
|
||||||
@ -3252,14 +3254,16 @@ public:
|
|||||||
/// \brief Removes the environment's files in a proper and multiprocess-safe
|
/// \brief Removes the environment's files in a proper and multiprocess-safe
|
||||||
/// way.
|
/// way.
|
||||||
#ifdef MDBX_STD_FILESYSTEM_PATH
|
#ifdef MDBX_STD_FILESYSTEM_PATH
|
||||||
static bool remove(const MDBX_STD_FILESYSTEM_PATH &,
|
static bool remove(const MDBX_STD_FILESYSTEM_PATH &pathname,
|
||||||
const remove_mode mode = just_remove);
|
const remove_mode mode = just_remove);
|
||||||
#endif /* MDBX_STD_FILESYSTEM_PATH */
|
#endif /* MDBX_STD_FILESYSTEM_PATH */
|
||||||
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
||||||
static bool remove(const ::std::wstring &,
|
static bool remove(const ::std::wstring &pathname,
|
||||||
const remove_mode mode = just_remove);
|
const remove_mode mode = just_remove);
|
||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
static bool remove(const ::std::string &,
|
static bool remove(const ::std::string &pathname,
|
||||||
|
const remove_mode mode = just_remove);
|
||||||
|
static bool remove(const char *pathname,
|
||||||
const remove_mode mode = just_remove);
|
const remove_mode mode = just_remove);
|
||||||
|
|
||||||
/// \brief Statistics for a database in the MDBX environment.
|
/// \brief Statistics for a database in the MDBX environment.
|
||||||
@ -3497,14 +3501,16 @@ public:
|
|||||||
|
|
||||||
/// \brief Open existing database.
|
/// \brief Open existing database.
|
||||||
#ifdef MDBX_STD_FILESYSTEM_PATH
|
#ifdef MDBX_STD_FILESYSTEM_PATH
|
||||||
env_managed(const MDBX_STD_FILESYSTEM_PATH &, const operate_parameters &,
|
env_managed(const MDBX_STD_FILESYSTEM_PATH &pathname,
|
||||||
bool accede = true);
|
const operate_parameters &, bool accede = true);
|
||||||
#endif /* MDBX_STD_FILESYSTEM_PATH */
|
#endif /* MDBX_STD_FILESYSTEM_PATH */
|
||||||
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
||||||
env_managed(const ::std::wstring &, const operate_parameters &,
|
env_managed(const ::std::wstring &pathname, const operate_parameters &,
|
||||||
bool accede = true);
|
bool accede = true);
|
||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
env_managed(const ::std::string &, const operate_parameters &,
|
env_managed(const ::std::string &pathname, const operate_parameters &,
|
||||||
|
bool accede = true);
|
||||||
|
explicit env_managed(const char *pathname, const operate_parameters &,
|
||||||
bool accede = true);
|
bool accede = true);
|
||||||
|
|
||||||
/// \brief Additional parameters for creating a new database.
|
/// \brief Additional parameters for creating a new database.
|
||||||
@ -3518,14 +3524,17 @@ public:
|
|||||||
|
|
||||||
/// \brief Create new or open existing database.
|
/// \brief Create new or open existing database.
|
||||||
#ifdef MDBX_STD_FILESYSTEM_PATH
|
#ifdef MDBX_STD_FILESYSTEM_PATH
|
||||||
env_managed(const MDBX_STD_FILESYSTEM_PATH &, const create_parameters &,
|
env_managed(const MDBX_STD_FILESYSTEM_PATH &pathname,
|
||||||
const operate_parameters &, bool accede = true);
|
const create_parameters &, const operate_parameters &,
|
||||||
|
bool accede = true);
|
||||||
#endif /* MDBX_STD_FILESYSTEM_PATH */
|
#endif /* MDBX_STD_FILESYSTEM_PATH */
|
||||||
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
||||||
env_managed(const ::std::wstring &, const create_parameters &,
|
env_managed(const ::std::wstring &pathname, const create_parameters &,
|
||||||
const operate_parameters &, bool accede = true);
|
const operate_parameters &, bool accede = true);
|
||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
env_managed(const ::std::string &, const create_parameters &,
|
env_managed(const ::std::string &pathname, const create_parameters &,
|
||||||
|
const operate_parameters &, bool accede = true);
|
||||||
|
explicit env_managed(const char *pathname, const create_parameters &,
|
||||||
const operate_parameters &, bool accede = true);
|
const operate_parameters &, bool accede = true);
|
||||||
|
|
||||||
/// \brief Explicitly closes the environment and release the memory map.
|
/// \brief Explicitly closes the environment and release the memory map.
|
||||||
|
46
src/mdbx.c++
46
src/mdbx.c++
@ -214,12 +214,6 @@ MDBX_MAYBE_UNUSED PATH pchar_to_path(const char *c_str) {
|
|||||||
return PATH(c_str);
|
return PATH(c_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <> struct path_to_pchar<std::string> {
|
|
||||||
const char *const ptr;
|
|
||||||
path_to_pchar(const std::string &path) : ptr(path.c_str()) {}
|
|
||||||
operator const char *() const { return ptr; }
|
|
||||||
};
|
|
||||||
|
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
|
||||||
#ifndef WC_ERR_INVALID_CHARS
|
#ifndef WC_ERR_INVALID_CHARS
|
||||||
@ -1271,17 +1265,21 @@ env &env::copy(const ::std::wstring &destination, bool compactify,
|
|||||||
}
|
}
|
||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
|
|
||||||
env &env::copy(const ::std::string &destination, bool compactify,
|
env &env::copy(const char *destination, bool compactify,
|
||||||
bool force_dynamic_size) {
|
bool force_dynamic_size) {
|
||||||
const path_to_pchar<::std::string> utf8(destination);
|
|
||||||
error::success_or_throw(
|
error::success_or_throw(
|
||||||
::mdbx_env_copy(handle_, utf8,
|
::mdbx_env_copy(handle_, destination,
|
||||||
(compactify ? MDBX_CP_COMPACT : MDBX_CP_DEFAULTS) |
|
(compactify ? MDBX_CP_COMPACT : MDBX_CP_DEFAULTS) |
|
||||||
(force_dynamic_size ? MDBX_CP_FORCE_DYNAMIC_SIZE
|
(force_dynamic_size ? MDBX_CP_FORCE_DYNAMIC_SIZE
|
||||||
: MDBX_CP_DEFAULTS)));
|
: MDBX_CP_DEFAULTS)));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
env &env::copy(const ::std::string &destination, bool compactify,
|
||||||
|
bool force_dynamic_size) {
|
||||||
|
return copy(destination.c_str(), compactify, force_dynamic_size);
|
||||||
|
}
|
||||||
|
|
||||||
env &env::copy(filehandle fd, bool compactify, bool force_dynamic_size) {
|
env &env::copy(filehandle fd, bool compactify, bool force_dynamic_size) {
|
||||||
error::success_or_throw(
|
error::success_or_throw(
|
||||||
::mdbx_env_copy2fd(handle_, fd,
|
::mdbx_env_copy2fd(handle_, fd,
|
||||||
@ -1314,10 +1312,13 @@ bool env::remove(const ::std::wstring &pathname, const remove_mode mode) {
|
|||||||
}
|
}
|
||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
|
|
||||||
bool env::remove(const ::std::string &pathname, const remove_mode mode) {
|
bool env::remove(const char *pathname, const remove_mode mode) {
|
||||||
const path_to_pchar<::std::string> utf8(pathname);
|
|
||||||
return error::boolean_or_throw(
|
return error::boolean_or_throw(
|
||||||
::mdbx_env_delete(utf8, MDBX_env_delete_mode_t(mode)));
|
::mdbx_env_delete(pathname, MDBX_env_delete_mode_t(mode)));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool env::remove(const ::std::string &pathname, const remove_mode mode) {
|
||||||
|
return remove(pathname.c_str(), mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
@ -1418,28 +1419,26 @@ __cold env_managed::env_managed(const ::std::wstring &pathname,
|
|||||||
}
|
}
|
||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
|
|
||||||
__cold env_managed::env_managed(const ::std::string &pathname,
|
__cold env_managed::env_managed(const char *pathname,
|
||||||
const operate_parameters &op, bool accede)
|
const operate_parameters &op, bool accede)
|
||||||
: env_managed(create_env()) {
|
: env_managed(create_env()) {
|
||||||
setup(op.max_maps, op.max_readers);
|
setup(op.max_maps, op.max_readers);
|
||||||
const path_to_pchar<::std::string> utf8(pathname);
|
|
||||||
error::success_or_throw(
|
error::success_or_throw(
|
||||||
::mdbx_env_open(handle_, utf8, op.make_flags(accede), 0));
|
::mdbx_env_open(handle_, pathname, op.make_flags(accede), 0));
|
||||||
|
|
||||||
if (op.options.nested_write_transactions &&
|
if (op.options.nested_write_transactions &&
|
||||||
!get_options().nested_write_transactions)
|
!get_options().nested_write_transactions)
|
||||||
MDBX_CXX20_UNLIKELY error::throw_exception(MDBX_INCOMPATIBLE);
|
MDBX_CXX20_UNLIKELY error::throw_exception(MDBX_INCOMPATIBLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
__cold env_managed::env_managed(const ::std::string &pathname,
|
__cold env_managed::env_managed(const char *pathname,
|
||||||
const env_managed::create_parameters &cp,
|
const env_managed::create_parameters &cp,
|
||||||
const env::operate_parameters &op, bool accede)
|
const env::operate_parameters &op, bool accede)
|
||||||
: env_managed(create_env()) {
|
: env_managed(create_env()) {
|
||||||
setup(op.max_maps, op.max_readers);
|
setup(op.max_maps, op.max_readers);
|
||||||
const path_to_pchar<::std::string> utf8(pathname);
|
|
||||||
set_geometry(cp.geometry);
|
set_geometry(cp.geometry);
|
||||||
error::success_or_throw(
|
error::success_or_throw(::mdbx_env_open(
|
||||||
::mdbx_env_open(handle_, utf8, op.make_flags(accede, cp.use_subdirectory),
|
handle_, pathname, op.make_flags(accede, cp.use_subdirectory),
|
||||||
cp.file_mode_bits));
|
cp.file_mode_bits));
|
||||||
|
|
||||||
if (op.options.nested_write_transactions &&
|
if (op.options.nested_write_transactions &&
|
||||||
@ -1447,6 +1446,15 @@ __cold env_managed::env_managed(const ::std::string &pathname,
|
|||||||
MDBX_CXX20_UNLIKELY error::throw_exception(MDBX_INCOMPATIBLE);
|
MDBX_CXX20_UNLIKELY error::throw_exception(MDBX_INCOMPATIBLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
__cold env_managed::env_managed(const ::std::string &pathname,
|
||||||
|
const operate_parameters &op, bool accede)
|
||||||
|
: env_managed(pathname.c_str(), op, accede) {}
|
||||||
|
|
||||||
|
__cold env_managed::env_managed(const ::std::string &pathname,
|
||||||
|
const env_managed::create_parameters &cp,
|
||||||
|
const env::operate_parameters &op, bool accede)
|
||||||
|
: env_managed(pathname.c_str(), cp, op, accede) {}
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
|
||||||
txn_managed txn::start_nested() {
|
txn_managed txn::start_nested() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user