blob: 0c30ac9367216f46282e4361808cab0ab572c7a7 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- SBCommandInterpreter.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 "lldb/lldb-types.h"
Jim Ingham84cdc152010-06-15 19:49:27 +000011#include "lldb/Interpreter/Args.h"
Chris Lattner24943d22010-06-08 16:52:24 +000012#include "lldb/Core/SourceManager.h"
13#include "lldb/Core/Listener.h"
14#include "lldb/Interpreter/CommandInterpreter.h"
15#include "lldb/Interpreter/CommandReturnObject.h"
16#include "lldb/Target/Target.h"
17
Eli Friedmand6ec8aa2010-06-09 07:37:52 +000018#include "lldb/API/SBBroadcaster.h"
19#include "lldb/API/SBDebugger.h"
20#include "lldb/API/SBCommandReturnObject.h"
Eli Friedmand6ec8aa2010-06-09 07:37:52 +000021#include "lldb/API/SBSourceManager.h"
22#include "lldb/API/SBCommandInterpreter.h"
23#include "lldb/API/SBProcess.h"
24#include "lldb/API/SBTarget.h"
25#include "lldb/API/SBListener.h"
Caroline Tice7826c882010-10-26 03:11:13 +000026#include "lldb/API/SBStream.h"
Eli Friedmand6ec8aa2010-06-09 07:37:52 +000027#include "lldb/API/SBStringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000028
29using namespace lldb;
30using namespace lldb_private;
31
32
Greg Clayton63094e02010-06-23 01:19:29 +000033SBCommandInterpreter::SBCommandInterpreter (CommandInterpreter *interpreter) :
34 m_opaque_ptr (interpreter)
Chris Lattner24943d22010-06-08 16:52:24 +000035{
Caroline Tice61ba7ec2010-10-26 23:49:36 +000036 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +000037
38 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +000039 log->Printf ("SBCommandInterpreter::SBCommandInterpreter (interpreter=%p)"
40 " => SBCommandInterpreter(%p)", interpreter, m_opaque_ptr);
Chris Lattner24943d22010-06-08 16:52:24 +000041}
42
43SBCommandInterpreter::~SBCommandInterpreter ()
44{
45}
46
47bool
Greg Clayton63094e02010-06-23 01:19:29 +000048SBCommandInterpreter::IsValid() const
49{
50 return m_opaque_ptr != NULL;
51}
52
53
54bool
Chris Lattner24943d22010-06-08 16:52:24 +000055SBCommandInterpreter::CommandExists (const char *cmd)
56{
Greg Clayton63094e02010-06-23 01:19:29 +000057 if (m_opaque_ptr)
58 return m_opaque_ptr->CommandExists (cmd);
59 return false;
Chris Lattner24943d22010-06-08 16:52:24 +000060}
61
62bool
63SBCommandInterpreter::AliasExists (const char *cmd)
64{
Greg Clayton63094e02010-06-23 01:19:29 +000065 if (m_opaque_ptr)
66 return m_opaque_ptr->AliasExists (cmd);
67 return false;
Chris Lattner24943d22010-06-08 16:52:24 +000068}
69
Chris Lattner24943d22010-06-08 16:52:24 +000070lldb::ReturnStatus
71SBCommandInterpreter::HandleCommand (const char *command_line, SBCommandReturnObject &result, bool add_to_history)
72{
Caroline Tice7826c882010-10-26 03:11:13 +000073 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
74
75 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +000076 log->Printf ("SBCommandInterpreter(%p)::HandleCommand (command_line='%s', result=%p, add_to_history=%i)",
77 m_opaque_ptr, command_line, &result, add_to_history);
Caroline Tice7826c882010-10-26 03:11:13 +000078
Chris Lattner24943d22010-06-08 16:52:24 +000079 result.Clear();
Greg Clayton63094e02010-06-23 01:19:29 +000080 if (m_opaque_ptr)
81 {
82 m_opaque_ptr->HandleCommand (command_line, add_to_history, result.ref());
83 }
84 else
85 {
86 result->AppendError ("SBCommandInterpreter is not valid");
87 result->SetStatus (eReturnStatusFailed);
88 }
Caroline Tice7826c882010-10-26 03:11:13 +000089
Caroline Tice7de24cc2010-10-27 21:23:37 +000090 // We need to get the value again, in case the command disabled the log!
91 log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +000092 if (log)
93 {
94 SBStream sstr;
95 result.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +000096 log->Printf ("SBCommandInterpreter(%p)::HandleCommand (\"%s\") => SBCommandReturnObject(%p): '%s'",
97 m_opaque_ptr, command_line, result.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +000098 }
99
Chris Lattner24943d22010-06-08 16:52:24 +0000100 return result.GetStatus();
101}
102
103int
104SBCommandInterpreter::HandleCompletion (const char *current_line,
105 const char *cursor,
106 const char *last_char,
107 int match_start_point,
108 int max_return_elements,
109 SBStringList &matches)
110{
Greg Clayton63094e02010-06-23 01:19:29 +0000111 int num_completions = 0;
112 if (m_opaque_ptr)
113 {
114 lldb_private::StringList lldb_matches;
115 num_completions = m_opaque_ptr->HandleCompletion (current_line, cursor, last_char, match_start_point,
116 max_return_elements, lldb_matches);
Chris Lattner24943d22010-06-08 16:52:24 +0000117
Greg Clayton63094e02010-06-23 01:19:29 +0000118 SBStringList temp_list (&lldb_matches);
119 matches.AppendList (temp_list);
120 }
Chris Lattner24943d22010-06-08 16:52:24 +0000121 return num_completions;
122}
123
Chris Lattner24943d22010-06-08 16:52:24 +0000124bool
125SBCommandInterpreter::HasCommands ()
126{
Greg Clayton63094e02010-06-23 01:19:29 +0000127 if (m_opaque_ptr)
128 return m_opaque_ptr->HasCommands();
129 return false;
Chris Lattner24943d22010-06-08 16:52:24 +0000130}
131
132bool
133SBCommandInterpreter::HasAliases ()
134{
Greg Clayton63094e02010-06-23 01:19:29 +0000135 if (m_opaque_ptr)
136 return m_opaque_ptr->HasAliases();
137 return false;
Chris Lattner24943d22010-06-08 16:52:24 +0000138}
139
140bool
Chris Lattner24943d22010-06-08 16:52:24 +0000141SBCommandInterpreter::HasAliasOptions ()
142{
Greg Clayton63094e02010-06-23 01:19:29 +0000143 if (m_opaque_ptr)
144 return m_opaque_ptr->HasAliasOptions ();
145 return false;
Chris Lattner24943d22010-06-08 16:52:24 +0000146}
147
Chris Lattner24943d22010-06-08 16:52:24 +0000148SBProcess
149SBCommandInterpreter::GetProcess ()
150{
151 SBProcess process;
Greg Clayton63094e02010-06-23 01:19:29 +0000152 if (m_opaque_ptr)
Chris Lattner24943d22010-06-08 16:52:24 +0000153 {
Greg Clayton63094e02010-06-23 01:19:29 +0000154 Debugger &debugger = m_opaque_ptr->GetDebugger();
Jim Inghamc8332952010-08-26 21:32:51 +0000155 Target *target = debugger.GetSelectedTarget().get();
Chris Lattner24943d22010-06-08 16:52:24 +0000156 if (target)
157 process.SetProcess(target->GetProcessSP());
158 }
Greg Claytona66ba462010-10-30 04:51:46 +0000159 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
160
161 if (log)
162 log->Printf ("SBCommandInterpreter(%p)::GetProcess () => SBProcess(%p)",
163 m_opaque_ptr, process.get());
164
165
Chris Lattner24943d22010-06-08 16:52:24 +0000166 return process;
167}
168
169ssize_t
170SBCommandInterpreter::WriteToScriptInterpreter (const char *src)
171{
Greg Claytona66ba462010-10-30 04:51:46 +0000172 return WriteToScriptInterpreter (src, strlen(src));
Chris Lattner24943d22010-06-08 16:52:24 +0000173}
174
175ssize_t
176SBCommandInterpreter::WriteToScriptInterpreter (const char *src, size_t src_len)
177{
Greg Claytona66ba462010-10-30 04:51:46 +0000178 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
179
180 ssize_t bytes_written = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000181 if (m_opaque_ptr && src && src[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000182 {
Greg Clayton63094e02010-06-23 01:19:29 +0000183 ScriptInterpreter *script_interpreter = m_opaque_ptr->GetScriptInterpreter();
Chris Lattner24943d22010-06-08 16:52:24 +0000184 if (script_interpreter)
Greg Claytona66ba462010-10-30 04:51:46 +0000185 bytes_written = ::write (script_interpreter->GetMasterFileDescriptor(), src, src_len);
Chris Lattner24943d22010-06-08 16:52:24 +0000186 }
Greg Claytona66ba462010-10-30 04:51:46 +0000187 if (log)
188 log->Printf ("SBCommandInterpreter(%p)::WriteToScriptInterpreter (src=\"%s\", src_len=%zu) => %zi",
189 m_opaque_ptr, src, src_len, bytes_written);
190
191 return bytes_written;
Chris Lattner24943d22010-06-08 16:52:24 +0000192}
193
194
195CommandInterpreter *
Greg Clayton63094e02010-06-23 01:19:29 +0000196SBCommandInterpreter::get ()
Chris Lattner24943d22010-06-08 16:52:24 +0000197{
Greg Clayton63094e02010-06-23 01:19:29 +0000198 return m_opaque_ptr;
Chris Lattner24943d22010-06-08 16:52:24 +0000199}
200
201CommandInterpreter &
Greg Clayton63094e02010-06-23 01:19:29 +0000202SBCommandInterpreter::ref ()
Chris Lattner24943d22010-06-08 16:52:24 +0000203{
Greg Clayton63094e02010-06-23 01:19:29 +0000204 assert (m_opaque_ptr);
205 return *m_opaque_ptr;
206}
207
208void
209SBCommandInterpreter::reset (lldb_private::CommandInterpreter *interpreter)
210{
211 m_opaque_ptr = interpreter;
Chris Lattner24943d22010-06-08 16:52:24 +0000212}
213
214void
215SBCommandInterpreter::SourceInitFileInHomeDirectory (SBCommandReturnObject &result)
216{
217 result.Clear();
Greg Clayton63094e02010-06-23 01:19:29 +0000218 if (m_opaque_ptr)
219 {
220 m_opaque_ptr->SourceInitFile (false, result.ref());
221 }
222 else
223 {
224 result->AppendError ("SBCommandInterpreter is not valid");
225 result->SetStatus (eReturnStatusFailed);
226 }
Greg Claytona66ba462010-10-30 04:51:46 +0000227 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
228
229 if (log)
230 log->Printf ("SBCommandInterpreter(%p)::SourceInitFileInHomeDirectory (&SBCommandReturnObject(%p))",
231 m_opaque_ptr, result.get());
232
Chris Lattner24943d22010-06-08 16:52:24 +0000233}
234
235void
236SBCommandInterpreter::SourceInitFileInCurrentWorkingDirectory (SBCommandReturnObject &result)
237{
238 result.Clear();
Greg Clayton63094e02010-06-23 01:19:29 +0000239 if (m_opaque_ptr)
240 {
241 m_opaque_ptr->SourceInitFile (true, result.ref());
242 }
243 else
244 {
245 result->AppendError ("SBCommandInterpreter is not valid");
246 result->SetStatus (eReturnStatusFailed);
247 }
Greg Claytona66ba462010-10-30 04:51:46 +0000248 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
249
250 if (log)
251 log->Printf ("SBCommandInterpreter(%p)::SourceInitFileInCurrentWorkingDirectory (&SBCommandReturnObject(%p))",
252 m_opaque_ptr, result.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000253}
254
255SBBroadcaster
256SBCommandInterpreter::GetBroadcaster ()
257{
Caroline Tice7826c882010-10-26 03:11:13 +0000258 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
259
Greg Clayton63094e02010-06-23 01:19:29 +0000260 SBBroadcaster broadcaster (m_opaque_ptr, false);
Caroline Tice7826c882010-10-26 03:11:13 +0000261
262 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000263 log->Printf ("SBCommandInterpreter(%p)::GetBroadcaster() => SBBroadcaster(%p)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000264 m_opaque_ptr, broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000265
Chris Lattner24943d22010-06-08 16:52:24 +0000266 return broadcaster;
267}
268