Constify main.c:get_init_files.
authorPedro Alves <palves@redhat.com>
Mon, 1 Jul 2013 11:22:12 +0000 (11:22 +0000)
committerPedro Alves <palves@redhat.com>
Mon, 1 Jul 2013 11:22:12 +0000 (11:22 +0000)
A following patch will want to make the "gdbinit" global array const.
As usual, that forces in a cascading series of const additions.  This
patch preemptively does those.  I went all the way up to constifying
catch_command_errors, but then that would require constifying
execute_command as well (which is a much more significant effort).  So
as stop point, I found the cleanest would be to add a variant of
catch_command_errors that takes const args, and use that in the few
spots that needed it due to the the get_init_files constification.

gdb/
2013-07-01  Pedro Alves  <palves@redhat.com>

* cli/cli-cmds.c (source_script): Make 'file' parameter const.
* cli/cli-cmds.h (source_script): Likewise.
* exceptions.c (catch_command_errors_const): New function.
* exceptions.h (catch_command_errors_const): Declare.
* main.c (get_init_files): Make parameters const, and adjust.
(captured_main): Make 'system_gdbinit', 'home_gdbinit' and
'local_gdbinit' locals const.  Adjust to use
catch_command_errors_const.
(print_gdb_help): Make 'system_gdbinit', 'home_gdbinit' and
'local_gdbinit' locals const.

gdb/ChangeLog
gdb/cli/cli-cmds.c
gdb/cli/cli-cmds.h
gdb/exceptions.c
gdb/exceptions.h
gdb/main.c

index 7292d8b13dc4672fc7480dafd7baa439743bd1f6..7edc65ad5aa3a66a74f9d871b83ed1ad01d631bd 100644 (file)
@@ -1,3 +1,16 @@
+2013-07-01  Pedro Alves  <palves@redhat.com>
+
+       * cli/cli-cmds.c (source_script): Make 'file' parameter const.
+       * cli/cli-cmds.h (source_script): Likewise.
+       * exceptions.c (catch_command_errors_const): New function.
+       * exceptions.h (catch_command_errors_const): Declare.
+       * main.c (get_init_files): Make parameters const, and adjust.
+       (captured_main): Make 'system_gdbinit', 'home_gdbinit' and
+       'local_gdbinit' locals const.  Adjust to use
+       catch_command_errors_const.
+       (print_gdb_help): Make 'system_gdbinit', 'home_gdbinit' and
+       'local_gdbinit' locals const.
+
 2013-07-01  Pedro Alves  <palves@redhat.com>
 
        * defs.h: Don't check HAVE_UNISTD_H before including <unistd.h>.
index 6ee767320b006a35a533a66561073e066776c9bc..bd2ca2d58febe7e97de3ff1cecf7e1d3fcbe4547 100644 (file)
@@ -597,7 +597,7 @@ source_script_with_search (const char *file, int from_tty, int search_path)
    for use in loading .gdbinit scripts.  */
 
 void
-source_script (char *file, int from_tty)
+source_script (const char *file, int from_tty)
 {
   source_script_with_search (file, from_tty, 0);
 }
index 9f6977c0c6641f563955cd7faef3b1f36a1d39c3..34fe44554c693bf6ae7f8d213a760ddf508e6e81 100644 (file)
@@ -117,7 +117,7 @@ extern void cd_command (char *, int);
 
 extern void quit_command (char *, int);
 
-extern void source_script (char *, int);
+extern void source_script (const char *, int);
 
 /* Exported to objfiles.c.  */
 
index 0cdd16b75f63bc0958cb34ba836c06016d5c5c70..416d81d1fd10cb4712eabd21a6c6d199753396d2 100644 (file)
@@ -577,3 +577,19 @@ catch_command_errors (catch_command_errors_ftype *command,
     return 0;
   return 1;
 }
+
+int
+catch_command_errors_const (catch_command_errors_const_ftype *command,
+                           const char *arg, int from_tty, return_mask mask)
+{
+  volatile struct gdb_exception e;
+
+  TRY_CATCH (e, mask)
+    {
+      command (arg, from_tty);
+    }
+  print_any_exception (gdb_stderr, NULL, e);
+  if (e.reason < 0)
+    return 0;
+  return 1;
+}
index 7e3be95a04f0734e1f0752156cb9d50835dab96d..19eacd3ad67e445dd2c5658b77b6d97d0e2fbb31 100644 (file)
@@ -257,4 +257,10 @@ typedef void (catch_command_errors_ftype) (char *, int);
 extern int catch_command_errors (catch_command_errors_ftype *func,
                                 char *arg, int from_tty, return_mask);
 
