mirror of
https://github.com/intel/llvm.git
synced 2026-01-14 03:50:17 +08:00
Summary: This patch removes File::SetStream() and File::SetDescriptor(), and replaces most direct uses of File with pointers to File. Instead of calling SetStream() on a file, we make a new file and replace it. My ultimate goal here is to introduce a new API class SBFile, which has full support for python io.IOStream file objects. These can redirect read() and write() to python code, so lldb::Files will need a way to dispatch those methods. Additionally it will need some form of sharing and assigning files, as a SBFile will be passed in and assigned to the main IO streams of the debugger. In my prototype patch queue, I make File itself copyable and add a secondary class FileOps to manage the sharing and dispatch. In that case SBFile was a unique_ptr<File>. (here: https://github.com/smoofra/llvm-project/tree/files) However in review, Pavel Labath suggested that it be shared_ptr instead. (here: https://reviews.llvm.org/D67793) In order for SBFile to use shared_ptr<File>, everything else should as well. If this patch is accepted, I will make SBFile use a shared_ptr I will remove FileOps from future patches and use subclasses of File instead. Reviewers: JDevlieghere, jasonmolenda, zturner, jingham, labath Reviewed By: labath Subscribers: lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D67891 llvm-svn: 373090
51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
//===-- CommandObjectGUI.cpp ------------------------------------*- C++ -*-===//
|
|
//
|
|
// 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/Interpreter/CommandInterpreter.h"
|
|
#include "lldb/Interpreter/CommandReturnObject.h"
|
|
#include "lldb/lldb-private.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() {}
|
|
|
|
bool CommandObjectGUI::DoExecute(Args &args, CommandReturnObject &result) {
|
|
#ifndef LLDB_DISABLE_CURSES
|
|
if (args.GetArgumentCount() == 0) {
|
|
Debugger &debugger = GetDebugger();
|
|
|
|
File &input = debugger.GetInputFile();
|
|
if (input.GetIsRealTerminal() && input.GetIsInteractive()) {
|
|
IOHandlerSP io_handler_sp(new IOHandlerCursesGUI(debugger));
|
|
if (io_handler_sp)
|
|
debugger.PushIOHandler(io_handler_sp);
|
|
result.SetStatus(eReturnStatusSuccessFinishResult);
|
|
} else {
|
|
result.AppendError("the gui command requires an interactive terminal.");
|
|
result.SetStatus(eReturnStatusFailed);
|
|
}
|
|
} else {
|
|
result.AppendError("the gui command takes no arguments.");
|
|
result.SetStatus(eReturnStatusFailed);
|
|
}
|
|
return true;
|
|
#else
|
|
result.AppendError("lldb was not build with gui support");
|
|
return false;
|
|
#endif
|
|
}
|