ClickHouse/dbms/include/DB/DataStreams/IRowOutputStream.h
2013-05-04 04:05:15 +00:00

40 lines
1.5 KiB
C++

#pragma once
#include <boost/noncopyable.hpp>
#include <DB/Core/Row.h>
namespace DB
{
/** Интерфейс потока для записи данных по строкам (например, для вывода в консоль).
*/
class IRowOutputStream : private boost::noncopyable
{
public:
/** Записать строку.
* Есть реализация по умолчанию, которая использует методы для записи одиночных значений и разделителей
* (кроме разделителя между строк (writeRowBetweenDelimiter())).
*/
virtual void write(const Row & row);
/** Записать значение. */
virtual void writeField(const Field & field) = 0;
/** Записать разделитель. */
virtual void writeFieldDelimiter() {}; /// разделитель между значениями
virtual void writeRowStartDelimiter() {}; /// разделитель перед каждой строкой
virtual void writeRowEndDelimiter() {}; /// разделитель после каждой строки
virtual void writeRowBetweenDelimiter() {}; /// разделитель между строками
virtual void writePrefix() {}; /// разделитель перед началом результата
virtual void writeSuffix() {}; /// разделитель после конца результата
virtual ~IRowOutputStream() {}
};
typedef SharedPtr<IRowOutputStream> RowOutputStreamPtr;
}