#include "ICommand.h" #include #include #include #include #include namespace DB { namespace ErrorCodes { extern const int BAD_ARGUMENTS; } class CommandWrite final : public ICommand { public: CommandWrite() { command_name = "write"; command_option_description.emplace(createOptionsDescription("Allowed options", getTerminalWidth())); description = "Write File `from_path` or stdin to `to_path`"; usage = "write [OPTION]... \nor\nstdin | write [OPTION]... \nPath should be in format './' or './path' or 'path'"; command_option_description->add_options() ("input", po::value(), "set path to file to which we are write") ; } void processOptions( Poco::Util::LayeredConfiguration & config, po::variables_map & options) const override { if (options.count("input")) config.setString("input", options["input"].as()); } void execute( const std::vector & command_arguments, DB::ContextMutablePtr & global_context, Poco::Util::LayeredConfiguration & config) override { if (command_arguments.size() != 1) { printHelpMessage(); throw DB::Exception(DB::ErrorCodes::BAD_ARGUMENTS, "Bad Arguments"); } String disk_name = config.getString("disk", "default"); const String & path = command_arguments[0]; DiskPtr disk = global_context->getDisk(disk_name); String relative_path = validatePathAndGetAsRelative(path); String path_input = config.getString("input", ""); std::unique_ptr in; if (path_input.empty()) { in = std::make_unique(STDIN_FILENO); } else { String relative_path_input = validatePathAndGetAsRelative(path_input); in = disk->readFile(relative_path_input); } auto out = disk->writeFile(relative_path); copyData(*in, *out); out->finalize(); } }; } std::unique_ptr makeCommandWrite() { return std::make_unique(); }