From 8cb022d5aa519dbbbd7ab790076e01750a6ead36 Mon Sep 17 00:00:00 2001 From: Marek Blaha Date: Fri, 8 Dec 2023 12:17:55 +0100 Subject: [PATCH] cli: Progress bars miss newlines on non-interactive output Resolves: https://github.com/rpm-software-management/dnf5/issues/1058 --- libdnf5-cli/progressbar/multi_progress_bar.cpp | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/libdnf5-cli/progressbar/multi_progress_bar.cpp b/libdnf5-cli/progressbar/multi_progress_bar.cpp index f1d0e8bbc..f13e41712 100644 --- a/libdnf5-cli/progressbar/multi_progress_bar.cpp +++ b/libdnf5-cli/progressbar/multi_progress_bar.cpp @@ -98,16 +98,14 @@ std::size_t MultiProgressBar::get_total_num_of_bars() const noexcept { std::ostream & operator<<(std::ostream & stream, MultiProgressBar & mbar) { const bool is_interactive{tty::is_interactive()}; - if (is_interactive) { - if (mbar.num_of_lines_to_clear > 0) { - stream << tty::clear_line; - for (std::size_t i = 1; i < mbar.num_of_lines_to_clear; i++) { - stream << tty::cursor_up << tty::clear_line; - } - stream << "\r"; - } else if (mbar.line_printed) { - stream << std::endl; + if (is_interactive && mbar.num_of_lines_to_clear > 0) { + stream << tty::clear_line; + for (std::size_t i = 1; i < mbar.num_of_lines_to_clear; i++) { + stream << tty::cursor_up << tty::clear_line; } + stream << "\r"; + } else if (mbar.line_printed) { + stream << std::endl; } mbar.num_of_lines_to_clear = 0; mbar.line_printed = false;