
This is currently being done in an ad hoc way, and so for some commands it isn't being checked. We have the info to make this check, since commands are supposed to add their arguments to the m_arguments field of the CommandObject. This change uses that info to check whether the command received arguments in error. A handful of commands weren't defining their argument types, I also had to fix them. And a bunch of commands were checking for arguments by hand, so I removed those checks in favor of the CommandObject one. That also meant I had to change some tests that were checking for the ad hoc error outputs. Differential Revision: https://reviews.llvm.org/D128453
48 lines
1.6 KiB
C++
48 lines
1.6 KiB
C++
//===-- CommandObjectGUI.cpp ----------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "CommandObjectGUI.h"
|
|
|
|
#include "lldb/Core/IOHandlerCursesGUI.h"
|
|
#include "lldb/Host/Config.h"
|
|
#include "lldb/Interpreter/CommandInterpreter.h"
|
|
#include "lldb/Interpreter/CommandReturnObject.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
// CommandObjectGUI
|
|
|
|
CommandObjectGUI::CommandObjectGUI(CommandInterpreter &interpreter)
|
|
: CommandObjectParsed(interpreter, "gui",
|
|
"Switch into the curses based GUI mode.", "gui") {}
|
|
|
|
CommandObjectGUI::~CommandObjectGUI() = default;
|
|
|
|
bool CommandObjectGUI::DoExecute(Args &args, CommandReturnObject &result) {
|
|
#if LLDB_ENABLE_CURSES
|
|
Debugger &debugger = GetDebugger();
|
|
|
|
File &input = debugger.GetInputFile();
|
|
File &output = debugger.GetOutputFile();
|
|
if (input.GetStream() && output.GetStream() && input.GetIsRealTerminal() &&
|
|
input.GetIsInteractive()) {
|
|
IOHandlerSP io_handler_sp(new IOHandlerCursesGUI(debugger));
|
|
if (io_handler_sp)
|
|
debugger.RunIOHandlerAsync(io_handler_sp);
|
|
result.SetStatus(eReturnStatusSuccessFinishResult);
|
|
} else {
|
|
result.AppendError("the gui command requires an interactive terminal.");
|
|
}
|
|
return true;
|
|
#else
|
|
result.AppendError("lldb was not built with gui support");
|
|
return false;
|
|
#endif
|
|
}
|