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

46 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>
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
2011-10-24 12:10:59 +00:00
/** Создать копию объекта.
* Предполагается, что функция вызывается только до использования объекта (сразу после создания, до вызова других методов),
* только для того, чтобы можно было преобразовать параметр, переданный по ссылке в shared ptr.
*/
virtual SharedPtr<IRowOutputStream> clone() = 0;
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
}