Merge topic 'ccmake_incremental_log_display' into release-3.17

60bfaa8fe6 ccmake: Use incremental rendering for the logs
e9b36731e9 cmCursesLongMessageForm: Factor out helper to draw message to form

Acked-by: Kitware Robot <kwrobot@kitware.com>
Acked-by: Robert Maynard <robert.maynard@kitware.com>
Merge-request: !4573
This commit is contained in:
Brad King
2020-04-09 12:10:52 +00:00
committed by Kitware Robot
4 changed files with 48 additions and 19 deletions
@@ -35,6 +35,22 @@ cmCursesLongMessageForm::~cmCursesLongMessageForm()
}
}
void cmCursesLongMessageForm::UpdateContent(std::string const& output,
std::string const& title)
{
this->Title = title;
if (!output.empty() && this->Messages.size() < MAX_CONTENT_SIZE) {
this->Messages.append("\n" + output);
form_driver(this->Form, REQ_NEW_LINE);
this->DrawMessage(output.c_str());
}
this->UpdateStatusBar();
touchwin(stdscr);
refresh();
}
void cmCursesLongMessageForm::UpdateStatusBar()
{
int x;
@@ -109,8 +125,6 @@ void cmCursesLongMessageForm::Render(int /*left*/, int /*top*/, int /*width*/,
this->Form = nullptr;
}
const char* msg = this->Messages.c_str();
if (this->Fields[0]) {
free_field(this->Fields[0]);
this->Fields[0] = nullptr;
@@ -123,9 +137,18 @@ void cmCursesLongMessageForm::Render(int /*left*/, int /*top*/, int /*width*/,
this->Form = new_form(this->Fields);
post_form(this->Form);
int i = 0;
form_driver(this->Form, REQ_BEG_FIELD);
while (msg[i] != '\0' && i < 60000) {
this->DrawMessage(this->Messages.c_str());
this->UpdateStatusBar();
touchwin(stdscr);
refresh();
}
void cmCursesLongMessageForm::DrawMessage(const char* msg) const
{
int i = 0;
while (msg[i] != '\0' && i < MAX_CONTENT_SIZE) {
if (msg[i] == '\n' && msg[i + 1] != '\0') {
form_driver(this->Form, REQ_NEW_LINE);
} else {
@@ -138,10 +161,6 @@ void cmCursesLongMessageForm::Render(int /*left*/, int /*top*/, int /*width*/,
} else {
form_driver(this->Form, REQ_BEG_FIELD);
}
this->UpdateStatusBar();
touchwin(stdscr);
refresh();
}
void cmCursesLongMessageForm::HandleInput()
@@ -27,6 +27,8 @@ public:
cmCursesLongMessageForm(cmCursesLongMessageForm const&) = delete;
cmCursesLongMessageForm& operator=(cmCursesLongMessageForm const&) = delete;
void UpdateContent(std::string const& output, std::string const& title);
// Description:
// Handle user input.
void HandleInput() override;
@@ -47,6 +49,10 @@ public:
void UpdateStatusBar() override;
protected:
static constexpr int MAX_CONTENT_SIZE = 60000;
void DrawMessage(const char* msg) const;
std::string Messages;
std::string Title;
ScrollBehavior Scrolling;
+14 -10
View File
@@ -453,11 +453,11 @@ void cmCursesMainForm::UpdateProgress(const std::string& msg, float prog)
this->LastProgress.append(progressBarCompleted, '#');
this->LastProgress.append(progressBarWidth - progressBarCompleted, ' ');
this->LastProgress += "] " + msg + "...";
this->DisplayOutputs(std::string());
} else {
this->Outputs.emplace_back(msg);
this->DisplayOutputs(msg);
}
this->DisplayOutputs();
}
int cmCursesMainForm::Configure(int noconfigure)
@@ -589,7 +589,7 @@ void cmCursesMainForm::AddError(const std::string& message,
{
this->Outputs.emplace_back(message);
this->HasNonStatusOutputs = true;
this->DisplayOutputs();
this->DisplayOutputs(message);
}
void cmCursesMainForm::RemoveEntry(const char* value)
@@ -995,18 +995,22 @@ void cmCursesMainForm::ResetOutputs()
this->LastProgress.clear();
}
void cmCursesMainForm::DisplayOutputs()
void cmCursesMainForm::DisplayOutputs(std::string const& newOutput)
{
int xi;
int yi;
getmaxyx(stdscr, yi, xi);
auto newLogForm = new cmCursesLongMessageForm(
this->Outputs, this->LastProgress.c_str(),
cmCursesLongMessageForm::ScrollBehavior::ScrollDown);
CurrentForm = newLogForm;
this->LogForm.reset(newLogForm);
this->LogForm->Render(1, 1, xi, yi);
if (CurrentForm != this->LogForm.get()) {
auto newLogForm = new cmCursesLongMessageForm(
this->Outputs, this->LastProgress.c_str(),
cmCursesLongMessageForm::ScrollBehavior::ScrollDown);
CurrentForm = newLogForm;
this->LogForm.reset(newLogForm);
this->LogForm->Render(1, 1, xi, yi);
} else {
this->LogForm->UpdateContent(newOutput, this->LastProgress);
}
}
const char* cmCursesMainForm::s_ConstHelpMessage =
+1 -1
View File
@@ -129,7 +129,7 @@ protected:
void ResetOutputs();
// Display the current progress and output
void DisplayOutputs();
void DisplayOutputs(std::string const& newOutput);
// Copies of cache entries stored in the user interface
std::vector<cmCursesCacheEntryComposite> Entries;