ClickHouse/programs/disks/CommandRead.cpp

80 lines
2.3 KiB
C++
Raw Normal View History

#include "ICommand.h"
2022-07-20 20:30:16 +00:00
#include <Interpreters/Context.h>
#include <IO/ReadBufferFromFile.h>
#include <IO/WriteBufferFromFile.h>
#include <IO/copyData.h>
2022-12-08 17:53:05 +00:00
#include <Common/TerminalSize.h>
namespace DB
{
namespace ErrorCodes
{
extern const int BAD_ARGUMENTS;
}
class CommandRead final : public ICommand
{
public:
CommandRead()
{
command_name = "read";
2022-06-16 17:38:33 +00:00
command_option_description.emplace(createOptionsDescription("Allowed options", getTerminalWidth()));
2023-08-29 12:25:04 +00:00
description = "Read a file from `FROM_PATH` to `TO_PATH`";
usage = "read [OPTION]... <FROM_PATH> [<TO_PATH>]";
command_option_description->add_options()
2023-08-29 12:25:04 +00:00
("output", po::value<String>(), "file to which we are reading, defaults to `stdout`");
}
void processOptions(
Poco::Util::LayeredConfiguration & config,
po::variables_map & options) const override
{
if (options.count("output"))
config.setString("output", options["output"].as<String>());
}
2022-06-16 17:38:33 +00:00
void execute(
const std::vector<String> & command_arguments,
DB::ContextMutablePtr & global_context,
Poco::Util::LayeredConfiguration & config) override
{
2022-06-16 17:38:33 +00:00
if (command_arguments.size() != 1)
{
printHelpMessage();
throw DB::Exception(DB::ErrorCodes::BAD_ARGUMENTS, "Bad Arguments");
}
String disk_name = config.getString("disk", "default");
DiskPtr disk = global_context->getDisk(disk_name);
2022-12-08 17:43:54 +00:00
String relative_path = validatePathAndGetAsRelative(command_arguments[0]);
2022-06-02 18:24:13 +00:00
String path_output = config.getString("output", "");
2022-06-02 18:24:13 +00:00
if (!path_output.empty())
{
2022-12-08 17:43:54 +00:00
String relative_path_output = validatePathAndGetAsRelative(path_output);
2022-06-02 17:58:58 +00:00
2022-12-08 17:43:54 +00:00
auto in = disk->readFile(relative_path);
auto out = disk->writeFile(relative_path_output);
2022-06-02 17:58:58 +00:00
copyData(*in, *out);
out->finalize();
return;
}
else
{
2022-12-08 17:43:54 +00:00
auto in = disk->readFile(relative_path);
2022-06-02 17:58:58 +00:00
std::unique_ptr<WriteBufferFromFileBase> out = std::make_unique<WriteBufferFromFileDescriptor>(STDOUT_FILENO);
copyData(*in, *out);
}
}
};
}
std::unique_ptr <DB::ICommand> makeCommandRead()
{
return std::make_unique<DB::CommandRead>();
}