ClickHouse/src/IO/WriteHelpers.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

118 lines
3.6 KiB
C++
Raw Normal View History

#include <IO/WriteHelpers.h>
#include <cinttypes>
#include <utility>
2022-11-15 00:46:15 +00:00
#include <Common/formatIPv6.h>
2023-03-06 14:53:58 +00:00
#include <base/hex.h>
2010-06-04 18:25:25 +00:00
namespace DB
{
template <typename IteratorSrc, typename IteratorDst>
void formatHex(IteratorSrc src, IteratorDst dst, size_t num_bytes)
{
size_t src_pos = 0;
size_t dst_pos = 0;
for (; src_pos < num_bytes; ++src_pos)
{
writeHexByteLowercase(src[src_pos], &dst[dst_pos]);
dst_pos += 2;
}
}
/** Function used when byte ordering is important when parsing uuid
* ex: When we create an UUID type
*/
void formatUUID(std::reverse_iterator<const UInt8 *> src16, UInt8 * dst36)
{
formatHex(src16 + 8, &dst36[0], 4);
dst36[8] = '-';
formatHex(src16 + 12, &dst36[9], 2);
dst36[13] = '-';
formatHex(src16 + 14, &dst36[14], 2);
dst36[18] = '-';
formatHex(src16, &dst36[19], 2);
dst36[23] = '-';
formatHex(src16 + 2, &dst36[24], 6);
}
void writeIPv4Text(const IPv4 & ip, WriteBuffer & buf)
{
size_t idx = (ip >> 24);
2022-12-07 21:29:17 +00:00
buf.write(one_byte_to_string_lookup_table[idx].first, one_byte_to_string_lookup_table[idx].second);
buf.write('.');
idx = (ip >> 16) & 0xFF;
2022-12-07 21:29:17 +00:00
buf.write(one_byte_to_string_lookup_table[idx].first, one_byte_to_string_lookup_table[idx].second);
buf.write('.');
idx = (ip >> 8) & 0xFF;
2022-12-07 21:29:17 +00:00
buf.write(one_byte_to_string_lookup_table[idx].first, one_byte_to_string_lookup_table[idx].second);
buf.write('.');
idx = ip & 0xFF;
2022-12-07 21:29:17 +00:00
buf.write(one_byte_to_string_lookup_table[idx].first, one_byte_to_string_lookup_table[idx].second);
}
void writeIPv6Text(const IPv6 & ip, WriteBuffer & buf)
{
2022-11-15 00:46:15 +00:00
char addr[IPV6_MAX_TEXT_LENGTH + 1] {};
char * paddr = addr;
formatIPv6(reinterpret_cast<const unsigned char *>(&ip), paddr);
buf.write(addr, paddr - addr - 1);
}
2018-08-24 07:30:53 +00:00
void writeException(const Exception & e, WriteBuffer & buf, bool with_stack_trace)
2012-05-08 05:42:05 +00:00
{
writeBinary(e.code(), buf);
writeBinary(String(e.name()), buf);
2022-05-03 13:13:47 +00:00
writeBinary(e.displayText() + getExtraExceptionInfo(e), buf);
2018-08-24 07:30:53 +00:00
if (with_stack_trace)
writeBinary(e.getStackTraceString(), buf);
2018-08-24 07:30:53 +00:00
else
writeBinary(String(), buf);
2012-05-08 05:42:05 +00:00
bool has_nested = false;
2012-05-08 05:42:05 +00:00
writeBinary(has_nested, buf);
}
/// The same, but quotes apply only if there are characters that do not match the identifier without quotes
template <typename F>
static inline void writeProbablyQuotedStringImpl(StringRef s, WriteBuffer & buf, F && write_quoted_string)
{
if (isValidIdentifier(s.toView())
2021-12-09 20:51:52 +00:00
/// This are valid identifiers but are problematic if present unquoted in SQL query.
&& !(s.size == strlen("distinct") && 0 == strncasecmp(s.data, "distinct", strlen("distinct")))
&& !(s.size == strlen("all") && 0 == strncasecmp(s.data, "all", strlen("all"))))
{
2020-08-08 16:34:35 +00:00
writeString(s, buf);
2021-12-09 20:51:52 +00:00
}
else
2020-08-08 16:34:35 +00:00
write_quoted_string(s, buf);
}
void writeProbablyBackQuotedString(StringRef s, WriteBuffer & buf)
{
writeProbablyQuotedStringImpl(s, buf, [](StringRef s_, WriteBuffer & buf_) { return writeBackQuotedString(s_, buf_); });
}
void writeProbablyDoubleQuotedString(StringRef s, WriteBuffer & buf)
{
writeProbablyQuotedStringImpl(s, buf, [](StringRef s_, WriteBuffer & buf_) { return writeDoubleQuotedString(s_, buf_); });
}
void writeProbablyBackQuotedStringMySQL(StringRef s, WriteBuffer & buf)
{
writeProbablyQuotedStringImpl(s, buf, [](StringRef s_, WriteBuffer & buf_) { return writeBackQuotedStringMySQL(s_, buf_); });
}
2020-11-09 19:07:38 +00:00
void writePointerHex(const void * ptr, WriteBuffer & buf)
{
writeString("0x", buf);
char hex_str[2 * sizeof(ptr)];
writeHexUIntLowercase(reinterpret_cast<uintptr_t>(ptr), hex_str);
buf.write(hex_str, 2 * sizeof(ptr));
}
2010-06-04 18:25:25 +00:00
}