From e34ac3047a5aed3b55b7b1eff788137325ec5832 Mon Sep 17 00:00:00 2001 From: Jochen Topf Date: Tue, 5 Nov 2024 21:52:08 +0100 Subject: [PATCH] Fix reading from STDIN for sort command Reading from STDIN did not work. See #278. This also fixes another problem when using the multipass strategy: In that case reading from STDIN is not allowed and we now check for that. --- src/command_sort.cpp | 24 ++++++++++++++---------- src/command_sort.hpp | 1 - 2 files changed, 14 insertions(+), 11 deletions(-) diff --git a/src/command_sort.cpp b/src/command_sort.cpp index 2ddfd1e6..135bf2f8 100644 --- a/src/command_sort.cpp +++ b/src/command_sort.cpp @@ -76,10 +76,6 @@ bool CommandSort::setup(const std::vector& arguments) { setup_input_files(vm); setup_output_file(vm); - if (vm.count("input-filenames")) { - m_filenames = vm["input-filenames"].as>(); - } - if (vm.count("strategy")) { m_strategy = vm["strategy"].as(); if (m_strategy != "simple" && m_strategy != "multipass") { @@ -87,6 +83,14 @@ bool CommandSort::setup(const std::vector& arguments) { } } + if (m_strategy == "multipass") { + if (std::any_of(m_input_filenames.cbegin(), m_input_filenames.cend(), [&](const std::string& name) { + return name == "-"; + })) { + throw argument_error{"Can not read from STDIN when using multipass strategy"}; + } + } + return true; } @@ -110,8 +114,8 @@ bool CommandSort::run_single_pass() { m_vout << "Reading contents of input files...\n"; osmium::ProgressBar progress_bar{file_size_sum(m_input_files), display_progress()}; - for (const std::string& file_name : m_filenames) { - osmium::io::Reader reader{file_name, osmium::osm_entity_bits::object}; + for (const auto& file : m_input_files) { + osmium::io::Reader reader{file, osmium::osm_entity_bits::object}; const osmium::io::Header header{reader.header()}; bounding_box.extend(header.joined_boxes()); while (osmium::memory::Buffer buffer = reader.read()) { @@ -167,8 +171,8 @@ bool CommandSort::run_multi_pass() { osmium::Box bounding_box; m_vout << "Reading input file headers...\n"; - for (const std::string& file_name : m_filenames) { - osmium::io::Reader reader{file_name, osmium::osm_entity_bits::nothing}; + for (const auto& file : m_input_files) { + osmium::io::Reader reader{file, osmium::osm_entity_bits::nothing}; const osmium::io::Header header{reader.header()}; bounding_box.extend(header.joined_boxes()); reader.close(); @@ -196,8 +200,8 @@ bool CommandSort::run_multi_pass() { m_vout << "Pass " << pass++ << "...\n"; m_vout << "Reading contents of input files...\n"; - for (const std::string& file_name : m_filenames) { - osmium::io::Reader reader{file_name, entity}; + for (const auto& file : m_input_files) { + osmium::io::Reader reader{file, entity}; const osmium::io::Header read_header{reader.header()}; bounding_box.extend(read_header.joined_boxes()); while (osmium::memory::Buffer buffer = reader.read()) { diff --git a/src/command_sort.hpp b/src/command_sort.hpp index 9e12dbb8..3d050147 100644 --- a/src/command_sort.hpp +++ b/src/command_sort.hpp @@ -30,7 +30,6 @@ along with this program. If not, see . class CommandSort : public CommandWithMultipleOSMInputs, public with_osm_output { - std::vector m_filenames; std::string m_strategy{"simple"}; public: