xref: /dflybsd-src/contrib/gdb-7/gdb/auto-load.c (revision de8e141f24382815c10a4012d209bbbf7abf1112)
1*ef5ccd6cSJohn Marino /* GDB routines for supporting auto-loaded scripts.
2*ef5ccd6cSJohn Marino 
3*ef5ccd6cSJohn Marino    Copyright (C) 2012-2013 Free Software Foundation, Inc.
4*ef5ccd6cSJohn Marino 
5*ef5ccd6cSJohn Marino    This file is part of GDB.
6*ef5ccd6cSJohn Marino 
7*ef5ccd6cSJohn Marino    This program is free software; you can redistribute it and/or modify
8*ef5ccd6cSJohn Marino    it under the terms of the GNU General Public License as published by
9*ef5ccd6cSJohn Marino    the Free Software Foundation; either version 3 of the License, or
10*ef5ccd6cSJohn Marino    (at your option) any later version.
11*ef5ccd6cSJohn Marino 
12*ef5ccd6cSJohn Marino    This program is distributed in the hope that it will be useful,
13*ef5ccd6cSJohn Marino    but WITHOUT ANY WARRANTY; without even the implied warranty of
14*ef5ccd6cSJohn Marino    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15*ef5ccd6cSJohn Marino    GNU General Public License for more details.
16*ef5ccd6cSJohn Marino 
17*ef5ccd6cSJohn Marino    You should have received a copy of the GNU General Public License
18*ef5ccd6cSJohn Marino    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
19*ef5ccd6cSJohn Marino 
20*ef5ccd6cSJohn Marino #include "defs.h"
21*ef5ccd6cSJohn Marino #include "auto-load.h"
22*ef5ccd6cSJohn Marino #include "progspace.h"
23*ef5ccd6cSJohn Marino #include "python/python.h"
24*ef5ccd6cSJohn Marino #include "gdb_regex.h"
25*ef5ccd6cSJohn Marino #include "ui-out.h"
26*ef5ccd6cSJohn Marino #include "filenames.h"
27*ef5ccd6cSJohn Marino #include "command.h"
28*ef5ccd6cSJohn Marino #include "observer.h"
29*ef5ccd6cSJohn Marino #include "objfiles.h"
30*ef5ccd6cSJohn Marino #include "exceptions.h"
31*ef5ccd6cSJohn Marino #include "cli/cli-script.h"
32*ef5ccd6cSJohn Marino #include "gdbcmd.h"
33*ef5ccd6cSJohn Marino #include "cli/cli-decode.h"
34*ef5ccd6cSJohn Marino #include "cli/cli-setshow.h"
35*ef5ccd6cSJohn Marino #include "gdb_vecs.h"
36*ef5ccd6cSJohn Marino #include "readline/tilde.h"
37*ef5ccd6cSJohn Marino #include "completer.h"
38*ef5ccd6cSJohn Marino #include "observer.h"
39*ef5ccd6cSJohn Marino #include "fnmatch.h"
40*ef5ccd6cSJohn Marino #include "top.h"
41*ef5ccd6cSJohn Marino 
42*ef5ccd6cSJohn Marino /* The suffix of per-objfile scripts to auto-load as non-Python command files.
43*ef5ccd6cSJohn Marino    E.g. When the program loads libfoo.so, look for libfoo-gdb.gdb.  */
44*ef5ccd6cSJohn Marino #define GDB_AUTO_FILE_NAME "-gdb.gdb"
45*ef5ccd6cSJohn Marino 
46*ef5ccd6cSJohn Marino static void source_gdb_script_for_objfile (struct objfile *objfile, FILE *file,
47*ef5ccd6cSJohn Marino 					   const char *filename);
48*ef5ccd6cSJohn Marino 
49*ef5ccd6cSJohn Marino /* Value of the 'set debug auto-load' configuration variable.  */
50*ef5ccd6cSJohn Marino static int debug_auto_load = 0;
51*ef5ccd6cSJohn Marino 
52*ef5ccd6cSJohn Marino /* "show" command for the debug_auto_load configuration variable.  */
53*ef5ccd6cSJohn Marino 
54*ef5ccd6cSJohn Marino static void
show_debug_auto_load(struct ui_file * file,int from_tty,struct cmd_list_element * c,const char * value)55*ef5ccd6cSJohn Marino show_debug_auto_load (struct ui_file *file, int from_tty,
56*ef5ccd6cSJohn Marino 		      struct cmd_list_element *c, const char *value)
57*ef5ccd6cSJohn Marino {
58*ef5ccd6cSJohn Marino   fprintf_filtered (file, _("Debugging output for files "
59*ef5ccd6cSJohn Marino 			    "of 'set auto-load ...' is %s.\n"),
60*ef5ccd6cSJohn Marino 		    value);
61*ef5ccd6cSJohn Marino }
62*ef5ccd6cSJohn Marino 
63*ef5ccd6cSJohn Marino /* User-settable option to enable/disable auto-loading of GDB_AUTO_FILE_NAME
64*ef5ccd6cSJohn Marino    scripts:
65*ef5ccd6cSJohn Marino    set auto-load gdb-scripts on|off
66*ef5ccd6cSJohn Marino    This is true if we should auto-load associated scripts when an objfile
67*ef5ccd6cSJohn Marino    is opened, false otherwise.  */
68*ef5ccd6cSJohn Marino static int auto_load_gdb_scripts = 1;
69*ef5ccd6cSJohn Marino 
70*ef5ccd6cSJohn Marino /* "show" command for the auto_load_gdb_scripts configuration variable.  */
71*ef5ccd6cSJohn Marino 
72*ef5ccd6cSJohn Marino static void
show_auto_load_gdb_scripts(struct ui_file * file,int from_tty,struct cmd_list_element * c,const char * value)73*ef5ccd6cSJohn Marino show_auto_load_gdb_scripts (struct ui_file *file, int from_tty,
74*ef5ccd6cSJohn Marino 			    struct cmd_list_element *c, const char *value)
75*ef5ccd6cSJohn Marino {
76*ef5ccd6cSJohn Marino   fprintf_filtered (file, _("Auto-loading of canned sequences of commands "
77*ef5ccd6cSJohn Marino 			    "scripts is %s.\n"),
78*ef5ccd6cSJohn Marino 		    value);
79*ef5ccd6cSJohn Marino }
80*ef5ccd6cSJohn Marino 
81*ef5ccd6cSJohn Marino /* Internal-use flag to enable/disable auto-loading.
82*ef5ccd6cSJohn Marino    This is true if we should auto-load python code when an objfile is opened,
83*ef5ccd6cSJohn Marino    false otherwise.
84*ef5ccd6cSJohn Marino 
85*ef5ccd6cSJohn Marino    Both auto_load_scripts && global_auto_load must be true to enable
86*ef5ccd6cSJohn Marino    auto-loading.
87*ef5ccd6cSJohn Marino 
88*ef5ccd6cSJohn Marino    This flag exists to facilitate deferring auto-loading during start-up
89*ef5ccd6cSJohn Marino    until after ./.gdbinit has been read; it may augment the search directories
90*ef5ccd6cSJohn Marino    used to find the scripts.  */
91*ef5ccd6cSJohn Marino int global_auto_load = 1;
92*ef5ccd6cSJohn Marino 
93*ef5ccd6cSJohn Marino /* Auto-load .gdbinit file from the current directory?  */
94*ef5ccd6cSJohn Marino int auto_load_local_gdbinit = 1;
95*ef5ccd6cSJohn Marino 
96*ef5ccd6cSJohn Marino /* Absolute pathname to the current directory .gdbinit, if it exists.  */
97*ef5ccd6cSJohn Marino char *auto_load_local_gdbinit_pathname = NULL;
98*ef5ccd6cSJohn Marino 
99*ef5ccd6cSJohn Marino /* Boolean value if AUTO_LOAD_LOCAL_GDBINIT_PATHNAME has been loaded.  */
100*ef5ccd6cSJohn Marino int auto_load_local_gdbinit_loaded = 0;
101*ef5ccd6cSJohn Marino 
102*ef5ccd6cSJohn Marino /* "show" command for the auto_load_local_gdbinit configuration variable.  */
103*ef5ccd6cSJohn Marino 
104*ef5ccd6cSJohn Marino static void
show_auto_load_local_gdbinit(struct ui_file * file,int from_tty,struct cmd_list_element * c,const char * value)105*ef5ccd6cSJohn Marino show_auto_load_local_gdbinit (struct ui_file *file, int from_tty,
106*ef5ccd6cSJohn Marino 			      struct cmd_list_element *c, const char *value)
107*ef5ccd6cSJohn Marino {
108*ef5ccd6cSJohn Marino   fprintf_filtered (file, _("Auto-loading of .gdbinit script from current "
109*ef5ccd6cSJohn Marino 			    "directory is %s.\n"),
110*ef5ccd6cSJohn Marino 		    value);
111*ef5ccd6cSJohn Marino }
112*ef5ccd6cSJohn Marino 
113*ef5ccd6cSJohn Marino /* Directory list from which to load auto-loaded scripts.  It is not checked
114*ef5ccd6cSJohn Marino    for absolute paths but they are strongly recommended.  It is initialized by
115*ef5ccd6cSJohn Marino    _initialize_auto_load.  */
116*ef5ccd6cSJohn Marino static char *auto_load_dir;
117*ef5ccd6cSJohn Marino 
118*ef5ccd6cSJohn Marino /* "set" command for the auto_load_dir configuration variable.  */
119*ef5ccd6cSJohn Marino 
120*ef5ccd6cSJohn Marino static void
set_auto_load_dir(char * args,int from_tty,struct cmd_list_element * c)121*ef5ccd6cSJohn Marino set_auto_load_dir (char *args, int from_tty, struct cmd_list_element *c)
122*ef5ccd6cSJohn Marino {
123*ef5ccd6cSJohn Marino   /* Setting the variable to "" resets it to the compile time defaults.  */
124*ef5ccd6cSJohn Marino   if (auto_load_dir[0] == '\0')
125*ef5ccd6cSJohn Marino     {
126*ef5ccd6cSJohn Marino       xfree (auto_load_dir);
127*ef5ccd6cSJohn Marino       auto_load_dir = xstrdup (AUTO_LOAD_DIR);
128*ef5ccd6cSJohn Marino     }
129*ef5ccd6cSJohn Marino }
130*ef5ccd6cSJohn Marino 
131*ef5ccd6cSJohn Marino /* "show" command for the auto_load_dir configuration variable.  */
132*ef5ccd6cSJohn Marino 
133*ef5ccd6cSJohn Marino static void
show_auto_load_dir(struct ui_file * file,int from_tty,struct cmd_list_element * c,const char * value)134*ef5ccd6cSJohn Marino show_auto_load_dir (struct ui_file *file, int from_tty,
135*ef5ccd6cSJohn Marino 		    struct cmd_list_element *c, const char *value)
136*ef5ccd6cSJohn Marino {
137*ef5ccd6cSJohn Marino   fprintf_filtered (file, _("List of directories from which to load "
138*ef5ccd6cSJohn Marino 			    "auto-loaded scripts is %s.\n"),
139*ef5ccd6cSJohn Marino 		    value);
140*ef5ccd6cSJohn Marino }
141*ef5ccd6cSJohn Marino 
142*ef5ccd6cSJohn Marino /* Directory list safe to hold auto-loaded files.  It is not checked for
143*ef5ccd6cSJohn Marino    absolute paths but they are strongly recommended.  It is initialized by
144*ef5ccd6cSJohn Marino    _initialize_auto_load.  */
145*ef5ccd6cSJohn Marino static char *auto_load_safe_path;
146*ef5ccd6cSJohn Marino 
147*ef5ccd6cSJohn Marino /* Vector of directory elements of AUTO_LOAD_SAFE_PATH with each one normalized
148*ef5ccd6cSJohn Marino    by tilde_expand and possibly each entries has added its gdb_realpath
149*ef5ccd6cSJohn Marino    counterpart.  */
VEC(char_ptr)150*ef5ccd6cSJohn Marino static VEC (char_ptr) *auto_load_safe_path_vec;
151*ef5ccd6cSJohn Marino 
152*ef5ccd6cSJohn Marino /* Expand $datadir and $debugdir in STRING according to the rules of
153*ef5ccd6cSJohn Marino    substitute_path_component.  Return vector from dirnames_to_char_ptr_vec,
154*ef5ccd6cSJohn Marino    this vector must be freed by free_char_ptr_vec by the caller.  */
155*ef5ccd6cSJohn Marino 
156*ef5ccd6cSJohn Marino static VEC (char_ptr) *
157*ef5ccd6cSJohn Marino auto_load_expand_dir_vars (const char *string)
158*ef5ccd6cSJohn Marino {
159*ef5ccd6cSJohn Marino   VEC (char_ptr) *dir_vec;
160*ef5ccd6cSJohn Marino   char *s;
161*ef5ccd6cSJohn Marino 
162*ef5ccd6cSJohn Marino   s = xstrdup (string);
163*ef5ccd6cSJohn Marino   substitute_path_component (&s, "$datadir", gdb_datadir);
164*ef5ccd6cSJohn Marino   substitute_path_component (&s, "$debugdir", debug_file_directory);
165*ef5ccd6cSJohn Marino 
166*ef5ccd6cSJohn Marino   if (debug_auto_load && strcmp (s, string) != 0)
167*ef5ccd6cSJohn Marino     fprintf_unfiltered (gdb_stdlog,
168*ef5ccd6cSJohn Marino 			_("auto-load: Expanded $-variables to \"%s\".\n"), s);
169*ef5ccd6cSJohn Marino 
170*ef5ccd6cSJohn Marino   dir_vec = dirnames_to_char_ptr_vec (s);
171*ef5ccd6cSJohn Marino   xfree(s);
172*ef5ccd6cSJohn Marino 
173*ef5ccd6cSJohn Marino   return dir_vec;
174*ef5ccd6cSJohn Marino }
175*ef5ccd6cSJohn Marino 
176*ef5ccd6cSJohn Marino /* Update auto_load_safe_path_vec from current AUTO_LOAD_SAFE_PATH.  */
177*ef5ccd6cSJohn Marino 
178*ef5ccd6cSJohn Marino static void
auto_load_safe_path_vec_update(void)179*ef5ccd6cSJohn Marino auto_load_safe_path_vec_update (void)
180*ef5ccd6cSJohn Marino {
181*ef5ccd6cSJohn Marino   unsigned len;
182*ef5ccd6cSJohn Marino   int ix;
183*ef5ccd6cSJohn Marino 
184*ef5ccd6cSJohn Marino   if (debug_auto_load)
185*ef5ccd6cSJohn Marino     fprintf_unfiltered (gdb_stdlog,
186*ef5ccd6cSJohn Marino 			_("auto-load: Updating directories of \"%s\".\n"),
187*ef5ccd6cSJohn Marino 			auto_load_safe_path);
188*ef5ccd6cSJohn Marino 
189*ef5ccd6cSJohn Marino   free_char_ptr_vec (auto_load_safe_path_vec);
190*ef5ccd6cSJohn Marino 
191*ef5ccd6cSJohn Marino   auto_load_safe_path_vec = auto_load_expand_dir_vars (auto_load_safe_path);
192*ef5ccd6cSJohn Marino   len = VEC_length (char_ptr, auto_load_safe_path_vec);
193*ef5ccd6cSJohn Marino 
194*ef5ccd6cSJohn Marino   /* Apply tilde_expand and gdb_realpath to each AUTO_LOAD_SAFE_PATH_VEC
195*ef5ccd6cSJohn Marino      element.  */
196*ef5ccd6cSJohn Marino   for (ix = 0; ix < len; ix++)
197*ef5ccd6cSJohn Marino     {
198*ef5ccd6cSJohn Marino       char *dir = VEC_index (char_ptr, auto_load_safe_path_vec, ix);
199*ef5ccd6cSJohn Marino       char *expanded = tilde_expand (dir);
200*ef5ccd6cSJohn Marino       char *real_path = gdb_realpath (expanded);
201*ef5ccd6cSJohn Marino 
202*ef5ccd6cSJohn Marino       /* Ensure the current entry is at least tilde_expand-ed.  */
203*ef5ccd6cSJohn Marino       VEC_replace (char_ptr, auto_load_safe_path_vec, ix, expanded);
204*ef5ccd6cSJohn Marino 
205*ef5ccd6cSJohn Marino       if (debug_auto_load)
206*ef5ccd6cSJohn Marino 	{
207*ef5ccd6cSJohn Marino 	  if (strcmp (expanded, dir) == 0)
208*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog,
209*ef5ccd6cSJohn Marino 				_("auto-load: Using directory \"%s\".\n"),
210*ef5ccd6cSJohn Marino 				expanded);
211*ef5ccd6cSJohn Marino 	  else
212*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog,
213*ef5ccd6cSJohn Marino 				_("auto-load: Resolved directory \"%s\" "
214*ef5ccd6cSJohn Marino 				  "as \"%s\".\n"),
215*ef5ccd6cSJohn Marino 				dir, expanded);
216*ef5ccd6cSJohn Marino 	}
217*ef5ccd6cSJohn Marino       xfree (dir);
218*ef5ccd6cSJohn Marino 
219*ef5ccd6cSJohn Marino       /* If gdb_realpath returns a different content, append it.  */
220*ef5ccd6cSJohn Marino       if (strcmp (real_path, expanded) == 0)
221*ef5ccd6cSJohn Marino 	xfree (real_path);
222*ef5ccd6cSJohn Marino       else
223*ef5ccd6cSJohn Marino 	{
224*ef5ccd6cSJohn Marino 	  VEC_safe_push (char_ptr, auto_load_safe_path_vec, real_path);
225*ef5ccd6cSJohn Marino 
226*ef5ccd6cSJohn Marino 	  if (debug_auto_load)
227*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog,
228*ef5ccd6cSJohn Marino 				_("auto-load: And canonicalized as \"%s\".\n"),
229*ef5ccd6cSJohn Marino 				real_path);
230*ef5ccd6cSJohn Marino 	}
231*ef5ccd6cSJohn Marino     }
232*ef5ccd6cSJohn Marino }
233*ef5ccd6cSJohn Marino 
234*ef5ccd6cSJohn Marino /* Variable gdb_datadir has been set.  Update content depending on $datadir.  */
235*ef5ccd6cSJohn Marino 
236*ef5ccd6cSJohn Marino static void
auto_load_gdb_datadir_changed(void)237*ef5ccd6cSJohn Marino auto_load_gdb_datadir_changed (void)
238*ef5ccd6cSJohn Marino {
239*ef5ccd6cSJohn Marino   auto_load_safe_path_vec_update ();
240*ef5ccd6cSJohn Marino }
241*ef5ccd6cSJohn Marino 
242*ef5ccd6cSJohn Marino /* "set" command for the auto_load_safe_path configuration variable.  */
243*ef5ccd6cSJohn Marino 
244*ef5ccd6cSJohn Marino static void
set_auto_load_safe_path(char * args,int from_tty,struct cmd_list_element * c)245*ef5ccd6cSJohn Marino set_auto_load_safe_path (char *args, int from_tty, struct cmd_list_element *c)
246*ef5ccd6cSJohn Marino {
247*ef5ccd6cSJohn Marino   /* Setting the variable to "" resets it to the compile time defaults.  */
248*ef5ccd6cSJohn Marino   if (auto_load_safe_path[0] == '\0')
249*ef5ccd6cSJohn Marino     {
250*ef5ccd6cSJohn Marino       xfree (auto_load_safe_path);
251*ef5ccd6cSJohn Marino       auto_load_safe_path = xstrdup (AUTO_LOAD_SAFE_PATH);
252*ef5ccd6cSJohn Marino     }
253*ef5ccd6cSJohn Marino 
254*ef5ccd6cSJohn Marino   auto_load_safe_path_vec_update ();
255*ef5ccd6cSJohn Marino }
256*ef5ccd6cSJohn Marino 
257*ef5ccd6cSJohn Marino /* "show" command for the auto_load_safe_path configuration variable.  */
258*ef5ccd6cSJohn Marino 
259*ef5ccd6cSJohn Marino static void
show_auto_load_safe_path(struct ui_file * file,int from_tty,struct cmd_list_element * c,const char * value)260*ef5ccd6cSJohn Marino show_auto_load_safe_path (struct ui_file *file, int from_tty,
261*ef5ccd6cSJohn Marino 			  struct cmd_list_element *c, const char *value)
262*ef5ccd6cSJohn Marino {
263*ef5ccd6cSJohn Marino   const char *cs;
264*ef5ccd6cSJohn Marino 
265*ef5ccd6cSJohn Marino   /* Check if user has entered either "/" or for example ":".
266*ef5ccd6cSJohn Marino      But while more complicate content like ":/foo" would still also
267*ef5ccd6cSJohn Marino      permit any location do not hide those.  */
268*ef5ccd6cSJohn Marino 
269*ef5ccd6cSJohn Marino   for (cs = value; *cs && (*cs == DIRNAME_SEPARATOR || IS_DIR_SEPARATOR (*cs));
270*ef5ccd6cSJohn Marino        cs++);
271*ef5ccd6cSJohn Marino   if (*cs == 0)
272*ef5ccd6cSJohn Marino     fprintf_filtered (file, _("Auto-load files are safe to load from any "
273*ef5ccd6cSJohn Marino 			      "directory.\n"));
274*ef5ccd6cSJohn Marino   else
275*ef5ccd6cSJohn Marino     fprintf_filtered (file, _("List of directories from which it is safe to "
276*ef5ccd6cSJohn Marino 			      "auto-load files is %s.\n"),
277*ef5ccd6cSJohn Marino 		      value);
278*ef5ccd6cSJohn Marino }
279*ef5ccd6cSJohn Marino 
280*ef5ccd6cSJohn Marino /* "add-auto-load-safe-path" command for the auto_load_safe_path configuration
281*ef5ccd6cSJohn Marino    variable.  */
282*ef5ccd6cSJohn Marino 
283*ef5ccd6cSJohn Marino static void
add_auto_load_safe_path(char * args,int from_tty)284*ef5ccd6cSJohn Marino add_auto_load_safe_path (char *args, int from_tty)
285*ef5ccd6cSJohn Marino {
286*ef5ccd6cSJohn Marino   char *s;
287*ef5ccd6cSJohn Marino 
288*ef5ccd6cSJohn Marino   if (args == NULL || *args == 0)
289*ef5ccd6cSJohn Marino     error (_("\
290*ef5ccd6cSJohn Marino Directory argument required.\n\
291*ef5ccd6cSJohn Marino Use 'set auto-load safe-path /' for disabling the auto-load safe-path security.\
292*ef5ccd6cSJohn Marino "));
293*ef5ccd6cSJohn Marino 
294*ef5ccd6cSJohn Marino   s = xstrprintf ("%s%c%s", auto_load_safe_path, DIRNAME_SEPARATOR, args);
295*ef5ccd6cSJohn Marino   xfree (auto_load_safe_path);
296*ef5ccd6cSJohn Marino   auto_load_safe_path = s;
297*ef5ccd6cSJohn Marino 
298*ef5ccd6cSJohn Marino   auto_load_safe_path_vec_update ();
299*ef5ccd6cSJohn Marino }
300*ef5ccd6cSJohn Marino 
301*ef5ccd6cSJohn Marino /* Implementation for filename_is_in_pattern overwriting the caller's FILENAME
302*ef5ccd6cSJohn Marino    and PATTERN.  */
303*ef5ccd6cSJohn Marino 
304*ef5ccd6cSJohn Marino static int
filename_is_in_pattern_1(char * filename,char * pattern)305*ef5ccd6cSJohn Marino filename_is_in_pattern_1 (char *filename, char *pattern)
306*ef5ccd6cSJohn Marino {
307*ef5ccd6cSJohn Marino   size_t pattern_len = strlen (pattern);
308*ef5ccd6cSJohn Marino   size_t filename_len = strlen (filename);
309*ef5ccd6cSJohn Marino 
310*ef5ccd6cSJohn Marino   if (debug_auto_load)
311*ef5ccd6cSJohn Marino     fprintf_unfiltered (gdb_stdlog, _("auto-load: Matching file \"%s\" "
312*ef5ccd6cSJohn Marino 				      "to pattern \"%s\"\n"),
313*ef5ccd6cSJohn Marino 			filename, pattern);
314*ef5ccd6cSJohn Marino 
315*ef5ccd6cSJohn Marino   /* Trim trailing slashes ("/") from PATTERN.  Even for "d:\" paths as
316*ef5ccd6cSJohn Marino      trailing slashes are trimmed also from FILENAME it still matches
317*ef5ccd6cSJohn Marino      correctly.  */
318*ef5ccd6cSJohn Marino   while (pattern_len && IS_DIR_SEPARATOR (pattern[pattern_len - 1]))
319*ef5ccd6cSJohn Marino     pattern_len--;
320*ef5ccd6cSJohn Marino   pattern[pattern_len] = '\0';
321*ef5ccd6cSJohn Marino 
322*ef5ccd6cSJohn Marino   /* Ensure auto_load_safe_path "/" matches any FILENAME.  On MS-Windows
323*ef5ccd6cSJohn Marino      platform FILENAME even after gdb_realpath does not have to start with
324*ef5ccd6cSJohn Marino      IS_DIR_SEPARATOR character, such as the 'C:\x.exe' filename.  */
325*ef5ccd6cSJohn Marino   if (pattern_len == 0)
326*ef5ccd6cSJohn Marino     {
327*ef5ccd6cSJohn Marino       if (debug_auto_load)
328*ef5ccd6cSJohn Marino 	fprintf_unfiltered (gdb_stdlog,
329*ef5ccd6cSJohn Marino 			    _("auto-load: Matched - empty pattern\n"));
330*ef5ccd6cSJohn Marino       return 1;
331*ef5ccd6cSJohn Marino     }
332*ef5ccd6cSJohn Marino 
333*ef5ccd6cSJohn Marino   for (;;)
334*ef5ccd6cSJohn Marino     {
335*ef5ccd6cSJohn Marino       /* Trim trailing slashes ("/").  PATTERN also has slashes trimmed the
336*ef5ccd6cSJohn Marino          same way so they will match.  */
337*ef5ccd6cSJohn Marino       while (filename_len && IS_DIR_SEPARATOR (filename[filename_len - 1]))
338*ef5ccd6cSJohn Marino 	filename_len--;
339*ef5ccd6cSJohn Marino       filename[filename_len] = '\0';
340*ef5ccd6cSJohn Marino       if (filename_len == 0)
341*ef5ccd6cSJohn Marino 	{
342*ef5ccd6cSJohn Marino 	  if (debug_auto_load)
343*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog,
344*ef5ccd6cSJohn Marino 				_("auto-load: Not matched - pattern \"%s\".\n"),
345*ef5ccd6cSJohn Marino 				pattern);
346*ef5ccd6cSJohn Marino 	  return 0;
347*ef5ccd6cSJohn Marino 	}
348*ef5ccd6cSJohn Marino 
349*ef5ccd6cSJohn Marino       if (gdb_filename_fnmatch (pattern, filename, FNM_FILE_NAME | FNM_NOESCAPE)
350*ef5ccd6cSJohn Marino 	  == 0)
351*ef5ccd6cSJohn Marino 	{
352*ef5ccd6cSJohn Marino 	  if (debug_auto_load)
353*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog, _("auto-load: Matched - file "
354*ef5ccd6cSJohn Marino 					      "\"%s\" to pattern \"%s\".\n"),
355*ef5ccd6cSJohn Marino 				filename, pattern);
356*ef5ccd6cSJohn Marino 	  return 1;
357*ef5ccd6cSJohn Marino 	}
358*ef5ccd6cSJohn Marino 
359*ef5ccd6cSJohn Marino       /* Trim trailing FILENAME component.  */
360*ef5ccd6cSJohn Marino       while (filename_len > 0 && !IS_DIR_SEPARATOR (filename[filename_len - 1]))
361*ef5ccd6cSJohn Marino 	filename_len--;
362*ef5ccd6cSJohn Marino     }
363*ef5ccd6cSJohn Marino }
364*ef5ccd6cSJohn Marino 
365*ef5ccd6cSJohn Marino /* Return 1 if FILENAME matches PATTERN or if FILENAME resides in
366*ef5ccd6cSJohn Marino    a subdirectory of a directory that matches PATTERN.  Return 0 otherwise.
367*ef5ccd6cSJohn Marino    gdb_realpath normalization is never done here.  */
368*ef5ccd6cSJohn Marino 
369*ef5ccd6cSJohn Marino static ATTRIBUTE_PURE int
filename_is_in_pattern(const char * filename,const char * pattern)370*ef5ccd6cSJohn Marino filename_is_in_pattern (const char *filename, const char *pattern)
371*ef5ccd6cSJohn Marino {
372*ef5ccd6cSJohn Marino   char *filename_copy, *pattern_copy;
373*ef5ccd6cSJohn Marino 
374*ef5ccd6cSJohn Marino   filename_copy = alloca (strlen (filename) + 1);
375*ef5ccd6cSJohn Marino   strcpy (filename_copy, filename);
376*ef5ccd6cSJohn Marino   pattern_copy = alloca (strlen (pattern) + 1);
377*ef5ccd6cSJohn Marino   strcpy (pattern_copy, pattern);
378*ef5ccd6cSJohn Marino 
379*ef5ccd6cSJohn Marino   return filename_is_in_pattern_1 (filename_copy, pattern_copy);
380*ef5ccd6cSJohn Marino }
381*ef5ccd6cSJohn Marino 
382*ef5ccd6cSJohn Marino /* Return 1 if FILENAME belongs to one of directory components of
383*ef5ccd6cSJohn Marino    AUTO_LOAD_SAFE_PATH_VEC.  Return 0 otherwise.
384*ef5ccd6cSJohn Marino    auto_load_safe_path_vec_update is never called.
385*ef5ccd6cSJohn Marino    *FILENAME_REALP may be updated by gdb_realpath of FILENAME - it has to be
386*ef5ccd6cSJohn Marino    freed by the caller.  */
387*ef5ccd6cSJohn Marino 
388*ef5ccd6cSJohn Marino static int
filename_is_in_auto_load_safe_path_vec(const char * filename,char ** filename_realp)389*ef5ccd6cSJohn Marino filename_is_in_auto_load_safe_path_vec (const char *filename,
390*ef5ccd6cSJohn Marino 					char **filename_realp)
391*ef5ccd6cSJohn Marino {
392*ef5ccd6cSJohn Marino   char *pattern;
393*ef5ccd6cSJohn Marino   int ix;
394*ef5ccd6cSJohn Marino 
395*ef5ccd6cSJohn Marino   for (ix = 0; VEC_iterate (char_ptr, auto_load_safe_path_vec, ix, pattern);
396*ef5ccd6cSJohn Marino        ++ix)
397*ef5ccd6cSJohn Marino     if (*filename_realp == NULL && filename_is_in_pattern (filename, pattern))
398*ef5ccd6cSJohn Marino       break;
399*ef5ccd6cSJohn Marino 
400*ef5ccd6cSJohn Marino   if (pattern == NULL)
401*ef5ccd6cSJohn Marino     {
402*ef5ccd6cSJohn Marino       if (*filename_realp == NULL)
403*ef5ccd6cSJohn Marino 	{
404*ef5ccd6cSJohn Marino 	  *filename_realp = gdb_realpath (filename);
405*ef5ccd6cSJohn Marino 	  if (debug_auto_load && strcmp (*filename_realp, filename) != 0)
406*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog,
407*ef5ccd6cSJohn Marino 				_("auto-load: Resolved "
408*ef5ccd6cSJohn Marino 				  "file \"%s\" as \"%s\".\n"),
409*ef5ccd6cSJohn Marino 				filename, *filename_realp);
410*ef5ccd6cSJohn Marino 	}
411*ef5ccd6cSJohn Marino 
412*ef5ccd6cSJohn Marino       if (strcmp (*filename_realp, filename) != 0)
413*ef5ccd6cSJohn Marino 	for (ix = 0;
414*ef5ccd6cSJohn Marino 	     VEC_iterate (char_ptr, auto_load_safe_path_vec, ix, pattern); ++ix)
415*ef5ccd6cSJohn Marino 	  if (filename_is_in_pattern (*filename_realp, pattern))
416*ef5ccd6cSJohn Marino 	    break;
417*ef5ccd6cSJohn Marino     }
418*ef5ccd6cSJohn Marino 
419*ef5ccd6cSJohn Marino   if (pattern != NULL)
420*ef5ccd6cSJohn Marino     {
421*ef5ccd6cSJohn Marino       if (debug_auto_load)
422*ef5ccd6cSJohn Marino 	fprintf_unfiltered (gdb_stdlog, _("auto-load: File \"%s\" matches "
423*ef5ccd6cSJohn Marino 					  "directory \"%s\".\n"),
424*ef5ccd6cSJohn Marino 			    filename, pattern);
425*ef5ccd6cSJohn Marino       return 1;
426*ef5ccd6cSJohn Marino     }
427*ef5ccd6cSJohn Marino 
428*ef5ccd6cSJohn Marino   return 0;
429*ef5ccd6cSJohn Marino }
430*ef5ccd6cSJohn Marino 
431*ef5ccd6cSJohn Marino /* Return 1 if FILENAME is located in one of the directories of
432*ef5ccd6cSJohn Marino    AUTO_LOAD_SAFE_PATH.  Otherwise call warning and return 0.  FILENAME does
433*ef5ccd6cSJohn Marino    not have to be an absolute path.
434*ef5ccd6cSJohn Marino 
435*ef5ccd6cSJohn Marino    Existence of FILENAME is not checked.  Function will still give a warning
436*ef5ccd6cSJohn Marino    even if the caller would quietly skip non-existing file in unsafe
437*ef5ccd6cSJohn Marino    directory.  */
438*ef5ccd6cSJohn Marino 
439*ef5ccd6cSJohn Marino int
file_is_auto_load_safe(const char * filename,const char * debug_fmt,...)440*ef5ccd6cSJohn Marino file_is_auto_load_safe (const char *filename, const char *debug_fmt, ...)
441*ef5ccd6cSJohn Marino {
442*ef5ccd6cSJohn Marino   char *filename_real = NULL;
443*ef5ccd6cSJohn Marino   struct cleanup *back_to;
444*ef5ccd6cSJohn Marino   static int advice_printed = 0;
445*ef5ccd6cSJohn Marino 
446*ef5ccd6cSJohn Marino   if (debug_auto_load)
447*ef5ccd6cSJohn Marino     {
448*ef5ccd6cSJohn Marino       va_list debug_args;
449*ef5ccd6cSJohn Marino 
450*ef5ccd6cSJohn Marino       va_start (debug_args, debug_fmt);
451*ef5ccd6cSJohn Marino       vfprintf_unfiltered (gdb_stdlog, debug_fmt, debug_args);
452*ef5ccd6cSJohn Marino       va_end (debug_args);
453*ef5ccd6cSJohn Marino     }
454*ef5ccd6cSJohn Marino 
455*ef5ccd6cSJohn Marino   back_to = make_cleanup (free_current_contents, &filename_real);
456*ef5ccd6cSJohn Marino 
457*ef5ccd6cSJohn Marino   if (filename_is_in_auto_load_safe_path_vec (filename, &filename_real))
458*ef5ccd6cSJohn Marino     {
459*ef5ccd6cSJohn Marino       do_cleanups (back_to);
460*ef5ccd6cSJohn Marino       return 1;
461*ef5ccd6cSJohn Marino     }
462*ef5ccd6cSJohn Marino 
463*ef5ccd6cSJohn Marino   auto_load_safe_path_vec_update ();
464*ef5ccd6cSJohn Marino   if (filename_is_in_auto_load_safe_path_vec (filename, &filename_real))
465*ef5ccd6cSJohn Marino     {
466*ef5ccd6cSJohn Marino       do_cleanups (back_to);
467*ef5ccd6cSJohn Marino       return 1;
468*ef5ccd6cSJohn Marino     }
469*ef5ccd6cSJohn Marino 
470*ef5ccd6cSJohn Marino   warning (_("File \"%s\" auto-loading has been declined by your "
471*ef5ccd6cSJohn Marino 	     "`auto-load safe-path' set to \"%s\"."),
472*ef5ccd6cSJohn Marino 	   filename_real, auto_load_safe_path);
473*ef5ccd6cSJohn Marino 
474*ef5ccd6cSJohn Marino   if (!advice_printed)
475*ef5ccd6cSJohn Marino     {
476*ef5ccd6cSJohn Marino       const char *homedir = getenv ("HOME");
477*ef5ccd6cSJohn Marino       char *homeinit;
478*ef5ccd6cSJohn Marino 
479*ef5ccd6cSJohn Marino       if (homedir == NULL)
480*ef5ccd6cSJohn Marino 	homedir = "$HOME";
481*ef5ccd6cSJohn Marino       homeinit = xstrprintf ("%s/%s", homedir, gdbinit);
482*ef5ccd6cSJohn Marino       make_cleanup (xfree, homeinit);
483*ef5ccd6cSJohn Marino 
484*ef5ccd6cSJohn Marino       printf_filtered (_("\
485*ef5ccd6cSJohn Marino To enable execution of this file add\n\
486*ef5ccd6cSJohn Marino \tadd-auto-load-safe-path %s\n\
487*ef5ccd6cSJohn Marino line to your configuration file \"%s\".\n\
488*ef5ccd6cSJohn Marino To completely disable this security protection add\n\
489*ef5ccd6cSJohn Marino \tset auto-load safe-path /\n\
490*ef5ccd6cSJohn Marino line to your configuration file \"%s\".\n\
491*ef5ccd6cSJohn Marino For more information about this security protection see the\n\
492*ef5ccd6cSJohn Marino \"Auto-loading safe path\" section in the GDB manual.  E.g., run from the shell:\n\
493*ef5ccd6cSJohn Marino \tinfo \"(gdb)Auto-loading safe path\"\n"),
494*ef5ccd6cSJohn Marino 		       filename_real, homeinit, homeinit);
495*ef5ccd6cSJohn Marino       advice_printed = 1;
496*ef5ccd6cSJohn Marino     }
497*ef5ccd6cSJohn Marino 
498*ef5ccd6cSJohn Marino   do_cleanups (back_to);
499*ef5ccd6cSJohn Marino   return 0;
500*ef5ccd6cSJohn Marino }
501*ef5ccd6cSJohn Marino 
502*ef5ccd6cSJohn Marino /* Definition of script language for GDB canned sequences of commands.  */
503*ef5ccd6cSJohn Marino 
504*ef5ccd6cSJohn Marino static const struct script_language script_language_gdb
505*ef5ccd6cSJohn Marino   = { GDB_AUTO_FILE_NAME, source_gdb_script_for_objfile };
506*ef5ccd6cSJohn Marino 
507*ef5ccd6cSJohn Marino static void
source_gdb_script_for_objfile(struct objfile * objfile,FILE * file,const char * filename)508*ef5ccd6cSJohn Marino source_gdb_script_for_objfile (struct objfile *objfile, FILE *file,
509*ef5ccd6cSJohn Marino 			       const char *filename)
510*ef5ccd6cSJohn Marino {
511*ef5ccd6cSJohn Marino   int is_safe;
512*ef5ccd6cSJohn Marino   struct auto_load_pspace_info *pspace_info;
513*ef5ccd6cSJohn Marino   volatile struct gdb_exception e;
514*ef5ccd6cSJohn Marino 
515*ef5ccd6cSJohn Marino   is_safe = file_is_auto_load_safe (filename, _("auto-load: Loading canned "
516*ef5ccd6cSJohn Marino 						"sequences of commands script "
517*ef5ccd6cSJohn Marino 						"\"%s\" for objfile \"%s\".\n"),
518*ef5ccd6cSJohn Marino 				    filename, objfile->name);
519*ef5ccd6cSJohn Marino 
520*ef5ccd6cSJohn Marino   /* Add this script to the hash table too so "info auto-load gdb-scripts"
521*ef5ccd6cSJohn Marino      can print it.  */
522*ef5ccd6cSJohn Marino   pspace_info = get_auto_load_pspace_data_for_loading (current_program_space);
523*ef5ccd6cSJohn Marino   maybe_add_script (pspace_info, is_safe, filename, filename,
524*ef5ccd6cSJohn Marino 		    &script_language_gdb);
525*ef5ccd6cSJohn Marino 
526*ef5ccd6cSJohn Marino   if (!is_safe)
527*ef5ccd6cSJohn Marino     return;
528*ef5ccd6cSJohn Marino 
529*ef5ccd6cSJohn Marino   TRY_CATCH (e, RETURN_MASK_ALL)
530*ef5ccd6cSJohn Marino     {
531*ef5ccd6cSJohn Marino       script_from_file (file, filename);
532*ef5ccd6cSJohn Marino     }
533*ef5ccd6cSJohn Marino   exception_print (gdb_stderr, e);
534*ef5ccd6cSJohn Marino }
535*ef5ccd6cSJohn Marino 
536*ef5ccd6cSJohn Marino /* For scripts specified in .debug_gdb_scripts, multiple objfiles may load
537*ef5ccd6cSJohn Marino    the same script.  There's no point in loading the script multiple times,
538*ef5ccd6cSJohn Marino    and there can be a lot of objfiles and scripts, so we keep track of scripts
539*ef5ccd6cSJohn Marino    loaded this way.  */
540*ef5ccd6cSJohn Marino 
541*ef5ccd6cSJohn Marino struct auto_load_pspace_info
542*ef5ccd6cSJohn Marino {
543*ef5ccd6cSJohn Marino   /* For each program space we keep track of loaded scripts.  */
544*ef5ccd6cSJohn Marino   struct htab *loaded_scripts;
545*ef5ccd6cSJohn Marino 
546*ef5ccd6cSJohn Marino   /* Non-zero if we've issued the warning about an auto-load script not being
547*ef5ccd6cSJohn Marino      found.  We only want to issue this warning once.  */
548*ef5ccd6cSJohn Marino   int script_not_found_warning_printed;
549*ef5ccd6cSJohn Marino };
550*ef5ccd6cSJohn Marino 
551*ef5ccd6cSJohn Marino /* Objects of this type are stored in the loaded script hash table.  */
552*ef5ccd6cSJohn Marino 
553*ef5ccd6cSJohn Marino struct loaded_script
554*ef5ccd6cSJohn Marino {
555*ef5ccd6cSJohn Marino   /* Name as provided by the objfile.  */
556*ef5ccd6cSJohn Marino   const char *name;
557*ef5ccd6cSJohn Marino 
558*ef5ccd6cSJohn Marino   /* Full path name or NULL if script wasn't found (or was otherwise
559*ef5ccd6cSJohn Marino      inaccessible).  */
560*ef5ccd6cSJohn Marino   const char *full_path;
561*ef5ccd6cSJohn Marino 
562*ef5ccd6cSJohn Marino   /* Non-zero if this script has been loaded.  */
563*ef5ccd6cSJohn Marino   int loaded;
564*ef5ccd6cSJohn Marino 
565*ef5ccd6cSJohn Marino   const struct script_language *language;
566*ef5ccd6cSJohn Marino };
567*ef5ccd6cSJohn Marino 
568*ef5ccd6cSJohn Marino /* Per-program-space data key.  */
569*ef5ccd6cSJohn Marino static const struct program_space_data *auto_load_pspace_data;
570*ef5ccd6cSJohn Marino 
571*ef5ccd6cSJohn Marino static void
auto_load_pspace_data_cleanup(struct program_space * pspace,void * arg)572*ef5ccd6cSJohn Marino auto_load_pspace_data_cleanup (struct program_space *pspace, void *arg)
573*ef5ccd6cSJohn Marino {
574*ef5ccd6cSJohn Marino   struct auto_load_pspace_info *info;
575*ef5ccd6cSJohn Marino 
576*ef5ccd6cSJohn Marino   info = program_space_data (pspace, auto_load_pspace_data);
577*ef5ccd6cSJohn Marino   if (info != NULL)
578*ef5ccd6cSJohn Marino     {
579*ef5ccd6cSJohn Marino       if (info->loaded_scripts)
580*ef5ccd6cSJohn Marino 	htab_delete (info->loaded_scripts);
581*ef5ccd6cSJohn Marino       xfree (info);
582*ef5ccd6cSJohn Marino     }
583*ef5ccd6cSJohn Marino }
584*ef5ccd6cSJohn Marino 
585*ef5ccd6cSJohn Marino /* Get the current autoload data.  If none is found yet, add it now.  This
586*ef5ccd6cSJohn Marino    function always returns a valid object.  */
587*ef5ccd6cSJohn Marino 
588*ef5ccd6cSJohn Marino static struct auto_load_pspace_info *
get_auto_load_pspace_data(struct program_space * pspace)589*ef5ccd6cSJohn Marino get_auto_load_pspace_data (struct program_space *pspace)
590*ef5ccd6cSJohn Marino {
591*ef5ccd6cSJohn Marino   struct auto_load_pspace_info *info;
592*ef5ccd6cSJohn Marino 
593*ef5ccd6cSJohn Marino   info = program_space_data (pspace, auto_load_pspace_data);
594*ef5ccd6cSJohn Marino   if (info == NULL)
595*ef5ccd6cSJohn Marino     {
596*ef5ccd6cSJohn Marino       info = XZALLOC (struct auto_load_pspace_info);
597*ef5ccd6cSJohn Marino       set_program_space_data (pspace, auto_load_pspace_data, info);
598*ef5ccd6cSJohn Marino     }
599*ef5ccd6cSJohn Marino 
600*ef5ccd6cSJohn Marino   return info;
601*ef5ccd6cSJohn Marino }
602*ef5ccd6cSJohn Marino 
603*ef5ccd6cSJohn Marino /* Hash function for the loaded script hash.  */
604*ef5ccd6cSJohn Marino 
605*ef5ccd6cSJohn Marino static hashval_t
hash_loaded_script_entry(const void * data)606*ef5ccd6cSJohn Marino hash_loaded_script_entry (const void *data)
607*ef5ccd6cSJohn Marino {
608*ef5ccd6cSJohn Marino   const struct loaded_script *e = data;
609*ef5ccd6cSJohn Marino 
610*ef5ccd6cSJohn Marino   return htab_hash_string (e->name) ^ htab_hash_pointer (e->language);
611*ef5ccd6cSJohn Marino }
612*ef5ccd6cSJohn Marino 
613*ef5ccd6cSJohn Marino /* Equality function for the loaded script hash.  */
614*ef5ccd6cSJohn Marino 
615*ef5ccd6cSJohn Marino static int
eq_loaded_script_entry(const void * a,const void * b)616*ef5ccd6cSJohn Marino eq_loaded_script_entry (const void *a, const void *b)
617*ef5ccd6cSJohn Marino {
618*ef5ccd6cSJohn Marino   const struct loaded_script *ea = a;
619*ef5ccd6cSJohn Marino   const struct loaded_script *eb = b;
620*ef5ccd6cSJohn Marino 
621*ef5ccd6cSJohn Marino   return strcmp (ea->name, eb->name) == 0 && ea->language == eb->language;
622*ef5ccd6cSJohn Marino }
623*ef5ccd6cSJohn Marino 
624*ef5ccd6cSJohn Marino /* Initialize the table to track loaded scripts.
625*ef5ccd6cSJohn Marino    Each entry is hashed by the full path name.  */
626*ef5ccd6cSJohn Marino 
627*ef5ccd6cSJohn Marino static void
init_loaded_scripts_info(struct auto_load_pspace_info * pspace_info)628*ef5ccd6cSJohn Marino init_loaded_scripts_info (struct auto_load_pspace_info *pspace_info)
629*ef5ccd6cSJohn Marino {
630*ef5ccd6cSJohn Marino   /* Choose 31 as the starting size of the hash table, somewhat arbitrarily.
631*ef5ccd6cSJohn Marino      Space for each entry is obtained with one malloc so we can free them
632*ef5ccd6cSJohn Marino      easily.  */
633*ef5ccd6cSJohn Marino 
634*ef5ccd6cSJohn Marino   pspace_info->loaded_scripts = htab_create (31,
635*ef5ccd6cSJohn Marino 					     hash_loaded_script_entry,
636*ef5ccd6cSJohn Marino 					     eq_loaded_script_entry,
637*ef5ccd6cSJohn Marino 					     xfree);
638*ef5ccd6cSJohn Marino 
639*ef5ccd6cSJohn Marino   pspace_info->script_not_found_warning_printed = FALSE;
640*ef5ccd6cSJohn Marino }
641*ef5ccd6cSJohn Marino 
642*ef5ccd6cSJohn Marino /* Wrapper on get_auto_load_pspace_data to also allocate the hash table
643*ef5ccd6cSJohn Marino    for loading scripts.  */
644*ef5ccd6cSJohn Marino 
645*ef5ccd6cSJohn Marino struct auto_load_pspace_info *
get_auto_load_pspace_data_for_loading(struct program_space * pspace)646*ef5ccd6cSJohn Marino get_auto_load_pspace_data_for_loading (struct program_space *pspace)
647*ef5ccd6cSJohn Marino {
648*ef5ccd6cSJohn Marino   struct auto_load_pspace_info *info;
649*ef5ccd6cSJohn Marino 
650*ef5ccd6cSJohn Marino   info = get_auto_load_pspace_data (pspace);
651*ef5ccd6cSJohn Marino   if (info->loaded_scripts == NULL)
652*ef5ccd6cSJohn Marino     init_loaded_scripts_info (info);
653*ef5ccd6cSJohn Marino 
654*ef5ccd6cSJohn Marino   return info;
655*ef5ccd6cSJohn Marino }
656*ef5ccd6cSJohn Marino 
657*ef5ccd6cSJohn Marino /* Add script NAME in LANGUAGE to hash table of PSPACE_INFO.  LOADED 1 if the
658*ef5ccd6cSJohn Marino    script has been (is going to) be loaded, 0 otherwise (such as if it has not
659*ef5ccd6cSJohn Marino    been found).  FULL_PATH is NULL if the script wasn't found.  The result is
660*ef5ccd6cSJohn Marino    true if the script was already in the hash table.  */
661*ef5ccd6cSJohn Marino 
662*ef5ccd6cSJohn Marino int
maybe_add_script(struct auto_load_pspace_info * pspace_info,int loaded,const char * name,const char * full_path,const struct script_language * language)663*ef5ccd6cSJohn Marino maybe_add_script (struct auto_load_pspace_info *pspace_info, int loaded,
664*ef5ccd6cSJohn Marino 		  const char *name, const char *full_path,
665*ef5ccd6cSJohn Marino 		  const struct script_language *language)
666*ef5ccd6cSJohn Marino {
667*ef5ccd6cSJohn Marino   struct htab *htab = pspace_info->loaded_scripts;
668*ef5ccd6cSJohn Marino   struct loaded_script **slot, entry;
669*ef5ccd6cSJohn Marino   int in_hash_table;
670*ef5ccd6cSJohn Marino 
671*ef5ccd6cSJohn Marino   entry.name = name;
672*ef5ccd6cSJohn Marino   entry.language = language;
673*ef5ccd6cSJohn Marino   slot = (struct loaded_script **) htab_find_slot (htab, &entry, INSERT);
674*ef5ccd6cSJohn Marino   in_hash_table = *slot != NULL;
675*ef5ccd6cSJohn Marino 
676*ef5ccd6cSJohn Marino   /* If this script is not in the hash table, add it.  */
677*ef5ccd6cSJohn Marino 
678*ef5ccd6cSJohn Marino   if (! in_hash_table)
679*ef5ccd6cSJohn Marino     {
680*ef5ccd6cSJohn Marino       char *p;
681*ef5ccd6cSJohn Marino 
682*ef5ccd6cSJohn Marino       /* Allocate all space in one chunk so it's easier to free.  */
683*ef5ccd6cSJohn Marino       *slot = xmalloc (sizeof (**slot)
684*ef5ccd6cSJohn Marino 		       + strlen (name) + 1
685*ef5ccd6cSJohn Marino 		       + (full_path != NULL ? (strlen (full_path) + 1) : 0));
686*ef5ccd6cSJohn Marino       p = ((char*) *slot) + sizeof (**slot);
687*ef5ccd6cSJohn Marino       strcpy (p, name);
688*ef5ccd6cSJohn Marino       (*slot)->name = p;
689*ef5ccd6cSJohn Marino       if (full_path != NULL)
690*ef5ccd6cSJohn Marino 	{
691*ef5ccd6cSJohn Marino 	  p += strlen (p) + 1;
692*ef5ccd6cSJohn Marino 	  strcpy (p, full_path);
693*ef5ccd6cSJohn Marino 	  (*slot)->full_path = p;
694*ef5ccd6cSJohn Marino 	}
695*ef5ccd6cSJohn Marino       else
696*ef5ccd6cSJohn Marino 	(*slot)->full_path = NULL;
697*ef5ccd6cSJohn Marino       (*slot)->loaded = loaded;
698*ef5ccd6cSJohn Marino       (*slot)->language = language;
699*ef5ccd6cSJohn Marino     }
700*ef5ccd6cSJohn Marino 
701*ef5ccd6cSJohn Marino   return in_hash_table;
702*ef5ccd6cSJohn Marino }
703*ef5ccd6cSJohn Marino 
704*ef5ccd6cSJohn Marino /* Clear the table of loaded section scripts.  */
705*ef5ccd6cSJohn Marino 
706*ef5ccd6cSJohn Marino static void
clear_section_scripts(void)707*ef5ccd6cSJohn Marino clear_section_scripts (void)
708*ef5ccd6cSJohn Marino {
709*ef5ccd6cSJohn Marino   struct program_space *pspace = current_program_space;
710*ef5ccd6cSJohn Marino   struct auto_load_pspace_info *info;
711*ef5ccd6cSJohn Marino 
712*ef5ccd6cSJohn Marino   info = program_space_data (pspace, auto_load_pspace_data);
713*ef5ccd6cSJohn Marino   if (info != NULL && info->loaded_scripts != NULL)
714*ef5ccd6cSJohn Marino     {
715*ef5ccd6cSJohn Marino       htab_delete (info->loaded_scripts);
716*ef5ccd6cSJohn Marino       info->loaded_scripts = NULL;
717*ef5ccd6cSJohn Marino       info->script_not_found_warning_printed = FALSE;
718*ef5ccd6cSJohn Marino     }
719*ef5ccd6cSJohn Marino }
720*ef5ccd6cSJohn Marino 
721*ef5ccd6cSJohn Marino /* Look for the auto-load script in LANGUAGE associated with OBJFILE where
722*ef5ccd6cSJohn Marino    OBJFILE's gdb_realpath is REALNAME and load it.  Return 1 if we found any
723*ef5ccd6cSJohn Marino    matching script, return 0 otherwise.  */
724*ef5ccd6cSJohn Marino 
725*ef5ccd6cSJohn Marino static int
auto_load_objfile_script_1(struct objfile * objfile,const char * realname,const struct script_language * language)726*ef5ccd6cSJohn Marino auto_load_objfile_script_1 (struct objfile *objfile, const char *realname,
727*ef5ccd6cSJohn Marino 			    const struct script_language *language)
728*ef5ccd6cSJohn Marino {
729*ef5ccd6cSJohn Marino   char *filename, *debugfile;
730*ef5ccd6cSJohn Marino   int len, retval;
731*ef5ccd6cSJohn Marino   FILE *input;
732*ef5ccd6cSJohn Marino   struct cleanup *cleanups;
733*ef5ccd6cSJohn Marino 
734*ef5ccd6cSJohn Marino   len = strlen (realname);
735*ef5ccd6cSJohn Marino   filename = xmalloc (len + strlen (language->suffix) + 1);
736*ef5ccd6cSJohn Marino   memcpy (filename, realname, len);
737*ef5ccd6cSJohn Marino   strcpy (filename + len, language->suffix);
738*ef5ccd6cSJohn Marino 
739*ef5ccd6cSJohn Marino   cleanups = make_cleanup (xfree, filename);
740*ef5ccd6cSJohn Marino 
741*ef5ccd6cSJohn Marino   input = fopen (filename, "r");
742*ef5ccd6cSJohn Marino   debugfile = filename;
743*ef5ccd6cSJohn Marino   if (debug_auto_load)
744*ef5ccd6cSJohn Marino     fprintf_unfiltered (gdb_stdlog, _("auto-load: Attempted file \"%s\" %s.\n"),
745*ef5ccd6cSJohn Marino 			debugfile, input ? _("exists") : _("does not exist"));
746*ef5ccd6cSJohn Marino 
747*ef5ccd6cSJohn Marino   if (!input)
748*ef5ccd6cSJohn Marino     {
749*ef5ccd6cSJohn Marino       VEC (char_ptr) *vec;
750*ef5ccd6cSJohn Marino       int ix;
751*ef5ccd6cSJohn Marino       char *dir;
752*ef5ccd6cSJohn Marino 
753*ef5ccd6cSJohn Marino       /* Also try the same file in a subdirectory of gdb's data
754*ef5ccd6cSJohn Marino 	 directory.  */
755*ef5ccd6cSJohn Marino 
756*ef5ccd6cSJohn Marino       vec = auto_load_expand_dir_vars (auto_load_dir);
757*ef5ccd6cSJohn Marino       make_cleanup_free_char_ptr_vec (vec);
758*ef5ccd6cSJohn Marino 
759*ef5ccd6cSJohn Marino       if (debug_auto_load)
760*ef5ccd6cSJohn Marino 	fprintf_unfiltered (gdb_stdlog, _("auto-load: Searching 'set auto-load "
761*ef5ccd6cSJohn Marino 					  "scripts-directory' path \"%s\".\n"),
762*ef5ccd6cSJohn Marino 			    auto_load_dir);
763*ef5ccd6cSJohn Marino 
764*ef5ccd6cSJohn Marino       for (ix = 0; VEC_iterate (char_ptr, vec, ix, dir); ++ix)
765*ef5ccd6cSJohn Marino 	{
766*ef5ccd6cSJohn Marino 	  debugfile = xmalloc (strlen (dir) + strlen (filename) + 1);
767*ef5ccd6cSJohn Marino 	  strcpy (debugfile, dir);
768*ef5ccd6cSJohn Marino 
769*ef5ccd6cSJohn Marino 	  /* FILENAME is absolute, so we don't need a "/" here.  */
770*ef5ccd6cSJohn Marino 	  strcat (debugfile, filename);
771*ef5ccd6cSJohn Marino 
772*ef5ccd6cSJohn Marino 	  make_cleanup (xfree, debugfile);
773*ef5ccd6cSJohn Marino 	  input = fopen (debugfile, "r");
774*ef5ccd6cSJohn Marino 	  if (debug_auto_load)
775*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog, _("auto-load: Attempted file "
776*ef5ccd6cSJohn Marino 					      "\"%s\" %s.\n"),
777*ef5ccd6cSJohn Marino 				debugfile,
778*ef5ccd6cSJohn Marino 				input ? _("exists") : _("does not exist"));
779*ef5ccd6cSJohn Marino 	  if (input != NULL)
780*ef5ccd6cSJohn Marino 	    break;
781*ef5ccd6cSJohn Marino 	}
782*ef5ccd6cSJohn Marino     }
783*ef5ccd6cSJohn Marino 
784*ef5ccd6cSJohn Marino   if (input)
785*ef5ccd6cSJohn Marino     {
786*ef5ccd6cSJohn Marino       make_cleanup_fclose (input);
787*ef5ccd6cSJohn Marino 
788*ef5ccd6cSJohn Marino       /* To preserve existing behaviour we don't check for whether the
789*ef5ccd6cSJohn Marino 	 script was already in the table, and always load it.
790*ef5ccd6cSJohn Marino 	 It's highly unlikely that we'd ever load it twice,
791*ef5ccd6cSJohn Marino 	 and these scripts are required to be idempotent under multiple
792*ef5ccd6cSJohn Marino 	 loads anyway.  */
793*ef5ccd6cSJohn Marino       language->source_script_for_objfile (objfile, input, debugfile);
794*ef5ccd6cSJohn Marino 
795*ef5ccd6cSJohn Marino       retval = 1;
796*ef5ccd6cSJohn Marino     }
797*ef5ccd6cSJohn Marino   else
798*ef5ccd6cSJohn Marino     retval = 0;
799*ef5ccd6cSJohn Marino 
800*ef5ccd6cSJohn Marino   do_cleanups (cleanups);
801*ef5ccd6cSJohn Marino   return retval;
802*ef5ccd6cSJohn Marino }
803*ef5ccd6cSJohn Marino 
804*ef5ccd6cSJohn Marino /* Look for the auto-load script in LANGUAGE associated with OBJFILE and load
805*ef5ccd6cSJohn Marino    it.  */
806*ef5ccd6cSJohn Marino 
807*ef5ccd6cSJohn Marino void
auto_load_objfile_script(struct objfile * objfile,const struct script_language * language)808*ef5ccd6cSJohn Marino auto_load_objfile_script (struct objfile *objfile,
809*ef5ccd6cSJohn Marino 			  const struct script_language *language)
810*ef5ccd6cSJohn Marino {
811*ef5ccd6cSJohn Marino   char *realname = gdb_realpath (objfile->name);
812*ef5ccd6cSJohn Marino   struct cleanup *cleanups = make_cleanup (xfree, realname);
813*ef5ccd6cSJohn Marino 
814*ef5ccd6cSJohn Marino   if (!auto_load_objfile_script_1 (objfile, realname, language))
815*ef5ccd6cSJohn Marino     {
816*ef5ccd6cSJohn Marino       /* For Windows/DOS .exe executables, strip the .exe suffix, so that
817*ef5ccd6cSJohn Marino 	 FOO-gdb.gdb could be used for FOO.exe, and try again.  */
818*ef5ccd6cSJohn Marino 
819*ef5ccd6cSJohn Marino       size_t len = strlen (realname);
820*ef5ccd6cSJohn Marino       const size_t lexe = sizeof (".exe") - 1;
821*ef5ccd6cSJohn Marino 
822*ef5ccd6cSJohn Marino       if (len > lexe && strcasecmp (realname + len - lexe, ".exe") == 0)
823*ef5ccd6cSJohn Marino 	{
824*ef5ccd6cSJohn Marino 	  len -= lexe;
825*ef5ccd6cSJohn Marino 	  realname[len] = '\0';
826*ef5ccd6cSJohn Marino 	  if (debug_auto_load)
827*ef5ccd6cSJohn Marino 	    fprintf_unfiltered (gdb_stdlog, _("auto-load: Stripped .exe suffix, "
828*ef5ccd6cSJohn Marino 					      "retrying with \"%s\".\n"),
829*ef5ccd6cSJohn Marino 				realname);
830*ef5ccd6cSJohn Marino 	  auto_load_objfile_script_1 (objfile, realname, language);
831*ef5ccd6cSJohn Marino 	}
832*ef5ccd6cSJohn Marino     }
833*ef5ccd6cSJohn Marino 
834*ef5ccd6cSJohn Marino   do_cleanups (cleanups);
835*ef5ccd6cSJohn Marino }
836*ef5ccd6cSJohn Marino 
837*ef5ccd6cSJohn Marino /* Load any auto-loaded scripts for OBJFILE.  */
838*ef5ccd6cSJohn Marino 
839*ef5ccd6cSJohn Marino void
load_auto_scripts_for_objfile(struct objfile * objfile)840*ef5ccd6cSJohn Marino load_auto_scripts_for_objfile (struct objfile *objfile)
841*ef5ccd6cSJohn Marino {
842*ef5ccd6cSJohn Marino   if (!global_auto_load)
843*ef5ccd6cSJohn Marino     return;
844*ef5ccd6cSJohn Marino 
845*ef5ccd6cSJohn Marino   if (auto_load_gdb_scripts)
846*ef5ccd6cSJohn Marino     auto_load_objfile_script (objfile, &script_language_gdb);
847*ef5ccd6cSJohn Marino 
848*ef5ccd6cSJohn Marino   gdbpy_load_auto_scripts_for_objfile (objfile);
849*ef5ccd6cSJohn Marino }
850*ef5ccd6cSJohn Marino 
851*ef5ccd6cSJohn Marino /* This is a new_objfile observer callback to auto-load scripts.
852*ef5ccd6cSJohn Marino 
853*ef5ccd6cSJohn Marino    Two flavors of auto-loaded scripts are supported.
854*ef5ccd6cSJohn Marino    1) based on the path to the objfile
855*ef5ccd6cSJohn Marino    2) from .debug_gdb_scripts section  */
856*ef5ccd6cSJohn Marino 
857*ef5ccd6cSJohn Marino static void
auto_load_new_objfile(struct objfile * objfile)858*ef5ccd6cSJohn Marino auto_load_new_objfile (struct objfile *objfile)
859*ef5ccd6cSJohn Marino {
860*ef5ccd6cSJohn Marino   if (!objfile)
861*ef5ccd6cSJohn Marino     {
862*ef5ccd6cSJohn Marino       /* OBJFILE is NULL when loading a new "main" symbol-file.  */
863*ef5ccd6cSJohn Marino       clear_section_scripts ();
864*ef5ccd6cSJohn Marino       return;
865*ef5ccd6cSJohn Marino     }
866*ef5ccd6cSJohn Marino 
867*ef5ccd6cSJohn Marino   load_auto_scripts_for_objfile (objfile);
868*ef5ccd6cSJohn Marino }
869*ef5ccd6cSJohn Marino 
870*ef5ccd6cSJohn Marino /* Collect scripts to be printed in a vec.  */
871*ef5ccd6cSJohn Marino 
872*ef5ccd6cSJohn Marino typedef struct loaded_script *loaded_script_ptr;
873*ef5ccd6cSJohn Marino DEF_VEC_P (loaded_script_ptr);
874*ef5ccd6cSJohn Marino 
875*ef5ccd6cSJohn Marino struct collect_matching_scripts_data
876*ef5ccd6cSJohn Marino {
877*ef5ccd6cSJohn Marino   VEC (loaded_script_ptr) **scripts_p;
878*ef5ccd6cSJohn Marino 
879*ef5ccd6cSJohn Marino   const struct script_language *language;
880*ef5ccd6cSJohn Marino };
881*ef5ccd6cSJohn Marino 
882*ef5ccd6cSJohn Marino /* Traversal function for htab_traverse.
883*ef5ccd6cSJohn Marino    Collect the entry if it matches the regexp.  */
884*ef5ccd6cSJohn Marino 
885*ef5ccd6cSJohn Marino static int
collect_matching_scripts(void ** slot,void * info)886*ef5ccd6cSJohn Marino collect_matching_scripts (void **slot, void *info)
887*ef5ccd6cSJohn Marino {
888*ef5ccd6cSJohn Marino   struct loaded_script *script = *slot;
889*ef5ccd6cSJohn Marino   struct collect_matching_scripts_data *data = info;
890*ef5ccd6cSJohn Marino 
891*ef5ccd6cSJohn Marino   if (script->language == data->language && re_exec (script->name))
892*ef5ccd6cSJohn Marino     VEC_safe_push (loaded_script_ptr, *data->scripts_p, script);
893*ef5ccd6cSJohn Marino 
894*ef5ccd6cSJohn Marino   return 1;
895*ef5ccd6cSJohn Marino }
896*ef5ccd6cSJohn Marino 
897*ef5ccd6cSJohn Marino /* Print SCRIPT.  */
898*ef5ccd6cSJohn Marino 
899*ef5ccd6cSJohn Marino static void
print_script(struct loaded_script * script)900*ef5ccd6cSJohn Marino print_script (struct loaded_script *script)
901*ef5ccd6cSJohn Marino {
902*ef5ccd6cSJohn Marino   struct ui_out *uiout = current_uiout;
903*ef5ccd6cSJohn Marino   struct cleanup *chain;
904*ef5ccd6cSJohn Marino 
905*ef5ccd6cSJohn Marino   chain = make_cleanup_ui_out_tuple_begin_end (uiout, NULL);
906*ef5ccd6cSJohn Marino 
907*ef5ccd6cSJohn Marino   ui_out_field_string (uiout, "loaded", script->loaded ? "Yes" : "No");
908*ef5ccd6cSJohn Marino   ui_out_field_string (uiout, "script", script->name);
909*ef5ccd6cSJohn Marino   ui_out_text (uiout, "\n");
910*ef5ccd6cSJohn Marino 
911*ef5ccd6cSJohn Marino   /* If the name isn't the full path, print it too.  */
912*ef5ccd6cSJohn Marino   if (script->full_path != NULL
913*ef5ccd6cSJohn Marino       && strcmp (script->name, script->full_path) != 0)
914*ef5ccd6cSJohn Marino     {
915*ef5ccd6cSJohn Marino       ui_out_text (uiout, "\tfull name: ");
916*ef5ccd6cSJohn Marino       ui_out_field_string (uiout, "full_path", script->full_path);
917*ef5ccd6cSJohn Marino       ui_out_text (uiout, "\n");
918*ef5ccd6cSJohn Marino     }
919*ef5ccd6cSJohn Marino 
920*ef5ccd6cSJohn Marino   do_cleanups (chain);
921*ef5ccd6cSJohn Marino }
922*ef5ccd6cSJohn Marino 
923*ef5ccd6cSJohn Marino /* Helper for info_auto_load_scripts to sort the scripts by name.  */
924*ef5ccd6cSJohn Marino 
925*ef5ccd6cSJohn Marino static int
sort_scripts_by_name(const void * ap,const void * bp)926*ef5ccd6cSJohn Marino sort_scripts_by_name (const void *ap, const void *bp)
927*ef5ccd6cSJohn Marino {
928*ef5ccd6cSJohn Marino   const struct loaded_script *a = *(const struct loaded_script **) ap;
929*ef5ccd6cSJohn Marino   const struct loaded_script *b = *(const struct loaded_script **) bp;
930*ef5ccd6cSJohn Marino 
931*ef5ccd6cSJohn Marino   return FILENAME_CMP (a->name, b->name);
932*ef5ccd6cSJohn Marino }
933*ef5ccd6cSJohn Marino 
934*ef5ccd6cSJohn Marino /* Special internal GDB value of auto_load_info_scripts's PATTERN identify
935*ef5ccd6cSJohn Marino    the "info auto-load XXX" command has been executed through the general
936*ef5ccd6cSJohn Marino    "info auto-load" invocation.  Extra newline will be printed if needed.  */
937*ef5ccd6cSJohn Marino char auto_load_info_scripts_pattern_nl[] = "";
938*ef5ccd6cSJohn Marino 
939*ef5ccd6cSJohn Marino /* Implementation for "info auto-load gdb-scripts"
940*ef5ccd6cSJohn Marino    (and "info auto-load python-scripts").  List scripts in LANGUAGE matching
941*ef5ccd6cSJohn Marino    PATTERN.  FROM_TTY is the usual GDB boolean for user interactivity.  */
942*ef5ccd6cSJohn Marino 
943*ef5ccd6cSJohn Marino void
auto_load_info_scripts(char * pattern,int from_tty,const struct script_language * language)944*ef5ccd6cSJohn Marino auto_load_info_scripts (char *pattern, int from_tty,
945*ef5ccd6cSJohn Marino 			const struct script_language *language)
946*ef5ccd6cSJohn Marino {
947*ef5ccd6cSJohn Marino   struct ui_out *uiout = current_uiout;
948*ef5ccd6cSJohn Marino   struct auto_load_pspace_info *pspace_info;
949*ef5ccd6cSJohn Marino   struct cleanup *script_chain;
950*ef5ccd6cSJohn Marino   VEC (loaded_script_ptr) *scripts;
951*ef5ccd6cSJohn Marino   int nr_scripts;
952*ef5ccd6cSJohn Marino 
953*ef5ccd6cSJohn Marino   dont_repeat ();
954*ef5ccd6cSJohn Marino 
955*ef5ccd6cSJohn Marino   pspace_info = get_auto_load_pspace_data (current_program_space);
956*ef5ccd6cSJohn Marino 
957*ef5ccd6cSJohn Marino   if (pattern && *pattern)
958*ef5ccd6cSJohn Marino     {
959*ef5ccd6cSJohn Marino       char *re_err = re_comp (pattern);
960*ef5ccd6cSJohn Marino 
961*ef5ccd6cSJohn Marino       if (re_err)
962*ef5ccd6cSJohn Marino 	error (_("Invalid regexp: %s"), re_err);
963*ef5ccd6cSJohn Marino     }
964*ef5ccd6cSJohn Marino   else
965*ef5ccd6cSJohn Marino     {
966*ef5ccd6cSJohn Marino       re_comp ("");
967*ef5ccd6cSJohn Marino     }
968*ef5ccd6cSJohn Marino 
969*ef5ccd6cSJohn Marino   /* We need to know the number of rows before we build the table.
970*ef5ccd6cSJohn Marino      Plus we want to sort the scripts by name.
971*ef5ccd6cSJohn Marino      So first traverse the hash table collecting the matching scripts.  */
972*ef5ccd6cSJohn Marino 
973*ef5ccd6cSJohn Marino   scripts = VEC_alloc (loaded_script_ptr, 10);
974*ef5ccd6cSJohn Marino   script_chain = make_cleanup (VEC_cleanup (loaded_script_ptr), &scripts);
975*ef5ccd6cSJohn Marino 
976*ef5ccd6cSJohn Marino   if (pspace_info != NULL && pspace_info->loaded_scripts != NULL)
977*ef5ccd6cSJohn Marino     {
978*ef5ccd6cSJohn Marino       struct collect_matching_scripts_data data = { &scripts, language };
979*ef5ccd6cSJohn Marino 
980*ef5ccd6cSJohn Marino       /* Pass a pointer to scripts as VEC_safe_push can realloc space.  */
981*ef5ccd6cSJohn Marino       htab_traverse_noresize (pspace_info->loaded_scripts,
982*ef5ccd6cSJohn Marino 			      collect_matching_scripts, &data);
983*ef5ccd6cSJohn Marino     }
984*ef5ccd6cSJohn Marino 
985*ef5ccd6cSJohn Marino   nr_scripts = VEC_length (loaded_script_ptr, scripts);
986*ef5ccd6cSJohn Marino 
987*ef5ccd6cSJohn Marino   /* Table header shifted right by preceding "gdb-scripts:  " would not match
988*ef5ccd6cSJohn Marino      its columns.  */
989*ef5ccd6cSJohn Marino   if (nr_scripts > 0 && pattern == auto_load_info_scripts_pattern_nl)
990*ef5ccd6cSJohn Marino     ui_out_text (uiout, "\n");
991*ef5ccd6cSJohn Marino 
992*ef5ccd6cSJohn Marino   make_cleanup_ui_out_table_begin_end (uiout, 2, nr_scripts,
993*ef5ccd6cSJohn Marino 				       "AutoLoadedScriptsTable");
994*ef5ccd6cSJohn Marino 
995*ef5ccd6cSJohn Marino   ui_out_table_header (uiout, 7, ui_left, "loaded", "Loaded");
996*ef5ccd6cSJohn Marino   ui_out_table_header (uiout, 70, ui_left, "script", "Script");
997*ef5ccd6cSJohn Marino   ui_out_table_body (uiout);
998*ef5ccd6cSJohn Marino 
999*ef5ccd6cSJohn Marino   if (nr_scripts > 0)
1000*ef5ccd6cSJohn Marino     {
1001*ef5ccd6cSJohn Marino       int i;
1002*ef5ccd6cSJohn Marino       loaded_script_ptr script;
1003*ef5ccd6cSJohn Marino 
1004*ef5ccd6cSJohn Marino       qsort (VEC_address (loaded_script_ptr, scripts),
1005*ef5ccd6cSJohn Marino 	     VEC_length (loaded_script_ptr, scripts),
1006*ef5ccd6cSJohn Marino 	     sizeof (loaded_script_ptr), sort_scripts_by_name);
1007*ef5ccd6cSJohn Marino       for (i = 0; VEC_iterate (loaded_script_ptr, scripts, i, script); ++i)
1008*ef5ccd6cSJohn Marino 	print_script (script);
1009*ef5ccd6cSJohn Marino     }
1010*ef5ccd6cSJohn Marino 
1011*ef5ccd6cSJohn Marino   do_cleanups (script_chain);
1012*ef5ccd6cSJohn Marino 
1013*ef5ccd6cSJohn Marino   if (nr_scripts == 0)
1014*ef5ccd6cSJohn Marino     {
1015*ef5ccd6cSJohn Marino       if (pattern && *pattern)
1016*ef5ccd6cSJohn Marino 	ui_out_message (uiout, 0, "No auto-load scripts matching %s.\n",
1017*ef5ccd6cSJohn Marino 			pattern);
1018*ef5ccd6cSJohn Marino       else
1019*ef5ccd6cSJohn Marino 	ui_out_message (uiout, 0, "No auto-load scripts.\n");
1020*ef5ccd6cSJohn Marino     }
1021*ef5ccd6cSJohn Marino }
1022*ef5ccd6cSJohn Marino 
1023*ef5ccd6cSJohn Marino /* Wrapper for "info auto-load gdb-scripts".  */
1024*ef5ccd6cSJohn Marino 
1025*ef5ccd6cSJohn Marino static void
info_auto_load_gdb_scripts(char * pattern,int from_tty)1026*ef5ccd6cSJohn Marino info_auto_load_gdb_scripts (char *pattern, int from_tty)
1027*ef5ccd6cSJohn Marino {
1028*ef5ccd6cSJohn Marino   auto_load_info_scripts (pattern, from_tty, &script_language_gdb);
1029*ef5ccd6cSJohn Marino }
1030*ef5ccd6cSJohn Marino 
1031*ef5ccd6cSJohn Marino /* Implement 'info auto-load local-gdbinit'.  */
1032*ef5ccd6cSJohn Marino 
1033*ef5ccd6cSJohn Marino static void
info_auto_load_local_gdbinit(char * args,int from_tty)1034*ef5ccd6cSJohn Marino info_auto_load_local_gdbinit (char *args, int from_tty)
1035*ef5ccd6cSJohn Marino {
1036*ef5ccd6cSJohn Marino   if (auto_load_local_gdbinit_pathname == NULL)
1037*ef5ccd6cSJohn Marino     printf_filtered (_("Local .gdbinit file was not found.\n"));
1038*ef5ccd6cSJohn Marino   else if (auto_load_local_gdbinit_loaded)
1039*ef5ccd6cSJohn Marino     printf_filtered (_("Local .gdbinit file \"%s\" has been loaded.\n"),
1040*ef5ccd6cSJohn Marino 		     auto_load_local_gdbinit_pathname);
1041*ef5ccd6cSJohn Marino   else
1042*ef5ccd6cSJohn Marino     printf_filtered (_("Local .gdbinit file \"%s\" has not been loaded.\n"),
1043*ef5ccd6cSJohn Marino 		     auto_load_local_gdbinit_pathname);
1044*ef5ccd6cSJohn Marino }
1045*ef5ccd6cSJohn Marino 
1046*ef5ccd6cSJohn Marino /* Return non-zero if SCRIPT_NOT_FOUND_WARNING_PRINTED of PSPACE_INFO was unset
1047*ef5ccd6cSJohn Marino    before calling this function.  Always set SCRIPT_NOT_FOUND_WARNING_PRINTED
1048*ef5ccd6cSJohn Marino    of PSPACE_INFO.  */
1049*ef5ccd6cSJohn Marino 
1050*ef5ccd6cSJohn Marino int
script_not_found_warning_print(struct auto_load_pspace_info * pspace_info)1051*ef5ccd6cSJohn Marino script_not_found_warning_print (struct auto_load_pspace_info *pspace_info)
1052*ef5ccd6cSJohn Marino {
1053*ef5ccd6cSJohn Marino   int retval = !pspace_info->script_not_found_warning_printed;
1054*ef5ccd6cSJohn Marino 
1055*ef5ccd6cSJohn Marino   pspace_info->script_not_found_warning_printed = 1;
1056*ef5ccd6cSJohn Marino 
1057*ef5ccd6cSJohn Marino   return retval;
1058*ef5ccd6cSJohn Marino }
1059*ef5ccd6cSJohn Marino 
1060*ef5ccd6cSJohn Marino /* The only valid "set auto-load" argument is off|0|no|disable.  */
1061*ef5ccd6cSJohn Marino 
1062*ef5ccd6cSJohn Marino static void
set_auto_load_cmd(char * args,int from_tty)1063*ef5ccd6cSJohn Marino set_auto_load_cmd (char *args, int from_tty)
1064*ef5ccd6cSJohn Marino {
1065*ef5ccd6cSJohn Marino   struct cmd_list_element *list;
1066*ef5ccd6cSJohn Marino   size_t length;
1067*ef5ccd6cSJohn Marino 
1068*ef5ccd6cSJohn Marino   /* See parse_binary_operation in use by the sub-commands.  */
1069*ef5ccd6cSJohn Marino 
1070*ef5ccd6cSJohn Marino   length = args ? strlen (args) : 0;
1071*ef5ccd6cSJohn Marino 
1072*ef5ccd6cSJohn Marino   while (length > 0 && (args[length - 1] == ' ' || args[length - 1] == '\t'))
1073*ef5ccd6cSJohn Marino     length--;
1074*ef5ccd6cSJohn Marino 
1075*ef5ccd6cSJohn Marino   if (length == 0 || (strncmp (args, "off", length) != 0
1076*ef5ccd6cSJohn Marino 		      && strncmp (args, "0", length) != 0
1077*ef5ccd6cSJohn Marino 		      && strncmp (args, "no", length) != 0
1078*ef5ccd6cSJohn Marino 		      && strncmp (args, "disable", length) != 0))
1079*ef5ccd6cSJohn Marino     error (_("Valid is only global 'set auto-load no'; "
1080*ef5ccd6cSJohn Marino 	     "otherwise check the auto-load sub-commands."));
1081*ef5ccd6cSJohn Marino 
1082*ef5ccd6cSJohn Marino   for (list = *auto_load_set_cmdlist_get (); list != NULL; list = list->next)
1083*ef5ccd6cSJohn Marino     if (list->var_type == var_boolean)
1084*ef5ccd6cSJohn Marino       {
1085*ef5ccd6cSJohn Marino 	gdb_assert (list->type == set_cmd);
1086*ef5ccd6cSJohn Marino 	do_set_command (args, from_tty, list);
1087*ef5ccd6cSJohn Marino       }
1088*ef5ccd6cSJohn Marino }
1089*ef5ccd6cSJohn Marino 
1090*ef5ccd6cSJohn Marino /* Initialize "set auto-load " commands prefix and return it.  */
1091*ef5ccd6cSJohn Marino 
1092*ef5ccd6cSJohn Marino struct cmd_list_element **
auto_load_set_cmdlist_get(void)1093*ef5ccd6cSJohn Marino auto_load_set_cmdlist_get (void)
1094*ef5ccd6cSJohn Marino {
1095*ef5ccd6cSJohn Marino   static struct cmd_list_element *retval;
1096*ef5ccd6cSJohn Marino 
1097*ef5ccd6cSJohn Marino   if (retval == NULL)
1098*ef5ccd6cSJohn Marino     add_prefix_cmd ("auto-load", class_maintenance, set_auto_load_cmd, _("\
1099*ef5ccd6cSJohn Marino Auto-loading specific settings.\n\
1100*ef5ccd6cSJohn Marino Configure various auto-load-specific variables such as\n\
1101*ef5ccd6cSJohn Marino automatic loading of Python scripts."),
1102*ef5ccd6cSJohn Marino 		    &retval, "set auto-load ",
1103*ef5ccd6cSJohn Marino 		    1/*allow-unknown*/, &setlist);
1104*ef5ccd6cSJohn Marino 
1105*ef5ccd6cSJohn Marino   return &retval;
1106*ef5ccd6cSJohn Marino }
1107*ef5ccd6cSJohn Marino 
1108*ef5ccd6cSJohn Marino /* Command "show auto-load" displays summary of all the current
1109*ef5ccd6cSJohn Marino    "show auto-load " settings.  */
1110*ef5ccd6cSJohn Marino 
1111*ef5ccd6cSJohn Marino static void
show_auto_load_cmd(char * args,int from_tty)1112*ef5ccd6cSJohn Marino show_auto_load_cmd (char *args, int from_tty)
1113*ef5ccd6cSJohn Marino {
1114*ef5ccd6cSJohn Marino   cmd_show_list (*auto_load_show_cmdlist_get (), from_tty, "");
1115*ef5ccd6cSJohn Marino }
1116*ef5ccd6cSJohn Marino 
1117*ef5ccd6cSJohn Marino /* Initialize "show auto-load " commands prefix and return it.  */
1118*ef5ccd6cSJohn Marino 
1119*ef5ccd6cSJohn Marino struct cmd_list_element **
auto_load_show_cmdlist_get(void)1120*ef5ccd6cSJohn Marino auto_load_show_cmdlist_get (void)
1121*ef5ccd6cSJohn Marino {
1122*ef5ccd6cSJohn Marino   static struct cmd_list_element *retval;
1123*ef5ccd6cSJohn Marino 
1124*ef5ccd6cSJohn Marino   if (retval == NULL)
1125*ef5ccd6cSJohn Marino     add_prefix_cmd ("auto-load", class_maintenance, show_auto_load_cmd, _("\
1126*ef5ccd6cSJohn Marino Show auto-loading specific settings.\n\
1127*ef5ccd6cSJohn Marino Show configuration of various auto-load-specific variables such as\n\
1128*ef5ccd6cSJohn Marino automatic loading of Python scripts."),
1129*ef5ccd6cSJohn Marino 		    &retval, "show auto-load ",
1130*ef5ccd6cSJohn Marino 		    0/*allow-unknown*/, &showlist);
1131*ef5ccd6cSJohn Marino 
1132*ef5ccd6cSJohn Marino   return &retval;
1133*ef5ccd6cSJohn Marino }
1134*ef5ccd6cSJohn Marino 
1135*ef5ccd6cSJohn Marino /* Command "info auto-load" displays whether the various auto-load files have
1136*ef5ccd6cSJohn Marino    been loaded.  This is reimplementation of cmd_show_list which inserts
1137*ef5ccd6cSJohn Marino    newlines at proper places.  */
1138*ef5ccd6cSJohn Marino 
1139*ef5ccd6cSJohn Marino static void
info_auto_load_cmd(char * args,int from_tty)1140*ef5ccd6cSJohn Marino info_auto_load_cmd (char *args, int from_tty)
1141*ef5ccd6cSJohn Marino {
1142*ef5ccd6cSJohn Marino   struct cmd_list_element *list;
1143*ef5ccd6cSJohn Marino   struct cleanup *infolist_chain;
1144*ef5ccd6cSJohn Marino   struct ui_out *uiout = current_uiout;
1145*ef5ccd6cSJohn Marino 
1146*ef5ccd6cSJohn Marino   infolist_chain = make_cleanup_ui_out_tuple_begin_end (uiout, "infolist");
1147*ef5ccd6cSJohn Marino 
1148*ef5ccd6cSJohn Marino   for (list = *auto_load_info_cmdlist_get (); list != NULL; list = list->next)
1149*ef5ccd6cSJohn Marino     {
1150*ef5ccd6cSJohn Marino       struct cleanup *option_chain
1151*ef5ccd6cSJohn Marino 	= make_cleanup_ui_out_tuple_begin_end (uiout, "option");
1152*ef5ccd6cSJohn Marino 
1153*ef5ccd6cSJohn Marino       gdb_assert (!list->prefixlist);
1154*ef5ccd6cSJohn Marino       gdb_assert (list->type == not_set_cmd);
1155*ef5ccd6cSJohn Marino 
1156*ef5ccd6cSJohn Marino       ui_out_field_string (uiout, "name", list->name);
1157*ef5ccd6cSJohn Marino       ui_out_text (uiout, ":  ");
1158*ef5ccd6cSJohn Marino       cmd_func (list, auto_load_info_scripts_pattern_nl, from_tty);
1159*ef5ccd6cSJohn Marino 
1160*ef5ccd6cSJohn Marino       /* Close the tuple.  */
1161*ef5ccd6cSJohn Marino       do_cleanups (option_chain);
1162*ef5ccd6cSJohn Marino     }
1163*ef5ccd6cSJohn Marino 
1164*ef5ccd6cSJohn Marino   /* Close the tuple.  */
1165*ef5ccd6cSJohn Marino   do_cleanups (infolist_chain);
1166*ef5ccd6cSJohn Marino }
1167*ef5ccd6cSJohn Marino 
1168*ef5ccd6cSJohn Marino /* Initialize "info auto-load " commands prefix and return it.  */
1169*ef5ccd6cSJohn Marino 
1170*ef5ccd6cSJohn Marino struct cmd_list_element **
auto_load_info_cmdlist_get(void)1171*ef5ccd6cSJohn Marino auto_load_info_cmdlist_get (void)
1172*ef5ccd6cSJohn Marino {
1173*ef5ccd6cSJohn Marino   static struct cmd_list_element *retval;
1174*ef5ccd6cSJohn Marino 
1175*ef5ccd6cSJohn Marino   if (retval == NULL)
1176*ef5ccd6cSJohn Marino     add_prefix_cmd ("auto-load", class_info, info_auto_load_cmd, _("\
1177*ef5ccd6cSJohn Marino Print current status of auto-loaded files.\n\
1178*ef5ccd6cSJohn Marino Print whether various files like Python scripts or .gdbinit files have been\n\
1179*ef5ccd6cSJohn Marino found and/or loaded."),
1180*ef5ccd6cSJohn Marino 		    &retval, "info auto-load ",
1181*ef5ccd6cSJohn Marino 		    0/*allow-unknown*/, &infolist);
1182*ef5ccd6cSJohn Marino 
1183*ef5ccd6cSJohn Marino   return &retval;
1184*ef5ccd6cSJohn Marino }
1185*ef5ccd6cSJohn Marino 
1186*ef5ccd6cSJohn Marino void _initialize_auto_load (void);
1187*ef5ccd6cSJohn Marino 
1188*ef5ccd6cSJohn Marino void
_initialize_auto_load(void)1189*ef5ccd6cSJohn Marino _initialize_auto_load (void)
1190*ef5ccd6cSJohn Marino {
1191*ef5ccd6cSJohn Marino   struct cmd_list_element *cmd;
1192*ef5ccd6cSJohn Marino   char *scripts_directory_help;
1193*ef5ccd6cSJohn Marino 
1194*ef5ccd6cSJohn Marino   auto_load_pspace_data
1195*ef5ccd6cSJohn Marino     = register_program_space_data_with_cleanup (NULL,
1196*ef5ccd6cSJohn Marino 						auto_load_pspace_data_cleanup);
1197*ef5ccd6cSJohn Marino 
1198*ef5ccd6cSJohn Marino   observer_attach_new_objfile (auto_load_new_objfile);
1199*ef5ccd6cSJohn Marino 
1200*ef5ccd6cSJohn Marino   add_setshow_boolean_cmd ("gdb-scripts", class_support,
1201*ef5ccd6cSJohn Marino 			   &auto_load_gdb_scripts, _("\
1202*ef5ccd6cSJohn Marino Enable or disable auto-loading of canned sequences of commands scripts."), _("\
1203*ef5ccd6cSJohn Marino Show whether auto-loading of canned sequences of commands scripts is enabled."),
1204*ef5ccd6cSJohn Marino 			   _("\
1205*ef5ccd6cSJohn Marino If enabled, canned sequences of commands are loaded when the debugger reads\n\
1206*ef5ccd6cSJohn Marino an executable or shared library.\n\
1207*ef5ccd6cSJohn Marino This options has security implications for untrusted inferiors."),
1208*ef5ccd6cSJohn Marino 			   NULL, show_auto_load_gdb_scripts,
1209*ef5ccd6cSJohn Marino 			   auto_load_set_cmdlist_get (),
1210*ef5ccd6cSJohn Marino 			   auto_load_show_cmdlist_get ());
1211*ef5ccd6cSJohn Marino 
1212*ef5ccd6cSJohn Marino   add_cmd ("gdb-scripts", class_info, info_auto_load_gdb_scripts,
1213*ef5ccd6cSJohn Marino 	   _("Print the list of automatically loaded sequences of commands.\n\
1214*ef5ccd6cSJohn Marino Usage: info auto-load gdb-scripts [REGEXP]"),
1215*ef5ccd6cSJohn Marino 	   auto_load_info_cmdlist_get ());
1216*ef5ccd6cSJohn Marino 
1217*ef5ccd6cSJohn Marino   add_setshow_boolean_cmd ("local-gdbinit", class_support,
1218*ef5ccd6cSJohn Marino 			   &auto_load_local_gdbinit, _("\
1219*ef5ccd6cSJohn Marino Enable or disable auto-loading of .gdbinit script in current directory."), _("\
1220*ef5ccd6cSJohn Marino Show whether auto-loading .gdbinit script in current directory is enabled."),
1221*ef5ccd6cSJohn Marino 			   _("\
1222*ef5ccd6cSJohn Marino If enabled, canned sequences of commands are loaded when debugger starts\n\
1223*ef5ccd6cSJohn Marino from .gdbinit file in current directory.  Such files are deprecated,\n\
1224*ef5ccd6cSJohn Marino use a script associated with inferior executable file instead.\n\
1225*ef5ccd6cSJohn Marino This options has security implications for untrusted inferiors."),
1226*ef5ccd6cSJohn Marino 			   NULL, show_auto_load_local_gdbinit,
1227*ef5ccd6cSJohn Marino 			   auto_load_set_cmdlist_get (),
1228*ef5ccd6cSJohn Marino 			   auto_load_show_cmdlist_get ());
1229*ef5ccd6cSJohn Marino 
1230*ef5ccd6cSJohn Marino   add_cmd ("local-gdbinit", class_info, info_auto_load_local_gdbinit,
1231*ef5ccd6cSJohn Marino 	   _("Print whether current directory .gdbinit file has been loaded.\n\
1232*ef5ccd6cSJohn Marino Usage: info auto-load local-gdbinit"),
1233*ef5ccd6cSJohn Marino 	   auto_load_info_cmdlist_get ());
1234*ef5ccd6cSJohn Marino 
1235*ef5ccd6cSJohn Marino   auto_load_dir = xstrdup (AUTO_LOAD_DIR);
1236*ef5ccd6cSJohn Marino   scripts_directory_help = xstrprintf (
1237*ef5ccd6cSJohn Marino #ifdef HAVE_PYTHON
1238*ef5ccd6cSJohn Marino 				       _("\
1239*ef5ccd6cSJohn Marino Automatically loaded Python scripts (named OBJFILE%s) and GDB scripts\n\
1240*ef5ccd6cSJohn Marino (named OBJFILE%s) are located in one of the directories listed by this\n\
1241*ef5ccd6cSJohn Marino option.\n\
1242*ef5ccd6cSJohn Marino %s"),
1243*ef5ccd6cSJohn Marino 				       GDBPY_AUTO_FILE_NAME,
1244*ef5ccd6cSJohn Marino #else
1245*ef5ccd6cSJohn Marino 				       _("\
1246*ef5ccd6cSJohn Marino Automatically loaded GDB scripts (named OBJFILE%s) are located in one\n\
1247*ef5ccd6cSJohn Marino of the directories listed by this option.\n\
1248*ef5ccd6cSJohn Marino %s"),
1249*ef5ccd6cSJohn Marino #endif
1250*ef5ccd6cSJohn Marino 				       GDB_AUTO_FILE_NAME,
1251*ef5ccd6cSJohn Marino 				       _("\
1252*ef5ccd6cSJohn Marino This option is ignored for the kinds of scripts \
1253*ef5ccd6cSJohn Marino having 'set auto-load ... off'.\n\
1254*ef5ccd6cSJohn Marino Directories listed here need to be present also \
1255*ef5ccd6cSJohn Marino in the 'set auto-load safe-path'\n\
1256*ef5ccd6cSJohn Marino option."));
1257*ef5ccd6cSJohn Marino   add_setshow_optional_filename_cmd ("scripts-directory", class_support,
1258*ef5ccd6cSJohn Marino 				     &auto_load_dir, _("\
1259*ef5ccd6cSJohn Marino Set the list of directories from which to load auto-loaded scripts."), _("\
1260*ef5ccd6cSJohn Marino Show the list of directories from which to load auto-loaded scripts."),
1261*ef5ccd6cSJohn Marino 				     scripts_directory_help,
1262*ef5ccd6cSJohn Marino 				     set_auto_load_dir, show_auto_load_dir,
1263*ef5ccd6cSJohn Marino 				     auto_load_set_cmdlist_get (),
1264*ef5ccd6cSJohn Marino 				     auto_load_show_cmdlist_get ());
1265*ef5ccd6cSJohn Marino   xfree (scripts_directory_help);
1266*ef5ccd6cSJohn Marino 
1267*ef5ccd6cSJohn Marino   auto_load_safe_path = xstrdup (AUTO_LOAD_SAFE_PATH);
1268*ef5ccd6cSJohn Marino   auto_load_safe_path_vec_update ();
1269*ef5ccd6cSJohn Marino   add_setshow_optional_filename_cmd ("safe-path", class_support,
1270*ef5ccd6cSJohn Marino 				     &auto_load_safe_path, _("\
1271*ef5ccd6cSJohn Marino Set the list of files and directories that are safe for auto-loading."), _("\
1272*ef5ccd6cSJohn Marino Show the list of files and directories that are safe for auto-loading."), _("\
1273*ef5ccd6cSJohn Marino Various files loaded automatically for the 'set auto-load ...' options must\n\
1274*ef5ccd6cSJohn Marino be located in one of the directories listed by this option.  Warning will be\n\
1275*ef5ccd6cSJohn Marino printed and file will not be used otherwise.\n\
1276*ef5ccd6cSJohn Marino You can mix both directory and filename entries.\n\
1277*ef5ccd6cSJohn Marino Setting this parameter to an empty list resets it to its default value.\n\
1278*ef5ccd6cSJohn Marino Setting this parameter to '/' (without the quotes) allows any file\n\
1279*ef5ccd6cSJohn Marino for the 'set auto-load ...' options.  Each path entry can be also shell\n\
1280*ef5ccd6cSJohn Marino wildcard pattern; '*' does not match directory separator.\n\
1281*ef5ccd6cSJohn Marino This option is ignored for the kinds of files having 'set auto-load ... off'.\n\
1282*ef5ccd6cSJohn Marino This options has security implications for untrusted inferiors."),
1283*ef5ccd6cSJohn Marino 				     set_auto_load_safe_path,
1284*ef5ccd6cSJohn Marino 				     show_auto_load_safe_path,
1285*ef5ccd6cSJohn Marino 				     auto_load_set_cmdlist_get (),
1286*ef5ccd6cSJohn Marino 				     auto_load_show_cmdlist_get ());
1287*ef5ccd6cSJohn Marino   observer_attach_gdb_datadir_changed (auto_load_gdb_datadir_changed);
1288*ef5ccd6cSJohn Marino 
1289*ef5ccd6cSJohn Marino   cmd = add_cmd ("add-auto-load-safe-path", class_support,
1290*ef5ccd6cSJohn Marino 		 add_auto_load_safe_path,
1291*ef5ccd6cSJohn Marino 		 _("Add entries to the list of directories from which it is safe "
1292*ef5ccd6cSJohn Marino 		   "to auto-load files.\n\
1293*ef5ccd6cSJohn Marino See the commands 'set auto-load safe-path' and 'show auto-load safe-path' to\n\
1294*ef5ccd6cSJohn Marino access the current full list setting."),
1295*ef5ccd6cSJohn Marino 		 &cmdlist);
1296*ef5ccd6cSJohn Marino   set_cmd_completer (cmd, filename_completer);
1297*ef5ccd6cSJohn Marino 
1298*ef5ccd6cSJohn Marino   add_setshow_boolean_cmd ("auto-load", class_maintenance,
1299*ef5ccd6cSJohn Marino 			   &debug_auto_load, _("\
1300*ef5ccd6cSJohn Marino Set auto-load verifications debugging."), _("\
1301*ef5ccd6cSJohn Marino Show auto-load verifications debugging."), _("\
1302*ef5ccd6cSJohn Marino When non-zero, debugging output for files of 'set auto-load ...'\n\
1303*ef5ccd6cSJohn Marino is displayed."),
1304*ef5ccd6cSJohn Marino 			    NULL, show_debug_auto_load,
1305*ef5ccd6cSJohn Marino 			    &setdebuglist, &showdebuglist);
1306*ef5ccd6cSJohn Marino }
1307