* command.c (lookup_cmd_1): Clarify descriptive comments.
authorFred Fish <fnf@specifix.com>
Fri, 10 Jul 1992 17:22:35 +0000 (17:22 +0000)
committerFred Fish <fnf@specifix.com>
Fri, 10 Jul 1992 17:22:35 +0000 (17:22 +0000)
* gdbcmd.h (maintenanceprintlist):  Add declaration.
* main.c (maintenanceprintlist):  Add definition.
* main.c (gdb_completer_command_word_break_characters):  Add.
* main.c (symbol_completion_function):  Switch completer word
break character sets dynamically, based on whether completion is
being done on commands or on something else.
* main.c (initialize_cmd_lists):  Init maintenanceprintlist.
* maint.c:  Include demangle.h.
* maint.c (maintenance_demangle):  New function.
* maint.c (maintenance_print_command):  New function.
* maint.c (_initialize_maint_cmds):  Reorganize some commands
under new maintenance print subcommand.

gdb/ChangeLog
gdb/command.c
gdb/maint.c

index 522c25faebe7422764dd56becc3b0b19b48d86bc..c7c91a5e7e44978c4228edf8d52ff18b632e94f7 100644 (file)
@@ -1,3 +1,19 @@
+Fri Jul 10 10:19:52 1992  Fred Fish  (fnf@cygnus.com)
+
+       * command.c (lookup_cmd_1):  Clarify descriptive comments.
+       * gdbcmd.h (maintenanceprintlist):  Add declaration.
+       * main.c (maintenanceprintlist):  Add definition.
+       * main.c (gdb_completer_command_word_break_characters):  Add.
+       * main.c (symbol_completion_function):  Switch completer word
+       break character sets dynamically, based on whether completion is
+       being done on commands or on something else.
+       * main.c (initialize_cmd_lists):  Init maintenanceprintlist.
+       * maint.c:  Include demangle.h.
+       * maint.c (maintenance_demangle):  New function.
+       * maint.c (maintenance_print_command):  New function.
+       * maint.c (_initialize_maint_cmds):  Reorganize some commands
+       under new maintenance print subcommand.
+
 Thu Jul  9 19:05:27 1992  Per Bothner  (bothner@rtl.cygnus.com)
 
        * gdbtypes.c (lookup_struct_elt_type):  If the input type is
index 76402103f351b90a72de5e22f448f92e0aa00c84..5327a4cde8e6cd297aecb99ede64d4a48a117489 100644 (file)
@@ -471,36 +471,35 @@ help_cmd_list (list, class, prefix, recurse, stream)
     }
 }
 \f
