diff options
author | Christian Biesinger <cbiesinger@google.com> | 2019-08-20 16:38:29 -0500 |
---|---|---|
committer | Christian Biesinger <cbiesinger@google.com> | 2019-09-11 16:30:00 -0500 |
commit | 9224a01377868604ce4a7eb9c0d97736f7349dcd (patch) | |
tree | 92a4d226ec7ca7f8cf8c5261b5bc5c9f81495940 /gdb | |
parent | f48cd8368bf45b40547237939af3ab6b47dc7b01 (diff) | |
download | gdb-9224a01377868604ce4a7eb9c0d97736f7349dcd.zip gdb-9224a01377868604ce4a7eb9c0d97736f7349dcd.tar.gz gdb-9224a01377868604ce4a7eb9c0d97736f7349dcd.tar.bz2 |
Factor out the code to do the datadir-relocation for gdbinit
This simplifies get_init_files and makes it possible to reuse
this code in an upcoming patch for SYSTEM_GDBINIT_DIR.
gdb/ChangeLog:
2019-09-11 Christian Biesinger <cbiesinger@google.com>
* main.c (relocate_gdbinit_path_maybe_in_datadir): Factor this code
out of get_init_files.
(get_init_files): Update.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 6 | ||||
-rw-r--r-- | gdb/main.c | 74 |
2 files changed, 49 insertions, 31 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 27eae1d..91b860c 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,11 @@ 2019-09-11 Christian Biesinger <cbiesinger@google.com> + * main.c (relocate_gdbinit_path_maybe_in_datadir): Factor this code + out of get_init_files. + (get_init_files): Update. + +2019-09-11 Christian Biesinger <cbiesinger@google.com> + * main.c (get_init_files): Change to use std::string. (captured_main_1): Update. (print_gdb_help): Update. @@ -191,6 +191,47 @@ relocate_gdb_directory (const char *initial, bool relocatable) return dir; } +/* Given a gdbinit path in FILE, adjusts it according to the gdb_datadir + parameter if it is in the data dir, or passes it through relocate_path + otherwise. */ + +static std::string +relocate_gdbinit_path_maybe_in_datadir (const std::string& file) +{ + size_t datadir_len = strlen (GDB_DATADIR); + + std::string relocated_path; + + /* If SYSTEM_GDBINIT lives in data-directory, and data-directory + has been provided, search for SYSTEM_GDBINIT there. */ + if (gdb_datadir_provided + && datadir_len < file.length () + && filename_ncmp (file.c_str (), GDB_DATADIR, datadir_len) == 0 + && IS_DIR_SEPARATOR (file[datadir_len])) + { + /* Append the part of SYSTEM_GDBINIT that follows GDB_DATADIR + to gdb_datadir. */ + + size_t start = datadir_len; + for (; IS_DIR_SEPARATOR (file[start]); ++start) + ; + relocated_path = (std::string (gdb_datadir) + SLASH_STRING + + file.substr (start)); + } + else + { + char *relocated = relocate_path (gdb_program_name, + file.c_str (), + SYSTEM_GDBINIT_RELOCATABLE); + if (relocated != nullptr) + { + relocated_path = relocated; + xfree (relocated); + } + } + return relocated_path; +} + /* Compute the locations of init files that GDB should source and return them in SYSTEM_GDBINIT, HOME_GDBINIT, LOCAL_GDBINIT. If there is no system gdbinit (resp. home gdbinit and local gdbinit) @@ -212,37 +253,8 @@ get_init_files (std::string *system_gdbinit, if (SYSTEM_GDBINIT[0]) { - size_t datadir_len = strlen (GDB_DATADIR); - size_t sys_gdbinit_len = strlen (SYSTEM_GDBINIT); - std::string relocated_sysgdbinit; - - /* If SYSTEM_GDBINIT lives in data-directory, and data-directory - has been provided, search for SYSTEM_GDBINIT there. */ - if (gdb_datadir_provided - && datadir_len < sys_gdbinit_len - && filename_ncmp (SYSTEM_GDBINIT, GDB_DATADIR, datadir_len) == 0 - && IS_DIR_SEPARATOR (SYSTEM_GDBINIT[datadir_len])) - { - /* Append the part of SYSTEM_GDBINIT that follows GDB_DATADIR - to gdb_datadir. */ - - size_t start = datadir_len; - for (; IS_DIR_SEPARATOR (SYSTEM_GDBINIT[start]); ++start) - ; - relocated_sysgdbinit = (std::string (gdb_datadir) + SLASH_STRING - + &SYSTEM_GDBINIT[start]); - } - else - { - char *relocated = relocate_path (gdb_program_name, - SYSTEM_GDBINIT, - SYSTEM_GDBINIT_RELOCATABLE); - if (relocated != nullptr) - { - relocated_sysgdbinit = relocated; - xfree (relocated); - } - } + std::string relocated_sysgdbinit + = relocate_gdbinit_path_maybe_in_datadir (SYSTEM_GDBINIT); if (!relocated_sysgdbinit.empty () && stat (relocated_sysgdbinit.c_str (), &s) == 0) sysgdbinit = relocated_sysgdbinit; |