blob: 29e1f14e3b28a0cc1a705dad989d9484bae97aa5 [file] [log] [blame]
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001//===-- CommandObjectApropos.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
Chris Lattner30fdc8d2010-06-08 16:52:24 +000010// C Includes
11// C++ Includes
12// Other libraries and framework includes
13// Project includes
Eugene Zelenkoc8ecc2a2016-02-19 19:33:46 +000014#include "CommandObjectApropos.h"
Jim Ingham40af72e2010-06-15 19:49:27 +000015#include "lldb/Interpreter/Args.h"
16#include "lldb/Interpreter/Options.h"
Zachary Turner633a29c2015-03-04 01:58:01 +000017#include "lldb/Interpreter/Property.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000018#include "lldb/Interpreter/CommandInterpreter.h"
19#include "lldb/Interpreter/CommandReturnObject.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000020
21using namespace lldb;
22using namespace lldb_private;
23
24//-------------------------------------------------------------------------
25// CommandObjectApropos
26//-------------------------------------------------------------------------
27
Kate Stone7428a182016-07-14 22:03:10 +000028CommandObjectApropos::CommandObjectApropos(CommandInterpreter &interpreter)
29 : CommandObjectParsed(interpreter, "apropos", "List debugger commands related to a word or subject.", nullptr)
Chris Lattner30fdc8d2010-06-08 16:52:24 +000030{
Caroline Tice405fe672010-10-04 22:28:36 +000031 CommandArgumentEntry arg;
32 CommandArgumentData search_word_arg;
33
34 // Define the first (and only) variant of this arg.
35 search_word_arg.arg_type = eArgTypeSearchWord;
36 search_word_arg.arg_repetition = eArgRepeatPlain;
37
38 // There is only one variant this argument could be; put it into the argument entry.
39 arg.push_back (search_word_arg);
40
41 // Push the data for the first argument into the m_arguments vector.
42 m_arguments.push_back (arg);
Chris Lattner30fdc8d2010-06-08 16:52:24 +000043}
44
Eugene Zelenkoc8ecc2a2016-02-19 19:33:46 +000045CommandObjectApropos::~CommandObjectApropos() = default;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000046
47bool
Jim Ingham5a988412012-06-08 21:56:10 +000048CommandObjectApropos::DoExecute (Args& args, CommandReturnObject &result)
Chris Lattner30fdc8d2010-06-08 16:52:24 +000049{
Greg Claytonc7bece562013-01-25 18:06:21 +000050 const size_t argc = args.GetArgumentCount ();
Chris Lattner30fdc8d2010-06-08 16:52:24 +000051
52 if (argc == 1)
53 {
Greg Clayton66111032010-06-23 01:19:29 +000054 const char *search_word = args.GetArgumentAtIndex(0);
Eugene Zelenkoc8ecc2a2016-02-19 19:33:46 +000055 if ((search_word != nullptr)
Chris Lattner30fdc8d2010-06-08 16:52:24 +000056 && (strlen (search_word) > 0))
57 {
58 // The bulk of the work must be done inside the Command Interpreter, since the command dictionary
59 // is private.
60 StringList commands_found;
61 StringList commands_help;
Jim Inghamaf3753e2013-05-17 01:30:37 +000062
Enrico Granatad033e1c2016-03-23 01:21:55 +000063 m_interpreter.FindCommandsForApropos (search_word, commands_found, commands_help, true, true, true);
Jim Inghamaf3753e2013-05-17 01:30:37 +000064
Enrico Granatad033e1c2016-03-23 01:21:55 +000065 if (commands_found.GetSize() == 0)
Chris Lattner30fdc8d2010-06-08 16:52:24 +000066 {
Greg Clayton3bcbf842010-11-02 18:23:13 +000067 result.AppendMessageWithFormat ("No commands found pertaining to '%s'. Try 'help' to see a complete list of debugger commands.\n", search_word);
Chris Lattner30fdc8d2010-06-08 16:52:24 +000068 }
69 else
70 {
Jim Inghamaf3753e2013-05-17 01:30:37 +000071 if (commands_found.GetSize() > 0)
Chris Lattner30fdc8d2010-06-08 16:52:24 +000072 {
Enrico Granatad033e1c2016-03-23 01:21:55 +000073 result.AppendMessageWithFormat ("The following commands may relate to '%s':\n", search_word);
Jim Inghamaf3753e2013-05-17 01:30:37 +000074 size_t max_len = 0;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000075
Jim Inghamaf3753e2013-05-17 01:30:37 +000076 for (size_t i = 0; i < commands_found.GetSize(); ++i)
77 {
78 size_t len = strlen (commands_found.GetStringAtIndex (i));
79 if (len > max_len)
80 max_len = len;
81 }
82
83 for (size_t i = 0; i < commands_found.GetSize(); ++i)
84 m_interpreter.OutputFormattedHelpText (result.GetOutputStream(),
85 commands_found.GetStringAtIndex(i),
86 "--",
87 commands_help.GetStringAtIndex(i),
88 max_len);
Jim Inghamaf3753e2013-05-17 01:30:37 +000089 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +000090 }
Caroline Tice73fd2722011-02-04 00:16:49 +000091
Greg Clayton67cc0632012-08-22 17:17:09 +000092 std::vector<const Property *> properties;
93 const size_t num_properties = m_interpreter.GetDebugger().Apropos(search_word, properties);
94 if (num_properties)
Caroline Tice73fd2722011-02-04 00:16:49 +000095 {
Greg Clayton67cc0632012-08-22 17:17:09 +000096 const bool dump_qualified_name = true;
Caroline Tice73fd2722011-02-04 00:16:49 +000097 result.AppendMessageWithFormat ("\nThe following settings variables may relate to '%s': \n\n", search_word);
Greg Clayton67cc0632012-08-22 17:17:09 +000098 for (size_t i=0; i<num_properties; ++i)
99 properties[i]->DumpDescription (m_interpreter, result.GetOutputStream(), 0, dump_qualified_name);
100
Caroline Tice73fd2722011-02-04 00:16:49 +0000101 }
102
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000103 result.SetStatus (eReturnStatusSuccessFinishNoResult);
104 }
105 else
106 {
107 result.AppendError ("'' is not a valid search word.\n");
108 result.SetStatus (eReturnStatusFailed);
109 }
110 }
111 else
112 {
113 result.AppendError ("'apropos' must be called with exactly one argument.\n");
114 result.SetStatus (eReturnStatusFailed);
115 }
116
117 return result.Succeeded();
118}