#pragma once #include #include #include namespace DB { class Context; class ASTCreateQuery; class ASTStorage; /** Allows to create a table by the name and parameters of the engine. * In 'columns' Nested data structures must be flattened. * You should subsequently call IStorage::startup method to work with table. */ class StorageFactory : public ext::singleton { public: struct Arguments { const String & engine_name; ASTs & engine_args; ASTStorage * storage_def; const ASTCreateQuery & query; const String & data_path; const String & table_name; const String & database_name; Context & local_context; Context & context; const ColumnsDescription & columns; bool attach; bool has_force_restore_data_flag; }; using Creator = std::function; StoragePtr get( ASTCreateQuery & query, const String & data_path, const String & table_name, const String & database_name, Context & local_context, Context & context, const ColumnsDescription & columns, bool attach, bool has_force_restore_data_flag) const; /// Register a table engine by its name. /// No locking, you must register all engines before usage of get. void registerStorage(const std::string & name, Creator creator); private: using Storages = std::unordered_map; Storages storages; }; }