ClickHouse/src/Storages/StorageInput.h
Ivan 495c6e03aa
Replace all Context references with std::weak_ptr (#22297)
* Replace all Context references with std::weak_ptr

* Fix shared context captured by value

* Fix build

* Fix Context with named sessions

* Fix copy context

* Fix gcc build

* Merge with master and fix build

* Fix gcc-9 build
2021-04-11 02:33:54 +03:00

36 lines
925 B
C++

#pragma once
#include <Storages/IStorage.h>
#include <ext/shared_ptr_helper.h>
namespace DB
{
/** Internal temporary storage for table function input(...)
*/
class StorageInput final : public ext::shared_ptr_helper<StorageInput>, public IStorage
{
friend struct ext::shared_ptr_helper<StorageInput>;
public:
String getName() const override { return "Input"; }
/// A table will read from this stream.
void setInputStream(BlockInputStreamPtr input_stream_);
Pipe read(
const Names & column_names,
const StorageMetadataPtr & /*metadata_snapshot*/,
SelectQueryInfo & query_info,
ContextPtr context,
QueryProcessingStage::Enum processed_stage,
size_t max_block_size,
unsigned num_streams) override;
private:
BlockInputStreamPtr input_stream;
protected:
StorageInput(const StorageID & table_id, const ColumnsDescription & columns_);
};
}