blob: a650398724fea251298da72c66cc8d6d1eeec060 [file] [log] [blame]
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001//===-- CommandObjectQuit.cpp -----------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "CommandObjectQuit.h"
11
12// C Includes
13// C++ Includes
14// Other libraries and framework includes
15// Project includes
Eli Friedman59817b12010-06-09 07:57:51 +000016#include "lldb/Interpreter/CommandInterpreter.h"
17#include "lldb/Interpreter/CommandReturnObject.h"
Zachary Turnera78bd7f2015-03-03 23:11:11 +000018#include "lldb/Target/Process.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000019
20using namespace lldb;
21using namespace lldb_private;
22
23//-------------------------------------------------------------------------
24// CommandObjectQuit
25//-------------------------------------------------------------------------
26
Kate Stone7428a182016-07-14 22:03:10 +000027CommandObjectQuit::CommandObjectQuit(CommandInterpreter &interpreter)
28 : CommandObjectParsed(interpreter, "quit", "Quit the LLDB debugger.", "quit")
Chris Lattner30fdc8d2010-06-08 16:52:24 +000029{
30}
31
32CommandObjectQuit::~CommandObjectQuit ()
33{
34}
35
Enrico Granatabcba2b22013-01-17 21:36:19 +000036// returns true if there is at least one alive process
37// is_a_detach will be true if all alive processes will be detached when you quit
38// and false if at least one process will be killed instead
39bool
40CommandObjectQuit::ShouldAskForConfirmation (bool& is_a_detach)
41{
42 if (m_interpreter.GetPromptOnQuit() == false)
43 return false;
44 bool should_prompt = false;
45 is_a_detach = true;
46 for (uint32_t debugger_idx = 0;
47 debugger_idx < Debugger::GetNumDebuggers();
48 debugger_idx++)
49 {
50 DebuggerSP debugger_sp(Debugger::GetDebuggerAtIndex(debugger_idx));
51 if (!debugger_sp)
52 continue;
53 const TargetList& target_list(debugger_sp->GetTargetList());
54 for (uint32_t target_idx = 0;
Saleem Abdulrasool3985c8c2014-04-02 03:51:35 +000055 target_idx < static_cast<uint32_t>(target_list.GetNumTargets());
Enrico Granatabcba2b22013-01-17 21:36:19 +000056 target_idx++)
57 {
58 TargetSP target_sp(target_list.GetTargetAtIndex(target_idx));
59 if (!target_sp)
60 continue;
61 ProcessSP process_sp(target_sp->GetProcessSP());
Jason Molenda408fa332013-05-11 00:52:25 +000062 if (process_sp
63 && process_sp->IsValid()
64 && process_sp->IsAlive()
65 && process_sp->WarnBeforeDetach())
Enrico Granatabcba2b22013-01-17 21:36:19 +000066 {
67 should_prompt = true;
68 if (process_sp->GetShouldDetach() == false)
69 {
70 // if we need to kill at least one process, just say so and return
71 is_a_detach = false;
72 return should_prompt;
73 }
74 }
75 }
76 }
77 return should_prompt;
78}
79
Chris Lattner30fdc8d2010-06-08 16:52:24 +000080bool
Jim Ingham5a988412012-06-08 21:56:10 +000081CommandObjectQuit::DoExecute (Args& command, CommandReturnObject &result)
Chris Lattner30fdc8d2010-06-08 16:52:24 +000082{
Enrico Granatabcba2b22013-01-17 21:36:19 +000083 bool is_a_detach = true;
84 if (ShouldAskForConfirmation (is_a_detach))
85 {
86 StreamString message;
87 message.Printf("Quitting LLDB will %s one or more processes. Do you really want to proceed", (is_a_detach ? "detach from" : "kill"));
88 if (!m_interpreter.Confirm(message.GetData(), true))
89 {
90 result.SetStatus(eReturnStatusFailed);
91 return false;
92 }
93 }
Greg Clayton44d93782014-01-27 23:43:24 +000094 const uint32_t event_type = CommandInterpreter::eBroadcastBitQuitCommandReceived;
95 m_interpreter.BroadcastEvent (event_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +000096 result.SetStatus (eReturnStatusQuit);
97 return true;
98}
99