<div dir="ltr"><div>It looks like this patch reorders the #includes in a way that seems contrary to general practice.  In particular, if foo.cpp has a header foo.h, then it should include foo.h before any other files.  This helps ensure that foo.h can stand alone and won't require clients to have to figure out what else must be included.<br></div><div><br></div><div><a href="http://llvm.org/docs/CodingStandards.html#include-style">http://llvm.org/docs/CodingStandards.html#include-style</a><br></div><div><br></div><div>I know LLDB doesn't always follow LLVM guidelines, but this seems pretty common and intentional.</div><div><br></div><div class="gmail_extra"><div class="gmail_quote">On Mon, Feb 22, 2016 at 3:46 PM, Eugene Zelenko via lldb-commits <span dir="ltr"><<a href="mailto:lldb-commits@lists.llvm.org" target="_blank">lldb-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Author: eugenezelenko<br>
Date: Mon Feb 22 17:46:47 2016<br>
New Revision: 261593<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=261593&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=261593&view=rev</a><br>
Log:<br>
Fix Clang-tidy modernize-use-nullptr and modernize-use-default warnings in source/Commands/CommandObjectCommands.cpp; other minor fixes.<br>
<br>
Modified:<br>
    lldb/trunk/source/Commands/CommandObjectCommands.cpp<br>
<br>
Modified: lldb/trunk/source/Commands/CommandObjectCommands.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Commands/CommandObjectCommands.cpp?rev=261593&r1=261592&r2=261593&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Commands/CommandObjectCommands.cpp?rev=261593&r1=261592&r2=261593&view=diff</a><br>
==============================================================================<br>
--- lldb/trunk/source/Commands/CommandObjectCommands.cpp (original)<br>
+++ lldb/trunk/source/Commands/CommandObjectCommands.cpp Mon Feb 22 17:46:47 2016<br>
@@ -7,14 +7,13 @@<br>
 //<br>
 //===----------------------------------------------------------------------===//<br>
<br>
-#include "CommandObjectCommands.h"<br>
-<br>
 // C Includes<br>
 // C++ Includes<br>
 // Other libraries and framework includes<br>
 #include "llvm/ADT/StringRef.h"<br>
<br>
 // Project includes<br>
+#include "CommandObjectCommands.h"<br>
 #include "lldb/Core/Debugger.h"<br>
 #include "lldb/Core/IOHandler.h"<br>
 #include "lldb/Core/StringList.h"<br>
@@ -39,15 +38,15 @@ class CommandObjectCommandsHistory : pub<br>
 {<br>
 public:<br>
     CommandObjectCommandsHistory(CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                             "command history",<br>
-                             "Dump the history of commands in this session.",<br>
-                             NULL),<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command history",<br>
+                            "Dump the history of commands in this session.",<br>
+                            nullptr),<br>
         m_options (interpreter)<br>
     {<br>
     }<br>
<br>
-    ~CommandObjectCommandsHistory () override {}<br>
+    ~CommandObjectCommandsHistory() override = default;<br>
<br>
     Options *<br>
     GetOptions () override<br>
@@ -56,11 +55,9 @@ public:<br>
     }<br>
<br>
 protected:<br>
-<br>
     class CommandOptions : public Options<br>
     {<br>
     public:<br>
-<br>
         CommandOptions (CommandInterpreter &interpreter) :<br>
             Options (interpreter),<br>
             m_start_idx(0),<br>
@@ -70,7 +67,7 @@ protected:<br>
         {<br>
         }<br>
<br>
-        ~CommandOptions () override {}<br>
+        ~CommandOptions() override = default;<br>
<br>
         Error<br>
         SetOptionValue (uint32_t option_idx, const char *option_arg) override<br>
@@ -222,14 +219,13 @@ protected:<br>
 OptionDefinition<br>
 CommandObjectCommandsHistory::CommandOptions::g_option_table[] =<br>
 {<br>
-{ LLDB_OPT_SET_1, false, "count", 'c', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeUnsignedInteger,        "How many history commands to print."},<br>
-{ LLDB_OPT_SET_1, false, "start-index", 's', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeUnsignedInteger,  "Index at which to start printing history commands (or end to mean tail mode)."},<br>
-{ LLDB_OPT_SET_1, false, "end-index", 'e', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeUnsignedInteger,    "Index at which to stop printing history commands."},<br>
-{ LLDB_OPT_SET_2, false, "clear", 'C', OptionParser::eNoArgument, NULL, NULL, 0, eArgTypeBoolean,    "Clears the current command history."},<br>
-{ 0, false, NULL, 0, 0, NULL, NULL, 0, eArgTypeNone, NULL }<br>
+{ LLDB_OPT_SET_1, false, "count", 'c', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeUnsignedInteger,        "How many history commands to print."},<br>
+{ LLDB_OPT_SET_1, false, "start-index", 's', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeUnsignedInteger,  "Index at which to start printing history commands (or end to mean tail mode)."},<br>
+{ LLDB_OPT_SET_1, false, "end-index", 'e', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeUnsignedInteger,    "Index at which to stop printing history commands."},<br>
+{ LLDB_OPT_SET_2, false, "clear", 'C', OptionParser::eNoArgument, nullptr, nullptr, 0, eArgTypeBoolean,    "Clears the current command history."},<br>
+{ 0, false, nullptr, 0, 0, nullptr, nullptr, 0, eArgTypeNone, nullptr }<br>
 };<br>
<br>
-<br>
 //-------------------------------------------------------------------------<br>
 // CommandObjectCommandsSource<br>
 //-------------------------------------------------------------------------<br>
@@ -238,10 +234,10 @@ class CommandObjectCommandsSource : publ<br>
 {<br>
 public:<br>
     CommandObjectCommandsSource(CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                             "command source",<br>
-                             "Read in debugger commands from the file <filename> and execute them.",<br>
-                             NULL),<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command source",<br>
+                            "Read in debugger commands from the file <filename> and execute them.",<br>
+                            nullptr),<br>
         m_options (interpreter)<br>
     {<br>
         CommandArgumentEntry arg;<br>
@@ -258,7 +254,7 @@ public:<br>
         m_arguments.push_back (arg);<br>
     }<br>
<br>
-    ~CommandObjectCommandsSource () override {}<br>
+    ~CommandObjectCommandsSource() override = default;<br>
<br>
     const char*<br>
     GetRepeatCommand (Args &current_command_args, uint32_t index) override<br>
@@ -279,14 +275,14 @@ public:<br>
         std::string completion_str (input.GetArgumentAtIndex(cursor_index));<br>
         completion_str.erase (cursor_char_position);<br>
<br>
-        CommandCompletions::InvokeCommonCompletionCallbacks (m_interpreter,<br>
-                                                             CommandCompletions::eDiskFileCompletion,<br>
-                                                             completion_str.c_str(),<br>
-                                                             match_start_point,<br>
-                                                             max_return_elements,<br>
-                                                             NULL,<br>
-                                                             word_complete,<br>
-                                                             matches);<br>
+        CommandCompletions::InvokeCommonCompletionCallbacks(m_interpreter,<br>
+                                                            CommandCompletions::eDiskFileCompletion,<br>
+                                                            completion_str.c_str(),<br>
+                                                            match_start_point,<br>
+                                                            max_return_elements,<br>
+                                                            nullptr,<br>
+                                                            word_complete,<br>
+                                                            matches);<br>
         return matches.GetSize();<br>
     }<br>
