ClickHouse/dbms/src/DataStreams/VerticalRowOutputStream.cpp

74 lines
1.6 KiB
C++
Raw Normal View History

2011-11-28 04:05:53 +00:00
#include <DB/Functions/FunctionsMiscellaneous.h>
#include <DB/IO/WriteHelpers.h>
#include <DB/DataStreams/VerticalRowOutputStream.h>
namespace DB
{
using Poco::SharedPtr;
VerticalRowOutputStream::VerticalRowOutputStream(WriteBuffer & ostr_, const Block & sample_)
: ostr(ostr_), sample(sample_), field_number(0), row_number(0)
{
size_t columns = sample.columns();
data_types.resize(columns);
names.resize(columns);
typedef std::vector<size_t> Widths_t;
Widths_t name_widths(columns);
size_t max_name_width = 0;
2011-11-28 04:05:53 +00:00
for (size_t i = 0; i < columns; ++i)
{
data_types[i] = sample.getByPosition(i).type;
names[i] = sample.getByPosition(i).name;
stringWidthConstant(names[i], name_widths[i]);
if (name_widths[i] > max_name_width)
max_name_width = name_widths[i];
}
pads.resize(columns);
for (size_t i = 0; i < columns; ++i)
pads[i] = String(max_name_width - name_widths[i], ' ');
}
void VerticalRowOutputStream::writeField(const Field & field)
{
writeEscapedString(names[field_number], ostr);
writeCString(": ", ostr);
2011-11-28 04:05:53 +00:00
writeString(pads[field_number], ostr);
2011-11-28 04:05:53 +00:00
data_types[field_number]->serializeTextEscaped(field, ostr);
writeChar('\n', ostr);
++field_number;
}
void VerticalRowOutputStream::writeRowStartDelimiter()
{
++row_number;
writeCString("Row ", ostr);
2011-11-28 04:05:53 +00:00
writeIntText(row_number, ostr);
writeCString(":\n", ostr);
2011-11-28 04:05:53 +00:00
size_t width = log10(row_number + 1) + 1 + strlen("Row :");
for (size_t i = 0; i < width; ++i)
writeCString("", ostr);
2011-11-28 04:05:53 +00:00
writeChar('\n', ostr);
}
void VerticalRowOutputStream::writeRowBetweenDelimiter()
{
writeCString("\n", ostr);
2011-11-28 04:05:53 +00:00
field_number = 0;
}
}