From 458f713c538ca4843cd6370732a74584fa1b53b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=9B=D0=B5=D0=BE=D0=BD=D0=B8=D0=B4=20=D0=AE=D1=80=D1=8C?= =?UTF-8?q?=D0=B5=D0=B2=20=28Leonid=20Yuriev=29?= Date: Mon, 20 May 2024 18:18:18 +0300 Subject: [PATCH] =?UTF-8?q?mdbx++:=20=D0=B8=D1=81=D0=BF=D0=BE=D0=BB=D1=8C?= =?UTF-8?q?=D0=B7=D0=BE=D0=B2=D0=B0=D0=BD=D0=B8=D0=B5=20`\n`=20=D0=B2?= =?UTF-8?q?=D0=BC=D0=B5=D1=81=D1=82=D0=BE=20`std::endl`=20(backport).?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/mdbx.c++ | 23 +++++++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/src/mdbx.c++ b/src/mdbx.c++ index d6e82e4c..9b09c05a 100644 --- a/src/mdbx.c++ +++ b/src/mdbx.c++ @@ -247,6 +247,21 @@ struct temp_buffer { } // namespace +#ifndef MDBX_CXX_ENDL +/* Манипулятор std::endl выталкивате буфферизированый вывод, что здесь не + * требуется. + * + * Кроме этого, при сборке libmdbx для символов по-умолчанию выключается + * видимость вне DSO, из-за чего обращение к std::endl иногда укачивает + * линковщики, если комплятор ошибочно формируют direct access к global weak + * symbol, коим является std::endl. */ +#if 0 +#define MDBX_CXX_ENDL ::std::endl +#else +#define MDBX_CXX_ENDL "\n" +#endif +#endif /* MDBX_CXX_ENDL */ + //------------------------------------------------------------------------------ namespace mdbx { @@ -663,7 +678,7 @@ char *to_hex::write_bytes(char *__restrict const dest, size_t dest_size) const { unsigned width = 0; for (const auto end = source.end_byte_ptr(); src != end; ++src) { if (wrap_width && width >= wrap_width) { - out << ::std::endl; + out << MDBX_CXX_ENDL; width = 0; } const int8_t hi = *src >> 4; @@ -858,7 +873,7 @@ char *to_base58::write_bytes(char *__restrict const dest, while (MDBX_LIKELY(begin < end) && *begin == 0) { out.put('1'); if (wrap_width && ++width >= wrap_width) { - out << ::std::endl; + out << MDBX_CXX_ENDL; width = 0; } ++begin; @@ -872,7 +887,7 @@ char *to_base58::write_bytes(char *__restrict const dest, for (size_t i = 0; i < chunk.length(); ++i) { out.put(chunk.char_ptr()[i]); if (wrap_width && ++width >= wrap_width) { - out << ::std::endl; + out << MDBX_CXX_ENDL; width = 0; } } @@ -1049,7 +1064,7 @@ char *to_base64::write_bytes(char *__restrict const dest, src += 3; out.write(&buf.front(), 4); if (wrap_width && (width += 4) >= wrap_width && left) { - out << ::std::endl; + out << MDBX_CXX_ENDL; width = 0; } continue;