<br>
@@ -297,11 +293,9 @@ public:<br>
     }<br>
<br>
 protected:<br>
-<br>
     class CommandOptions : public Options<br>
     {<br>
     public:<br>
-<br>
         CommandOptions (CommandInterpreter &interpreter) :<br>
             Options (interpreter),<br>
             m_stop_on_error (true),<br>
@@ -310,7 +304,7 @@ protected:<br>
         {<br>
         }<br>
<br>
-        ~CommandOptions () override {}<br>
+        ~CommandOptions() override = default;<br>
<br>
         Error<br>
         SetOptionValue (uint32_t option_idx, const char *option_arg) override<br>
@@ -374,7 +368,7 @@ protected:<br>
             const char *filename = command.GetArgumentAtIndex(0);<br>
<br>
             FileSpec cmd_file (filename, true);<br>
-            ExecutionContext *exe_ctx = NULL;  // Just use the default context.<br>
+            ExecutionContext *exe_ctx = nullptr;  // Just use the default context.<br>
<br>
             // If any options were set, then use them<br>
             if (m_options.m_stop_on_error.OptionWasSet()    ||<br>
@@ -392,7 +386,6 @@ protected:<br>
                                                       exe_ctx,<br>
                                                       options,<br>
                                                       result);<br>
-<br>
             }<br>
             else<br>
             {<br>
@@ -403,7 +396,6 @@ protected:<br>
                                                       exe_ctx,<br>
                                                       options,<br>
                                                       result);<br>
-<br>
             }<br>
         }<br>
         else<br>
@@ -412,18 +404,18 @@ protected:<br>
             result.SetStatus (eReturnStatusFailed);<br>
         }<br>
         return result.Succeeded();<br>
-<br>
     }<br>
+<br>
     CommandOptions m_options;<br>
 };<br>
<br>
 OptionDefinition<br>
 CommandObjectCommandsSource::CommandOptions::g_option_table[] =<br>
 {<br>
-{ LLDB_OPT_SET_ALL, false, "stop-on-error", 'e', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeBoolean,    "If true, stop executing commands on error."},<br>
-{ LLDB_OPT_SET_ALL, false, "stop-on-continue", 'c', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeBoolean, "If true, stop executing commands on continue."},<br>
-{ LLDB_OPT_SET_ALL, false, "silent-run", 's', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeBoolean, "If true don't echo commands while executing."},<br>
-{ 0, false, NULL, 0, 0, NULL, NULL, 0, eArgTypeNone, NULL }<br>
+{ LLDB_OPT_SET_ALL, false, "stop-on-error", 'e', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeBoolean,    "If true, stop executing commands on error."},<br>
+{ LLDB_OPT_SET_ALL, false, "stop-on-continue", 'c', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeBoolean, "If true, stop executing commands on continue."},<br>
+{ LLDB_OPT_SET_ALL, false, "silent-run", 's', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeBoolean, "If true don't echo commands while executing."},<br>
+{ 0, false, nullptr, 0, 0, nullptr, nullptr, 0, eArgTypeNone, nullptr }<br>
 };<br>
<br>
 #pragma mark CommandObjectCommandsAlias<br>
@@ -435,17 +427,14 @@ static const char *g_python_command_inst<br>
                                                      "You must define a Python function with this signature:\n"<br>
                                                      "def my_command_impl(debugger, args, result, internal_dict):\n";<br>
