ClickHouse/dbms/include/DB/DataStreams/IRowOutputStream.h

50 lines
2.0 KiB
C
Raw Normal View History

2011-10-24 12:10:59 +00:00
#pragma once
2010-03-04 19:20:28 +00:00
#include <boost/noncopyable.hpp>
2010-03-04 19:20:28 +00:00
#include <DB/Core/Row.h>
#include <DB/Core/Block.h>
2010-03-04 19:20:28 +00:00
namespace DB
{
/** Интерфейс потока для записи данных по строкам (например, для вывода в консоль).
*/
class IRowOutputStream : private boost::noncopyable
2010-03-04 19:20:28 +00:00
{
public:
/** Записать строку.
2011-10-30 05:19:41 +00:00
* Есть реализация по умолчанию, которая использует методы для записи одиночных значений и разделителей
* (кроме разделителя между строк (writeRowBetweenDelimiter())).
2010-03-04 19:20:28 +00:00
*/
virtual void write(const Row & row);
/** Записать значение. */
virtual void writeField(const Field & field) = 0;
/** Записать разделитель. */
2011-10-31 06:37:12 +00:00
virtual void writeFieldDelimiter() {}; /// разделитель между значениями
virtual void writeRowStartDelimiter() {}; /// разделитель перед каждой строкой
virtual void writeRowEndDelimiter() {}; /// разделитель после каждой строки
virtual void writeRowBetweenDelimiter() {}; /// разделитель между строками
virtual void writePrefix() {}; /// разделитель перед началом результата
virtual void writeSuffix() {}; /// разделитель после конца результата
2010-03-04 19:20:28 +00:00
/** Сбросить имеющиеся буферы для записи. */
virtual void flush() {}
/** Методы для установки дополнительной информации для вывода в поддерживающих её форматах.
*/
virtual void setRowsBeforeLimit(size_t rows_before_limit) {}
virtual void setTotals(const Block & totals) {}
virtual void setExtremes(const Block & extremes) {}
2010-03-04 19:20:28 +00:00
virtual ~IRowOutputStream() {}
};
2011-10-24 12:10:59 +00:00
typedef SharedPtr<IRowOutputStream> RowOutputStreamPtr;
2010-03-04 19:20:28 +00:00
2011-10-24 12:10:59 +00:00
}