+/* Like catch_command_errors, but works with const command and args.  */
+
+typedef void (catch_command_errors_const_ftype) (const char *, int);
+extern int catch_command_errors_const (catch_command_errors_const_ftype *func,
+                                      const char *arg, int from_tty, return_mask);
+
 #endif
index 3c1ef759462b24c23a7eb2cbb4930608af0d099f..a0930ee7463eb1722701f60a5ae7316d87b571ab 100644 (file)
@@ -160,13 +160,13 @@ relocate_gdb_directory (const char *initial, int flag)
    to be loaded, then SYSTEM_GDBINIT (resp. HOME_GDBINIT and
    LOCAL_GDBINIT) is set to NULL.  */
 static void
-get_init_files (char **system_gdbinit,
-               char **home_gdbinit,
-               char **local_gdbinit)
+get_init_files (const char **system_gdbinit,
+               const char **home_gdbinit,
+               const char **local_gdbinit)
 {
-  static char *sysgdbinit = NULL;
+  static const char *sysgdbinit = NULL;
   static char *homeinit = NULL;
-  static char *localinit = NULL;
+  static const char *localinit = NULL;
   static int initialized = 0;
 
   if (!initialized)
@@ -336,9 +336,9 @@ captured_main (void *data)
   int ndir;
 
   /* gdb init files.  */
-  char *system_gdbinit;
-  char *home_gdbinit;
-  char *local_gdbinit;
+  const char *system_gdbinit;
+  const char *home_gdbinit;
+  const char *local_gdbinit;
 
   int i;
   int save_auto_load;
@@ -894,7 +894,8 @@ captured_main (void *data)
      processed; it sets global parameters, which are independent of
      what file you are debugging or what directory you are in.  */
   if (system_gdbinit && !inhibit_gdbinit)
-    catch_command_errors (source_script, system_gdbinit, 0, RETURN_MASK_ALL);
+    catch_command_errors_const (source_script, system_gdbinit,
+                               0, RETURN_MASK_ALL);
 
   /* Read and execute $HOME/.gdbinit file, if it exists.  This is done
      *before* all the command line arguments are processed; it sets
@@ -902,15 +903,16 @@ captured_main (void *data)
      debugging or what directory you are in.  */
 
   if (home_gdbinit && !inhibit_gdbinit && !inhibit_home_gdbinit)
-    catch_command_errors (source_script, home_gdbinit, 0, RETURN_MASK_ALL);
+    catch_command_errors_const (source_script,
+                               home_gdbinit, 0, RETURN_MASK_ALL);
 
   /* Process '-ix' and '-iex' options early.  */
   for (i = 0; VEC_iterate (cmdarg_s, cmdarg_vec, i, cmdarg_p); i++)
     switch (cmdarg_p->type)
     {
       case CMDARG_INIT_FILE:
-        catch_command_errors (source_script, cmdarg_p->string,
-                             !batch_flag, RETURN_MASK_ALL);
+        catch_command_errors_const (source_script, cmdarg_p->string,
+                                   !batch_flag, RETURN_MASK_ALL);
        break;
       case CMDARG_INIT_COMMAND:
         catch_command_errors (execute_command, cmdarg_p->string,
@@ -1006,8 +1008,8 @@ captured_main (void *data)
        {
          auto_load_local_gdbinit_loaded = 1;
 
-         catch_command_errors (source_script, local_gdbinit, 0,
-                               RETURN_MASK_ALL);
+         catch_command_errors_const (source_script, local_gdbinit, 0,
+                                     RETURN_MASK_ALL);
        }
     }
 
@@ -1024,8 +1026,8 @@ captured_main (void *data)
     switch (cmdarg_p->type)
     {
       case CMDARG_FILE:
-        catch_command_errors (source_script, cmdarg_p->string,
-                             !batch_flag, RETURN_MASK_ALL);
+        catch_command_errors_const (source_script, cmdarg_p->string,
+                                   !batch_flag, RETURN_MASK_ALL);
        break;
       case CMDARG_COMMAND:
         catch_command_errors (execute_command, cmdarg_p->string,
@@ -1075,9 +1077,9 @@ gdb_main (struct captured_main_args *args)
 static void
 print_gdb_help (struct ui_file *stream)
 {
-  char *system_gdbinit;
-  char *home_gdbinit;
-  char *local_gdbinit;
+  const char *system_gdbinit;
+  const char *home_gdbinit;
+  const char *local_gdbinit;
 
   get_init_files (&system_gdbinit, &home_gdbinit, &local_gdbinit);