-/* This routine takes a line of TEXT and a CLIST in which to
-   start the lookup.  When it returns it will have incremented the text
-   pointer past the section of text it matched, set *RESULT_LIST to
-   the list in which the last word was matched, and will return the
-   cmd list element which the text matches.  It will return 0 if no
-   match at all was possible.  It will return -1 if ambigous matches are
-   possible; in this case *RESULT_LIST will be set to the list in which
-   there are ambiguous choices (and text will be set to the ambiguous
-   text string).
+/* This routine takes a line of TEXT and a CLIST in which to start the
+   lookup.  When it returns it will have incremented the text pointer past
+   the section of text it matched, set *RESULT_LIST to point to the list in
+   which the last word was matched, and will return a pointer to the cmd
+   list element which the text matches.  It will return NULL if no match at
+   all was possible.  It will return -1 (cast appropriately, ick) if ambigous
+   matches are possible; in this case *RESULT_LIST will be set to point to
+   the list in which there are ambiguous choices (and *TEXT will be set to
+   the ambiguous text string).
 
    It does no error reporting whatsoever; control will always return
    to the superior routine.
 
-   In the case of an ambiguous return (-1), *RESULT_LIST will be set to
-   point at the prefix_command (ie. the best match) *or* (special
-   case) will be 0 if no prefix command was ever found.  For example,
-   in the case of "info a", "info" matches without ambiguity, but "a"
-   could be "args" or "address", so *RESULT_LIST is set to
-   the cmd_list_element for "info".  So in this case
-   result list should not be interpeted as a pointer to the beginning
-   of a list; it simply points to a specific command.
+   In the case of an ambiguous return (-1), *RESULT_LIST will be set to point
+   at the prefix_command (ie. the best match) *or* (special case) will be NULL
+   if no prefix command was ever found.  For example, in the case of "info a",
+   "info" matches without ambiguity, but "a" could be "args" or "address", so
+   *RESULT_LIST is set to the cmd_list_element for "info".  So in this case
+   RESULT_LIST should not be interpeted as a pointer to the beginning of a
+   list; it simply points to a specific command.
 
    If RESULT_LIST is NULL, don't set *RESULT_LIST (but don't otherwise
    affect the operation).
 
    This routine does *not* modify the text pointed to by TEXT.
    
-   If IGNORE_HELP_CLASSES is nonzero, ignore any command list
-   elements which are actually help classes rather than commands (i.e.
-   the function field of the struct cmd_list_element is 0).  */
+   If IGNORE_HELP_CLASSES is nonzero, ignore any command list elements which
+   are actually help classes rather than commands (i.e. the function field of
+   the struct cmd_list_element is NULL).  */
 
 struct cmd_list_element *
 lookup_cmd_1 (text, clist, result_list, ignore_help_classes)
index 6de6716a554090aa81fbe01c08a8e1a9147eee05..aff04b1b9d13771432d831968994c33fd37719f6 100644 (file)
@@ -28,6 +28,7 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
 #include "gdbcmd.h"
 #include "symtab.h"
 #include "gdbtypes.h"
+#include "demangle.h"
 
 static void
 maintenance_command PARAMS ((char *, int));
@@ -35,6 +36,9 @@ maintenance_command PARAMS ((char *, int));
 static void
 maintenance_dump_me PARAMS ((char *, int));
 
+static void
+maintenance_demangle PARAMS ((char *, int));
+
 /*
 
 LOCAL FUNCTION
@@ -72,6 +76,40 @@ maintenance_dump_me (args, from_tty)
     }
 }
 
+/*  Someday we should allow demangling for things other than just
+    explicit strings.  For example, we might want to be able to
+    specify the address of a string in either GDB's process space
+    or the debuggee's process space, and have gdb fetch and demangle
+    that string.  If we have a char* pointer "ptr" that points to
+    a string, we might want to be able to given just the name and
+    have GDB demangle and print what it points to, etc.  (FIXME) */
+
+static void
+maintenance_demangle (args, from_tty)
+     char *args;
+     int from_tty;
+{
+  char *demangled;
+
+  if (args == NULL || *args == '\0')
+    {
+      printf ("\"maintenance demangle\" takes an argument to demangle.\n");
+    }
+  else
+    {
+      demangled = cplus_demangle (args, DMGL_ANSI | DMGL_PARAMS);
+      if (demangled != NULL)
+       {
+         printf ("%s\n", demangled);
+         free (demangled);
+       }
+      else
+       {
+         printf ("Can't demangle \"%s\"\n", args);
+       }
+    }
+}
+
 /* The "maintenance info" command is defined as a prefix, with allow_unknown 0.
    Therefore, its own definition is called only for "maintenance info" with
    no args.  */
@@ -86,6 +124,20 @@ maintenance_info_command (arg, from_tty)
   help_list (maintenanceinfolist, "maintenance info ", -1, stdout);
 }
 
