ClickHouse/dbms/src/DataStreams/PrettyBlockOutputStream.h

56 lines
1.4 KiB
C++
Raw Normal View History

2011-11-07 01:15:37 +00:00
#pragma once
#include <Core/Block.h>
#include <DataStreams/IBlockOutputStream.h>
#include <DataTypes/FormatSettings.h>
2011-11-07 01:15:37 +00:00
namespace DB
{
2016-08-13 01:57:35 +00:00
class WriteBuffer;
class Context;
2016-08-13 01:57:35 +00:00
2017-05-13 22:19:04 +00:00
/** Prints the result in the form of beautiful tables.
2011-11-07 01:15:37 +00:00
*/
class PrettyBlockOutputStream : public IBlockOutputStream
{
public:
2017-05-13 22:19:04 +00:00
/// no_escapes - do not use ANSI escape sequences - to display in the browser, not in the console.
PrettyBlockOutputStream(WriteBuffer & ostr_, const Block & header_, const FormatSettings & format_settings);
2011-11-07 01:15:37 +00:00
Block getHeader() const override { return header; }
void write(const Block & block) override;
void writeSuffix() override;
void flush() override;
void setTotals(const Block & totals_) override { totals = totals_; }
void setExtremes(const Block & extremes_) override { extremes = extremes_; }
2011-11-28 04:05:53 +00:00
protected:
void writeTotals();
void writeExtremes();
WriteBuffer & ostr;
const Block header;
size_t total_rows = 0;
size_t terminal_width = 0;
2012-06-25 05:07:34 +00:00
const FormatSettings format_settings;
Block totals;
Block extremes;
using Widths = PODArray<size_t>;
using WidthsPerColumn = std::vector<Widths>;
static void calculateWidths(
const Block & block, WidthsPerColumn & widths, Widths & max_widths, Widths & name_widths, const FormatSettings & format_settings);
void writeValueWithPadding(const ColumnWithTypeAndName & elem, size_t row_num, size_t value_width, size_t pad_to_width);
2011-11-07 01:15:37 +00:00
};
}