From 1984139672f64bf1fbcabc19ed3e248f6c5ca06a Mon Sep 17 00:00:00 2001 From: Ted Woodward Date: Thu, 24 Mar 2016 20:35:03 +0000 Subject: Fix for missing prompt on Windows Summary: On Windows (and possibly other hosts with LLDB_DISABLE_LIBEDIT defined), the (lldb) prompt won't print after async output, like from a breakpoint hit or a step. This patch forces the prompt to be printed out after async output. Reviewers: zturner, clayborg Subscribers: amccarth, lldb-commits Differential Revision: http://reviews.llvm.org/D18335 --- lldb/source/Core/IOHandler.cpp | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'lldb/source/Core/IOHandler.cpp') diff --git a/lldb/source/Core/IOHandler.cpp b/lldb/source/Core/IOHandler.cpp index 130fa02f92d..a73fce8aa45 100644 --- a/lldb/source/Core/IOHandler.cpp +++ b/lldb/source/Core/IOHandler.cpp @@ -47,6 +47,10 @@ #include "lldb/Target/StackFrame.h" #endif +#ifdef _MSC_VER +#include +#endif + using namespace lldb; using namespace lldb_private; @@ -772,8 +776,27 @@ IOHandlerEditline::PrintAsync (Stream *stream, const char *s, size_t len) if (m_editline_ap) m_editline_ap->PrintAsync(stream, s, len); else +#endif + { + const char *prompt = GetPrompt(); +#ifdef _MSC_VER + if (prompt) + { + // Back up over previous prompt using Windows API + CONSOLE_SCREEN_BUFFER_INFO screen_buffer_info; + HANDLE console_handle = GetStdHandle(STD_OUTPUT_HANDLE); + GetConsoleScreenBufferInfo(console_handle, &screen_buffer_info); + COORD coord = screen_buffer_info.dwCursorPosition; + coord.X -= strlen(prompt); + if (coord.X < 0) + coord.X = 0; + SetConsoleCursorPosition(console_handle, coord); + } #endif IOHandler::PrintAsync(stream, s, len); + if (prompt) + IOHandler::PrintAsync(GetOutputStreamFile().get(), prompt, strlen(prompt)); + } } // we may want curses to be disabled for some builds -- cgit v1.2.3