/* GDB routines for supporting auto-loaded scripts. Copyright (C) 2012-2023 Free Software Foundation, Inc. This file is part of GDB. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #ifndef AUTO_LOAD_H #define AUTO_LOAD_H 1 struct objfile; struct program_space; struct auto_load_pspace_info; struct extension_language_defn; namespace gdb { namespace observers { struct token; } /* namespace observers */ } /* namespace gdb */ /* Value of the 'set debug auto-load' configuration variable. */ extern bool debug_auto_load; /* Print an "auto-load" debug statement. */ #define auto_load_debug_printf(fmt, ...) \ debug_prefixed_printf_cond (debug_auto_load, "auto-load", fmt, ##__VA_ARGS__) extern bool global_auto_load; extern bool auto_load_local_gdbinit; extern char *auto_load_local_gdbinit_pathname; extern bool auto_load_local_gdbinit_loaded; /* Token used for the auto_load_new_objfile observer, so other observers can specify it as a dependency. */ extern gdb::observers::token auto_load_new_objfile_observer_token; extern struct auto_load_pspace_info * get_auto_load_pspace_data_for_loading (struct program_space *pspace); extern void auto_load_objfile_script (struct objfile *objfile, const struct extension_language_defn *); extern void load_auto_scripts_for_objfile (struct objfile *objfile); extern char auto_load_info_scripts_pattern_nl[]; extern void auto_load_info_scripts (const char *pattern, int from_tty, const struct extension_language_defn *); extern struct cmd_list_element **auto_load_set_cmdlist_get (void); extern struct cmd_list_element **auto_load_show_cmdlist_get (void); extern struct cmd_list_element **auto_load_info_cmdlist_get (void); /* Return true if FILENAME is located in one of the directories of AUTO_LOAD_SAFE_PATH. Otherwise call warning and return false. FILENAME does not have to be an absolute path. Existence of FILENAME is not checked. Function will still give a warning even if the caller would quietly skip non-existing file in unsafe directory. */ extern bool file_is_auto_load_safe (const char *filename); /* Return true if auto-loading gdb scripts is enabled. */ extern bool auto_load_gdb_scripts_enabled (const struct extension_language_defn *extlang); #endif /* AUTO_LOAD_H */