diff --git a/lldb/include/lldb/Core/Debugger.h b/lldb/include/lldb/Core/Debugger.h --- a/lldb/include/lldb/Core/Debugger.h +++ b/lldb/include/lldb/Core/Debugger.h @@ -345,6 +345,10 @@ llvm::StringRef GetStopShowColumnAnsiSuffix() const; + llvm::StringRef GetShowProgressPrefix() const; + + llvm::StringRef GetShowProgressSuffix() const; + uint32_t GetStopSourceLineCount(bool before) const; StopDisassemblyType GetStopDisassemblyDisplay() const; diff --git a/lldb/source/Core/CoreProperties.td b/lldb/source/Core/CoreProperties.td --- a/lldb/source/Core/CoreProperties.td +++ b/lldb/source/Core/CoreProperties.td @@ -135,6 +135,14 @@ Global, DefaultTrue, Desc<"Whether to show progress or not.">; + def ShowProgressPrefix: Property<"show-progress-prefix", "String">, + Global, + DefaultStringValue<"${ansi.faint}">, + Desc<"When displaying progress a color-enabled (i.e. ANSI) terminal, use the ANSI terminal code specified in this format immediately after the column to be marked.">; + def ShowProgressSuffix: Property<"show-progress-suffix", "String">, + Global, + DefaultStringValue<"${ansi.normal}">, + Desc<"When displaying progress a color-enabled (i.e. ANSI) terminal, use the ANSI terminal code specified in this format immediately after the line to be marked.">; def UseSourceCache: Property<"use-source-cache", "Boolean">, Global, DefaultTrue, diff --git a/lldb/source/Core/Debugger.cpp b/lldb/source/Core/Debugger.cpp --- a/lldb/source/Core/Debugger.cpp +++ b/lldb/source/Core/Debugger.cpp @@ -436,6 +436,16 @@ return m_collection_sp->GetPropertyAtIndexAsString(nullptr, idx, ""); } +llvm::StringRef Debugger::GetShowProgressPrefix() const { + const uint32_t idx = ePropertyShowProgressPrefix; + return m_collection_sp->GetPropertyAtIndexAsString(nullptr, idx, ""); +} + +llvm::StringRef Debugger::GetShowProgressSuffix() const { + const uint32_t idx = ePropertyShowProgressSuffix; + return m_collection_sp->GetPropertyAtIndexAsString(nullptr, idx, ""); +} + uint32_t Debugger::GetStopSourceLineCount(bool before) const { const uint32_t idx = before ? ePropertyStopLineCountBefore : ePropertyStopLineCountAfter; @@ -1769,6 +1779,12 @@ return; } + const bool use_color = GetUseColor(); + llvm::StringRef prefix = GetShowProgressPrefix(); + if (!prefix.empty()) + output.Printf("%s", + ansi::FormatAnsiTerminalCodes(prefix, use_color).c_str()); + // Print over previous line, if any. output.Printf("\r"); @@ -1781,6 +1797,11 @@ output.Printf("%s...", message.c_str()); } + llvm::StringRef suffix = GetShowProgressSuffix(); + if (!suffix.empty()) + output.Printf("%s", + ansi::FormatAnsiTerminalCodes(suffix, use_color).c_str()); + // Clear until the end of the line. output.Printf("\x1B[K");