<br>
-<br>
 class CommandObjectCommandsAlias : public CommandObjectRaw<br>
 {<br>
-<br>
-<br>
 public:<br>
     CommandObjectCommandsAlias (CommandInterpreter &interpreter) :<br>
-        CommandObjectRaw (interpreter,<br>
-                       "command alias",<br>
-                       "Allow users to define their own debugger command abbreviations.",<br>
-                       NULL)<br>
+        CommandObjectRaw(interpreter,<br>
+                         "command alias",<br>
+                         "Allow users to define their own debugger command abbreviations.",<br>
+                         nullptr)<br>
     {<br>
         SetHelpLong(<br>
 "'alias' allows the user to create a short-cut or abbreviation for long \<br>
@@ -551,9 +540,7 @@ rather than using a positional placehold<br>
         m_arguments.push_back (arg3);<br>
     }<br>
<br>
-    ~CommandObjectCommandsAlias () override<br>
-    {<br>
-    }<br>
+    ~CommandObjectCommandsAlias() override = default;<br>
<br>
 protected:<br>
     bool<br>
@@ -648,9 +635,9 @@ protected:<br>
                 || m_interpreter.UserCommandExists (alias_command.c_str()))<br>
             {<br>
                 OptionArgVectorSP temp_option_arg_sp (m_interpreter.GetAliasOptions (alias_command.c_str()));<br>
-                if (temp_option_arg_sp.get())<br>
+                if (temp_option_arg_sp)<br>
                 {<br>
-                    if (option_arg_vector->size() == 0)<br>
+                    if (option_arg_vector->empty())<br>
                         m_interpreter.RemoveAliasOptions (alias_command.c_str());<br>
                 }<br>
                 result.AppendWarningWithFormat ("Overwriting existing definition for '%s'.\n",<br>
@@ -660,7 +647,7 @@ protected:<br>
             if (cmd_obj_sp)<br>
             {<br>
                 m_interpreter.AddAlias (alias_command.c_str(), cmd_obj_sp);<br>
-                if (option_arg_vector->size() > 0)<br>
+                if (!option_arg_vector->empty())<br>
                     m_interpreter.AddOrReplaceAliasOptions (alias_command.c_str(), option_arg_vector_sp);<br>
                 result.SetStatus (eReturnStatusSuccessFinishNoResult);<br>
             }<br>
@@ -703,10 +690,10 @@ protected:<br>
              CommandObjectSP command_obj_sp(m_interpreter.GetCommandSPExact (actual_command.c_str(), true));<br>
              CommandObjectSP subcommand_obj_sp;<br>
              bool use_subcommand = false;<br>
-             if (command_obj_sp.get())<br>
+             if (command_obj_sp)<br>
              {<br>
                  CommandObject *cmd_obj = command_obj_sp.get();<br>
-                 CommandObject *sub_cmd_obj = NULL;<br>
+                 CommandObject *sub_cmd_obj = nullptr;<br>
                  OptionArgVectorSP option_arg_vector_sp = OptionArgVectorSP (new OptionArgVector);<br>
                  OptionArgVector *option_arg_vector = option_arg_vector_sp.get();<br>
<br>
@@ -717,7 +704,7 @@ protected:<br>
                          const std::string sub_command = args.GetArgumentAtIndex(0);<br>
                          assert (sub_command.length() != 0);<br>
                          subcommand_obj_sp = cmd_obj->GetSubcommandSP (sub_command.c_str());<br>
-                         if (subcommand_obj_sp.get())<br>
+                         if (subcommand_obj_sp)<br>
                          {<br>
                              sub_cmd_obj = subcommand_obj_sp.get();<br>
                              use_subcommand = true;<br>
@@ -760,9 +747,9 @@ protected:<br>
                      || m_interpreter.UserCommandExists (alias_command.c_str()))<br>
                  {<br>
                      OptionArgVectorSP tmp_option_arg_sp (m_interpreter.GetAliasOptions (alias_command.c_str()));<br>
-                     if (tmp_option_arg_sp.get())<br>
+                     if (tmp_option_arg_sp)<br>
                      {<br>
-                         if (option_arg_vector->size() == 0)<br>
+                         if (option_arg_vector->empty())<br>
                              m_interpreter.RemoveAliasOptions (alias_command.c_str());<br>
                      }<br>
                      result.AppendWarningWithFormat ("Overwriting existing definition for '%s'.\n",<br>
@@ -773,7 +760,7 @@ protected:<br>
                      m_interpreter.AddAlias (alias_command.c_str(), subcommand_obj_sp);<br>
                  else<br>
                      m_interpreter.AddAlias (alias_command.c_str(), command_obj_sp);<br>
-                 if (option_arg_vector->size() > 0)<br>
+                 if (!option_arg_vector->empty())<br>
                      m_interpreter.AddOrReplaceAliasOptions (alias_command.c_str(), option_arg_vector_sp);<br>
                  result.SetStatus (eReturnStatusSuccessFinishNoResult);<br>
              }<br>
@@ -787,7 +774,6 @@ protected:<br>
<br>
         return result.Succeeded();<br>
     }<br>
-<br>
 };<br>
<br>
 #pragma mark CommandObjectCommandsUnalias<br>
@@ -799,10 +785,10 @@ class CommandObjectCommandsUnalias : pub<br>
 {<br>
 public:<br>
     CommandObjectCommandsUnalias (CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                       "command unalias",<br>
-                       "Allow the user to remove/delete a user-defined command abbreviation.",<br>
-                       NULL)<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command unalias",<br>
+                            "Allow the user to remove/delete a user-defined command abbreviation.",<br>
+                            nullptr)<br>
     {<br>
         CommandArgumentEntry arg;<br>
         CommandArgumentData alias_arg;<br>
@@ -818,9 +804,7 @@ public:<br>
         m_arguments.push_back (arg);<br>
     }<br>
<br>
-    ~CommandObjectCommandsUnalias() override<br>
-    {<br>
-    }<br>
+    ~CommandObjectCommandsUnalias() override = default;<br>
<br>
 protected:<br>
     bool<br>
@@ -851,8 +835,7 @@ protected:<br>
                 }<br>
                 else<br>
                 {<br>
-<br>
-                    if (m_interpreter.RemoveAlias (command_name) == false)<br>
+                    if (!m_interpreter.RemoveAlias(command_name))<br>
                     {<br>
                         if (m_interpreter.AliasExists (command_name))<br>
                             result.AppendErrorWithFormat ("Error occurred while attempting to unalias '%s'.\n",<br>
@@ -892,10 +875,10 @@ class CommandObjectCommandsDelete : publ<br>
 {<br>
 public:<br>
     CommandObjectCommandsDelete (CommandInterpreter &interpreter) :<br>
-    CommandObjectParsed (interpreter,<br>
-                         "command delete",<br>
-                         "Allow the user to delete user-defined regular expression, python or multi-word commands.",<br>
-                         NULL)<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command delete",<br>
+                            "Allow the user to delete user-defined regular expression, python or multi-word commands.",<br>
+                            nullptr)<br>
     {<br>
         CommandArgumentEntry arg;<br>
         CommandArgumentData alias_arg;<br>
@@ -911,9 +894,7 @@ public:<br>
         m_arguments.push_back (arg);<br>
     }<br>
<br>
-    ~CommandObjectCommandsDelete() override<br>
-    {<br>
-    }<br>
+    ~CommandObjectCommandsDelete() override = default;<br>
<br>
 protected:<br>
     bool<br>
@@ -997,14 +978,10 @@ a number follows 'f':" R"(<br>
     (lldb) command regex f s/^$/finish/ 's/([0-9]+)/frame select %1/')"<br>
         );<br>
     }<br>
-<br>
-    ~CommandObjectCommandsAddRegex() override<br>
-    {<br>
-    }<br>
-<br>
-<br>
+<br>
+    ~CommandObjectCommandsAddRegex() override = default;<br>
+<br>
 protected:<br>
-<br>
     void<br>
     IOHandlerActivated (IOHandler &io_handler) override<br>
     {<br>
@@ -1020,7 +997,7 @@ protected:<br>
     IOHandlerInputComplete (IOHandler &io_handler, std::string &data) override<br>
     {<br>
         io_handler.SetIsDone(true);<br>
-        if (m_regex_cmd_ap.get())<br>
+        if (m_regex_cmd_ap)<br>
         {<br>
             StringList lines;<br>
             if (lines.SplitIntoLines (data))<br>
@@ -1075,15 +1052,15 @@ protected:<br>
                 Debugger &debugger = m_interpreter.GetDebugger();<br>
                 bool color_prompt = debugger.GetUseColor();<br>
                 const bool multiple_lines = true; // Get multiple lines<br>
-                IOHandlerSP io_handler_sp (new IOHandlerEditline (debugger,<br>
-                                                                  IOHandler::Type::Other,<br>
-                                                                  "lldb-regex", // Name of input reader for history<br>
-                                                                  "> ",         // Prompt<br>
-                                                                  NULL,         // Continuation prompt<br>
-                                                                  multiple_lines,<br>
-                                                                  color_prompt,<br>
-                                                                  0,            // Don't show line numbers<br>
-                                                                  *this));<br>
+                IOHandlerSP io_handler_sp(new IOHandlerEditline(debugger,<br>
+                                                                IOHandler::Type::Other,<br>
+                                                                "lldb-regex", // Name of input reader for history<br>
+                                                                "> ",         // Prompt<br>
+                                                                nullptr,      // Continuation prompt<br>
+                                                                multiple_lines,<br>
+                                                                color_prompt,<br>
+                                                                0,            // Don't show line numbers<br>
+                                                                *this));<br>
<br>
                 if (io_handler_sp)<br>
                 {<br>
@@ -1122,7 +1099,7 @@ protected:<br>
     {<br>
         Error error;<br>
<br>
-        if (m_regex_cmd_ap.get() == NULL)<br>
+        if (!m_regex_cmd_ap)<br>
         {<br>
             error.SetErrorStringWithFormat("invalid regular expression command object for: '%.*s'",<br>
                                            (int)regex_sed.size(),<br>
@@ -1190,7 +1167,6 @@ protected:<br>
                                                regex_sed.data() + (third_separator_char_pos + 1));<br>
                 return error;<br>
             }<br>
-<br>
         }<br>
         else if (first_separator_char_pos + 1 == second_separator_char_pos)<br>
         {<br>
@@ -1213,7 +1189,7 @@ protected:<br>
             return error;<br>
         }<br>
<br>
-        if (check_only == false)<br>
+        if (!check_only)<br>
         {<br>
             std::string regex(regex_sed.substr(first_separator_char_pos + 1, second_separator_char_pos - first_separator_char_pos - 1));<br>
             std::string subst(regex_sed.substr(second_separator_char_pos + 1, third_separator_char_pos - second_separator_char_pos - 1));<br>
@@ -1226,7 +1202,7 @@ protected:<br>
     void<br>
     AddRegexCommandToInterpreter()<br>
     {<br>
-        if (m_regex_cmd_ap.get())<br>
+        if (m_regex_cmd_ap)<br>
         {<br>
             if (m_regex_cmd_ap->HasRegexEntries())<br>
             {<br>
@@ -1242,14 +1218,13 @@ private:<br>
      class CommandOptions : public Options<br>
      {<br>
      public:<br>
-<br>
          CommandOptions (CommandInterpreter &interpreter) :<br>
             Options (interpreter)<br>
          {<br>
          }<br>
-<br>
-         ~CommandOptions () override {}<br>
-<br>
+<br>
+         ~CommandOptions() override = default;<br>
+<br>
          Error<br>
          SetOptionValue (uint32_t option_idx, const char *option_arg) override<br>
          {<br>
@@ -1264,7 +1239,6 @@ private:<br>
                  case 's':<br>
                      m_syntax.assign (option_arg);<br>
                      break;<br>
-<br>
                  default:<br>
                      error.SetErrorStringWithFormat ("unrecognized option '%c'", short_option);<br>
                      break;<br>
@@ -1291,21 +1265,20 @@ private:<br>
          static OptionDefinition g_option_table[];<br>
<br>
          const char *<br>
-         GetHelp ()<br>
+         GetHelp()<br>
          {<br>
-             if (m_help.empty())<br>
-                 return NULL;<br>
-             return m_help.c_str();<br>
+             return (m_help.empty() ? nullptr : m_help.c_str());<br>
          }<br>
+<br>
          const char *<br>
          GetSyntax ()<br>
          {<br>
-             if (m_syntax.empty())<br>
-                 return NULL;<br>
-             return m_syntax.c_str();<br>
+             return (m_syntax.empty() ? nullptr : m_syntax.c_str());<br>
          }<br>
-         // Instance variables to hold the values for command options.<br>
+<br>
      protected:<br>
+         // Instance variables to hold the values for command options.<br>
+<br>
          std::string m_help;<br>
          std::string m_syntax;<br>
      };<br>
@@ -1322,30 +1295,23 @@ private:<br>
 OptionDefinition<br>
 CommandObjectCommandsAddRegex::CommandOptions::g_option_table[] =<br>
 {<br>
-{ LLDB_OPT_SET_1, false, "help"  , 'h', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeNone, "The help text to display for this command."},<br>
-{ LLDB_OPT_SET_1, false, "syntax", 's', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeNone, "A syntax string showing the typical usage syntax."},<br>
-{ 0             , false,  NULL   , 0  , 0                , NULL, NULL, 0, eArgTypeNone, NULL }<br>
+{ LLDB_OPT_SET_1, false, "help"  , 'h', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeNone, "The help text to display for this command."},<br>
+{ LLDB_OPT_SET_1, false, "syntax", 's', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeNone, "A syntax string showing the typical usage syntax."},<br>
+{ 0             , false,  nullptr   , 0  , 0                , nullptr, nullptr, 0, eArgTypeNone, nullptr }<br>
 };<br>
<br>
-<br>
 class CommandObjectPythonFunction : public CommandObjectRaw<br>
 {<br>
-private:<br>
-    std::string m_function_name;<br>
-    ScriptedCommandSynchronicity m_synchro;<br>
-    bool m_fetched_help_long;<br>
-<br>
 public:<br>
-<br>
     CommandObjectPythonFunction (CommandInterpreter &interpreter,<br>
                                  std::string name,<br>
                                  std::string funct,<br>
                                  std::string help,<br>
                                  ScriptedCommandSynchronicity synch) :<br>
-        CommandObjectRaw (interpreter,<br>
-                          name.c_str(),<br>
-                          NULL,<br>
-                          NULL),<br>
+        CommandObjectRaw(interpreter,<br>
+                         name.c_str(),<br>
+                         nullptr,<br>
+                         nullptr),<br>
         m_function_name(funct),<br>
         m_synchro(synch),<br>
         m_fetched_help_long(false)<br>
@@ -1359,11 +1325,9 @@ public:<br>
             SetHelp(stream.GetData());<br>
         }<br>
     }<br>
-<br>
-    ~CommandObjectPythonFunction () override<br>
-    {<br>
-    }<br>
-<br>
+<br>
+    ~CommandObjectPythonFunction() override = default;<br>
+<br>
     bool<br>
     IsRemovable () const override<br>
     {<br>
@@ -1409,12 +1373,12 @@ protected:<br>
<br>
         result.SetStatus(eReturnStatusInvalid);<br>
<br>
-        if (!scripter || scripter->RunScriptBasedCommand(m_function_name.c_str(),<br>
-                                                         raw_command_line,<br>
-                                                         m_synchro,<br>
-                                                         result,<br>
-                                                         error,<br>
-                                                         m_exe_ctx) == false)<br>
+        if (!scripter || !scripter->RunScriptBasedCommand(m_function_name.c_str(),<br>
+                                                          raw_command_line,<br>
+                                                          m_synchro,<br>
+                                                          result,<br>
+                                                          error,<br>
+                                                          m_exe_ctx))<br>
         {<br>
             result.AppendError(error.AsCString());<br>
             result.SetStatus(eReturnStatusFailed);<br>
@@ -1424,7 +1388,7 @@ protected:<br>
             // Don't change the status if the command already set it...<br>
             if (result.GetStatus() == eReturnStatusInvalid)<br>
             {<br>
-                if (result.GetOutputData() == NULL || result.GetOutputData()[0] == '\0')<br>
+                if (result.GetOutputData() == nullptr || result.GetOutputData()[0] == '\0')<br>
                     result.SetStatus(eReturnStatusSuccessFinishNoResult);<br>
                 else<br>
                     result.SetStatus(eReturnStatusSuccessFinishResult);<br>
@@ -1433,31 +1397,28 @@ protected:<br>
<br>
         return result.Succeeded();<br>
     }<br>
-<br>
+<br>
+private:<br>
+    std::string m_function_name;<br>
+    ScriptedCommandSynchronicity m_synchro;<br>
+    bool m_fetched_help_long;<br>
 };<br>
<br>
 class CommandObjectScriptingObject : public CommandObjectRaw<br>
 {<br>
-private:<br>
-    StructuredData::GenericSP m_cmd_obj_sp;<br>
-    ScriptedCommandSynchronicity m_synchro;<br>
-    bool m_fetched_help_short:1;<br>
-    bool m_fetched_help_long:1;<br>
-<br>
 public:<br>
-<br>
     CommandObjectScriptingObject (CommandInterpreter &interpreter,<br>
                                   std::string name,<br>
                                   StructuredData::GenericSP cmd_obj_sp,<br>
                                   ScriptedCommandSynchronicity synch) :<br>
-    CommandObjectRaw (interpreter,<br>
-                      name.c_str(),<br>
-                      NULL,<br>
-                      NULL),<br>
-    m_cmd_obj_sp(cmd_obj_sp),<br>
-    m_synchro(synch),<br>
-    m_fetched_help_short(false),<br>
-    m_fetched_help_long(false)<br>
+        CommandObjectRaw(interpreter,<br>
+                         name.c_str(),<br>
+                         nullptr,<br>
+                         nullptr),<br>
+        m_cmd_obj_sp(cmd_obj_sp),<br>
+        m_synchro(synch),<br>
+        m_fetched_help_short(false),<br>
+        m_fetched_help_long(false)<br>
     {<br>
         StreamString stream;<br>
         stream.Printf("For more information run 'help %s'",name.c_str());<br>
@@ -1465,11 +1426,9 @@ public:<br>
         if (ScriptInterpreter* scripter = m_interpreter.GetScriptInterpreter())<br>
             GetFlags().Set(scripter->GetFlagsForCommandObject(cmd_obj_sp));<br>
     }<br>
-<br>
-    ~CommandObjectScriptingObject () override<br>
-    {<br>
-    }<br>
-<br>
+<br>
+    ~CommandObjectScriptingObject() override = default;<br>
+<br>
     bool<br>
     IsRemovable () const override<br>
     {<br>
@@ -1532,12 +1491,12 @@ protected:<br>
<br>
         result.SetStatus(eReturnStatusInvalid);<br>
<br>
-        if (!scripter || scripter->RunScriptBasedCommand(m_cmd_obj_sp,<br>
-                                                         raw_command_line,<br>
-                                                         m_synchro,<br>
-                                                         result,<br>
-                                                         error,<br>
-                                                         m_exe_ctx) == false)<br>
+        if (!scripter || !scripter->RunScriptBasedCommand(m_cmd_obj_sp,<br>
+                                                          raw_command_line,<br>
+                                                          m_synchro,<br>
+                                                          result,<br>
+                                                          error,<br>
+                                                          m_exe_ctx))<br>
         {<br>
             result.AppendError(error.AsCString());<br>
             result.SetStatus(eReturnStatusFailed);<br>
@@ -1547,7 +1506,7 @@ protected:<br>
             // Don't change the status if the command already set it...<br>
             if (result.GetStatus() == eReturnStatusInvalid)<br>
             {<br>
-                if (result.GetOutputData() == NULL || result.GetOutputData()[0] == '\0')<br>
+                if (result.GetOutputData() == nullptr || result.GetOutputData()[0] == '\0')<br>
                     result.SetStatus(eReturnStatusSuccessFinishNoResult);<br>
                 else<br>
                     result.SetStatus(eReturnStatusSuccessFinishResult);<br>
@@ -1556,7 +1515,12 @@ protected:<br>
<br>
         return result.Succeeded();<br>
     }<br>
-<br>
+<br>
+private:<br>
+    StructuredData::GenericSP m_cmd_obj_sp;<br>
+    ScriptedCommandSynchronicity m_synchro;<br>
+    bool m_fetched_help_short: 1;<br>
+    bool m_fetched_help_long: 1;<br>
 };<br>
<br>
 //-------------------------------------------------------------------------<br>
@@ -1567,10 +1531,10 @@ class CommandObjectCommandsScriptImport<br>
 {<br>
 public:<br>
     CommandObjectCommandsScriptImport (CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                             "command script import",<br>
-                             "Import a scripting module in LLDB.",<br>
-                             NULL),<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command script import",<br>
+                            "Import a scripting module in LLDB.",<br>
+                            nullptr),<br>
         m_options(interpreter)<br>
     {<br>
         CommandArgumentEntry arg1;<br>
@@ -1586,11 +1550,9 @@ public:<br>
         // Push the data for the first argument into the m_arguments vector.<br>
         m_arguments.push_back (arg1);<br>
     }<br>
-<br>
-    ~CommandObjectCommandsScriptImport () override<br>
-    {<br>
-    }<br>
-<br>
+<br>
+    ~CommandObjectCommandsScriptImport() override = default;<br>
+<br>
     int<br>
     HandleArgumentCompletion (Args &input,<br>
                               int &cursor_index,<br>
@@ -1604,14 +1566,14 @@ public:<br>
         std::string completion_str (input.GetArgumentAtIndex(cursor_index));<br>
         completion_str.erase (cursor_char_position);<br>
<br>
-        CommandCompletions::InvokeCommonCompletionCallbacks (m_interpreter,<br>
-                                                             CommandCompletions::eDiskFileCompletion,<br>
-                                                             completion_str.c_str(),<br>
-                                                             match_start_point,<br>
-                                                             max_return_elements,<br>
-                                                             NULL,<br>
-                                                             word_complete,<br>
-                                                             matches);<br>
+        CommandCompletions::InvokeCommonCompletionCallbacks(m_interpreter,<br>
+                                                            CommandCompletions::eDiskFileCompletion,<br>
+                                                            completion_str.c_str(),<br>
+                                                            match_start_point,<br>
+                                                            max_return_elements,<br>
+                                                            nullptr,<br>
+                                                            word_complete,<br>
+                                                            matches);<br>
         return matches.GetSize();<br>
     }<br>
<br>
@@ -1622,18 +1584,16 @@ public:<br>
     }<br>
<br>
 protected:<br>
-<br>
     class CommandOptions : public Options<br>
     {<br>
     public:<br>
-<br>
         CommandOptions (CommandInterpreter &interpreter) :<br>
             Options (interpreter)<br>
         {<br>
         }<br>
-<br>
-        ~CommandOptions () override {}<br>
-<br>
+<br>
+        ~CommandOptions() override = default;<br>
+<br>
         Error<br>
         SetOptionValue (uint32_t option_idx, const char *option_arg) override<br>
         {<br>
@@ -1730,11 +1690,10 @@ protected:<br>
 OptionDefinition<br>
 CommandObjectCommandsScriptImport::CommandOptions::g_option_table[] =<br>
 {<br>
-    { LLDB_OPT_SET_1, false, "allow-reload", 'r', OptionParser::eNoArgument, NULL, NULL, 0, eArgTypeNone,        "Allow the script to be loaded even if it was already loaded before. This argument exists for backwards compatibility, but reloading is always allowed, whether you specify it or not."},<br>
-    { 0, false, NULL, 0, 0, NULL, NULL, 0, eArgTypeNone, NULL }<br>
+    { LLDB_OPT_SET_1, false, "allow-reload", 'r', OptionParser::eNoArgument, nullptr, nullptr, 0, eArgTypeNone,        "Allow the script to be loaded even if it was already loaded before. This argument exists for backwards compatibility, but reloading is always allowed, whether you specify it or not."},<br>
+    { 0, false, nullptr, 0, 0, nullptr, nullptr, 0, eArgTypeNone, nullptr }<br>
 };<br>
<br>
-<br>
 //-------------------------------------------------------------------------<br>
 // CommandObjectCommandsScriptAdd<br>
 //-------------------------------------------------------------------------<br>
@@ -1745,10 +1704,10 @@ class CommandObjectCommandsScriptAdd :<br>
 {<br>
 public:<br>
     CommandObjectCommandsScriptAdd(CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                             "command script add",<br>
-                             "Add a scripted function as an LLDB command.",<br>
-                             NULL),<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command script add",<br>
+                            "Add a scripted function as an LLDB command.",<br>
+                            nullptr),<br>
         IOHandlerDelegateMultiline ("DONE"),<br>
         m_options (interpreter)<br>
     {<br>
@@ -1765,11 +1724,9 @@ public:<br>
         // Push the data for the first argument into the m_arguments vector.<br>
         m_arguments.push_back (arg1);<br>
     }<br>
-<br>
-    ~CommandObjectCommandsScriptAdd () override<br>
-    {<br>
-    }<br>
-<br>
+<br>
+    ~CommandObjectCommandsScriptAdd() override = default;<br>
+<br>
     Options *<br>
     GetOptions () override<br>
     {<br>
@@ -1777,11 +1734,9 @@ public:<br>
     }<br>
<br>
 protected:<br>
-<br>
     class CommandOptions : public Options<br>
     {<br>
     public:<br>
-<br>
         CommandOptions (CommandInterpreter &interpreter) :<br>
             Options (interpreter),<br>
             m_class_name(),<br>
@@ -1790,9 +1745,9 @@ protected:<br>
             m_synchronicity(eScriptedCommandSynchronicitySynchronous)<br>
         {<br>
         }<br>
-<br>
-        ~CommandOptions () override {}<br>
-<br>
+<br>
+        ~CommandOptions() override = default;<br>
+<br>
         Error<br>
         SetOptionValue (uint32_t option_idx, const char *option_arg) override<br>
         {<br>
@@ -1922,15 +1877,12 @@ protected:<br>
         }<br>
<br>
         io_handler.SetIsDone(true);<br>
-<br>
-<br>
     }<br>
<br>
 protected:<br>
     bool<br>
     DoExecute (Args& command, CommandReturnObject &result) override<br>
     {<br>
-<br>
         if (m_interpreter.GetDebugger().GetScriptLanguage() != lldb::eScriptLanguagePython)<br>
         {<br>
             result.AppendError ("only scripting language supported for scripted commands is currently Python");<br>
@@ -1956,10 +1908,10 @@ protected:<br>
         {<br>
             if (m_options.m_funct_name.empty())<br>
             {<br>
-                m_interpreter.GetPythonCommandsFromIOHandler ("     ",  // Prompt<br>
-                                                              *this,    // IOHandlerDelegate<br>
-                                                              true,     // Run IOHandler in async mode<br>
-                                                              NULL);    // Baton for the "io_handler" that will be passed back into our IOHandlerDelegate functions<br>
+                m_interpreter.GetPythonCommandsFromIOHandler("     ",  // Prompt<br>
+                                                             *this,    // IOHandlerDelegate<br>
+                                                             true,     // Run IOHandler in async mode<br>
+                                                             nullptr); // Baton for the "io_handler" that will be passed back into our IOHandlerDelegate functions<br>
             }<br>
             else<br>
             {<br>
@@ -2013,7 +1965,6 @@ protected:<br>
         }<br>
<br>
         return result.Succeeded();<br>
-<br>
     }<br>
<br>
     CommandOptions m_options;<br>
@@ -2027,17 +1978,17 @@ static OptionEnumValueElement g_script_s<br>
     { eScriptedCommandSynchronicitySynchronous,      "synchronous",       "Run synchronous"},<br>
     { eScriptedCommandSynchronicityAsynchronous,     "asynchronous",      "Run asynchronous"},<br>
     { eScriptedCommandSynchronicityCurrentValue,     "current",           "Do not alter current setting"},<br>
-    { 0, NULL, NULL }<br>
+    { 0, nullptr, nullptr }<br>
 };<br>
<br>
 OptionDefinition<br>
 CommandObjectCommandsScriptAdd::CommandOptions::g_option_table[] =<br>
 {<br>
-    { LLDB_OPT_SET_1, false, "function", 'f', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypePythonFunction,        "Name of the Python function to bind to this command name."},<br>
-    { LLDB_OPT_SET_2, false, "class", 'c', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypePythonClass,        "Name of the Python class to bind to this command name."},<br>
-    { LLDB_OPT_SET_1, false, "help"  , 'h', OptionParser::eRequiredArgument, NULL, NULL, 0, eArgTypeHelpText, "The help text to display for this command."},<br>
-    { LLDB_OPT_SET_ALL, false, "synchronicity", 's', OptionParser::eRequiredArgument, NULL, g_script_synchro_type, 0, eArgTypeScriptedCommandSynchronicity,        "Set the synchronicity of this command's executions with regard to LLDB event system."},<br>
-    { 0, false, NULL, 0, 0, NULL, NULL, 0, eArgTypeNone, NULL }<br>
+    { LLDB_OPT_SET_1, false, "function", 'f', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypePythonFunction,        "Name of the Python function to bind to this command name."},<br>
+    { LLDB_OPT_SET_2, false, "class", 'c', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypePythonClass,        "Name of the Python class to bind to this command name."},<br>
+    { LLDB_OPT_SET_1, false, "help"  , 'h', OptionParser::eRequiredArgument, nullptr, nullptr, 0, eArgTypeHelpText, "The help text to display for this command."},<br>
+    { LLDB_OPT_SET_ALL, false, "synchronicity", 's', OptionParser::eRequiredArgument, nullptr, g_script_synchro_type, 0, eArgTypeScriptedCommandSynchronicity,        "Set the synchronicity of this command's executions with regard to LLDB event system."},<br>
+    { 0, false, nullptr, 0, 0, nullptr, nullptr, 0, eArgTypeNone, nullptr }<br>
 };<br>
<br>
 //-------------------------------------------------------------------------<br>
@@ -2046,33 +1997,26 @@ CommandObjectCommandsScriptAdd::CommandO<br>
<br>
 class CommandObjectCommandsScriptList : public CommandObjectParsed<br>
 {<br>
-private:<br>
-<br>
 public:<br>
     CommandObjectCommandsScriptList(CommandInterpreter &interpreter) :<br>
-    CommandObjectParsed (interpreter,<br>
-                   "command script list",<br>
-                   "List defined scripted commands.",<br>
-                   NULL)<br>
-    {<br>
-    }<br>
-<br>
-    ~CommandObjectCommandsScriptList () override<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command script list",<br>
+                            "List defined scripted commands.",<br>
+                            nullptr)<br>
     {<br>
     }<br>
-<br>
+<br>
+    ~CommandObjectCommandsScriptList() override = default;<br>
+<br>
     bool<br>
     DoExecute (Args& command, CommandReturnObject &result) override<br>
     {<br>
-<br>
         m_interpreter.GetHelp(result,<br>
                               CommandInterpreter::eCommandTypesUserDef);<br>
<br>
         result.SetStatus (eReturnStatusSuccessFinishResult);<br>
<br>
         return true;<br>
-<br>
-<br>
     }<br>
 };<br>
<br>
@@ -2082,26 +2026,21 @@ public:<br>
<br>
 class CommandObjectCommandsScriptClear : public CommandObjectParsed<br>
 {<br>
-private:<br>
-<br>
 public:<br>
     CommandObjectCommandsScriptClear(CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                             "command script clear",<br>
-                             "Delete all scripted commands.",<br>
-                             NULL)<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command script clear",<br>
+                            "Delete all scripted commands.",<br>
+                            nullptr)<br>
     {<br>
     }<br>
-<br>
-    ~CommandObjectCommandsScriptClear () override<br>
-    {<br>
-    }<br>
-<br>
+<br>
+    ~CommandObjectCommandsScriptClear() override = default;<br>
+<br>
 protected:<br>
     bool<br>
     DoExecute (Args& command, CommandReturnObject &result) override<br>
     {<br>
-<br>
         m_interpreter.RemoveAllUser();<br>
<br>
         result.SetStatus (eReturnStatusSuccessFinishResult);<br>
@@ -2118,10 +2057,10 @@ class CommandObjectCommandsScriptDelete<br>
 {<br>
 public:<br>
     CommandObjectCommandsScriptDelete(CommandInterpreter &interpreter) :<br>
-        CommandObjectParsed (interpreter,<br>
-                             "command script delete",<br>
-                             "Delete a scripted command.",<br>
-                             NULL)<br>
+        CommandObjectParsed(interpreter,<br>
+                            "command script delete",<br>
+                            "Delete a scripted command.",<br>
+                            nullptr)<br>
     {<br>
         CommandArgumentEntry arg1;<br>
         CommandArgumentData cmd_arg;<br>
@@ -2136,11 +2075,9 @@ public:<br>
         // Push the data for the first argument into the m_arguments vector.<br>
         m_arguments.push_back (arg1);<br>
     }<br>
-<br>
-    ~CommandObjectCommandsScriptDelete () override<br>
-    {<br>
-    }<br>
-<br>
+<br>
+    ~CommandObjectCommandsScriptDelete() override = default;<br>
+<br>
 protected:<br>
     bool<br>
     DoExecute (Args& command, CommandReturnObject &result) override<br>
@@ -2169,7 +2106,6 @@ protected:<br>
         }<br>
<br>
         return result.Succeeded();<br>
-<br>
     }<br>
 };<br>
<br>
@@ -2195,13 +2131,9 @@ public:<br>
         LoadSubCommand ("import", CommandObjectSP (new CommandObjectCommandsScriptImport (interpreter)));<br>
     }<br>
<br>
-    ~CommandObjectMultiwordCommandsScript () override<br>
-    {<br>
-    }<br>
-<br>
+    ~CommandObjectMultiwordCommandsScript() override = default;<br>
 };<br>
<br>
-<br>
 #pragma mark CommandObjectMultiwordCommands<br>
<br>
 //-------------------------------------------------------------------------<br>
@@ -2223,7 +2155,4 @@ CommandObjectMultiwordCommands::CommandO<br>
     LoadSubCommand ("script",  CommandObjectSP (new CommandObjectMultiwordCommandsScript (interpreter)));<br>
 }<br>
<br>
-CommandObjectMultiwordCommands::~CommandObjectMultiwordCommands ()<br>
-{<br>
-}<br>
-<br>
+CommandObjectMultiwordCommands::~CommandObjectMultiwordCommands() = default;<br>
<br>
<br>
_______________________________________________<br>
lldb-commits mailing list<br>
<a href="mailto:lldb-commits@lists.llvm.org">lldb-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits</a><br>
</blockquote></div><br></div></div>