+/* The "maintenance print" command is defined as a prefix, with allow_unknown
+   0.  Therefore, its own definition is called only for "maintenance print"
+   with no args.  */
+
+/* ARGSUSED */
+static void
+maintenance_print_command (arg, from_tty)
+     char *arg;
+     int from_tty;
+{
+  printf ("\"maintenance print\" must be followed by the name of a print command.\n");
+  help_list (maintenanceprintlist, "maintenance print ", -1, stdout);
+}
+
 /*
 
 GLOBAL FUNCTION
@@ -110,49 +162,62 @@ _initialize_maint_cmds ()
   add_prefix_cmd ("maintenance", class_maintenance, maintenance_command,
                  "Commands for use by GDB maintainers.\n\
 Includes commands to dump specific internal GDB structures in\n\
-a human readable form, including dumping of symbol tables, type\n\
-chains, etc.",
+a human readable form, to cause GDB to deliberately dump core,\n\
+to test internal functions such as the C++ demangler, etc.",
                  &maintenancelist, "maintenance ", 0,
                  &cmdlist);
 
+  add_com_alias ("mt", "maintenance", class_maintenance, 0);
+
   add_prefix_cmd ("info", class_info, maintenance_info_command,
-        "Maintenance command for showing things about the program being debugged.",
+                 "Commands for showing things about the program being debugged.",
                  &maintenanceinfolist, "maintenance info ", 0,
                  &maintenancelist);
 
+  add_prefix_cmd ("print", class_maintenance, maintenance_print_command,
+                 "Maintenance command for printing GDB internal state.",
+                 &maintenanceprintlist, "maintenance print ", 0,
+                 &maintenancelist);
+
   add_cmd ("dump-me", class_maintenance, maintenance_dump_me,
           "Get fatal error; make debugger dump its core.\n\
 GDB sets it's handling of SIGQUIT back to SIG_DFL and then sends\n\
 itself a SIGQUIT signal.",
           &maintenancelist);
 
-  add_cmd ("print-type", class_maintenance, maintenance_print_type,
+  add_cmd ("demangle", class_maintenance, maintenance_demangle,
+          "Demangle a C++ mangled name.\n\
+Call internal GDB demangler routine to demangle a C++ link name\n\
+and prints the result.",
+          &maintenancelist);
+
+  add_cmd ("type", class_maintenance, maintenance_print_type,
           "Print a type chain for a given symbol.\n\
 For each node in a type chain, print the raw data for each member of\n\
 the type structure, and the interpretation of the data.",
-          &maintenancelist);
+          &maintenanceprintlist);
 
-  add_cmd ("print-symbols", class_maintenance, maintenance_print_symbols,
+  add_cmd ("symbols", class_maintenance, maintenance_print_symbols,
           "Print dump of current symbol definitions.\n\
 Entries in the full symbol table are dumped to file OUTFILE.\n\
 If a SOURCE file is specified, dump only that file's symbols.",
-          &maintenancelist);
+          &maintenanceprintlist);
 
-  add_cmd ("print-msymbols", class_maintenance, maintenance_print_msymbols,
+  add_cmd ("msymbols", class_maintenance, maintenance_print_msymbols,
           "Print dump of current minimal symbol definitions.\n\
 Entries in the minimal symbol table are dumped to file OUTFILE.\n\
 If a SOURCE file is specified, dump only that file's minimal symbols.",
-          &maintenancelist);
+          &maintenanceprintlist);
 
-  add_cmd ("print-psymbols", class_maintenance, maintenance_print_psymbols,
+  add_cmd ("psymbols", class_maintenance, maintenance_print_psymbols,
           "Print dump of current partial symbol definitions.\n\
 Entries in the partial symbol table are dumped to file OUTFILE.\n\
 If a SOURCE file is specified, dump only that file's partial symbols.",
-          &maintenancelist);
+          &maintenanceprintlist);
 
-  add_cmd ("print-objfiles", class_maintenance, maintenance_print_objfiles,
+  add_cmd ("objfiles", class_maintenance, maintenance_print_objfiles,
           "Print dump of current object file definitions.",
-          &maintenancelist);
+          &maintenanceprintlist);
 
 }