]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
Convert substitute_path_component to C++
authorPhilipp Rudo <prudo@linux.vnet.ibm.com>
Tue, 7 Feb 2017 13:17:02 +0000 (14:17 +0100)
committerAndreas Arnez <arnez@linux.vnet.ibm.com>
Tue, 7 Feb 2017 15:25:53 +0000 (16:25 +0100)
Simplify the code of utils.c:substiute_path_component by converting it to C++.

gdb/ChangeLog:

* utils.c (substitute_path_component): Convert to C++.
* utils.h (substitute_path_componetn): Adjust declatation.
* auto-load.c (auto_load_expand_dir_vars): Adjust.

gdb/auto-load.c
gdb/utils.c
gdb/utils.h

index 56914c8f3a88d4eaa789cf9b15b9e2dc47373343..c84fee1148d804019d2c8e689318f5f05e04cbec 100644 (file)
@@ -40,6 +40,7 @@
 #include "filestuff.h"
 #include "extension.h"
 #include "gdb/section-scripts.h"
+#include <string>
 
 /* The section to look in for auto-loaded scripts (in file formats that
    support sections).
@@ -175,21 +176,20 @@ static VEC (char_ptr) *auto_load_safe_path_vec;
    this vector must be freed by free_char_ptr_vec by the caller.  */
 
 static VEC (char_ptr) *
-auto_load_expand_dir_vars (const char *string)
+auto_load_expand_dir_vars (std::string orig)
 {
   VEC (char_ptr) *dir_vec;
-  char *s;
+  std::string str = orig;
 
-  s = xstrdup (string);
-  substitute_path_component (&s, "$datadir", gdb_datadir);
-  substitute_path_component (&s, "$debugdir", debug_file_directory);
+  substitute_path_component (str, "$datadir", gdb_datadir);
+  substitute_path_component (str, "$debugdir", debug_file_directory);
 
-  if (debug_auto_load && strcmp (s, string) != 0)
+  if (debug_auto_load && str.compare (orig) != 0)
     fprintf_unfiltered (gdb_stdlog,
-                       _("auto-load: Expanded $-variables to \"%s\".\n"), s);
+                       _("auto-load: Expanded $-variables to \"%s\".\n"),
+                       str.c_str ());
 
-  dir_vec = dirnames_to_char_ptr_vec (s);
-  xfree(s);
+  dir_vec = dirnames_to_char_ptr_vec (str.c_str ());
 
   return dir_vec;
 }
index 3dc2f03d61dd0e02aa16685f77dc048e1b00ff55..2b947aad175f3f3c2986cc492de360ec0fce941d 100644 (file)
@@ -66,6 +66,8 @@
 #include "interps.h"
 #include "gdb_regex.h"
 
+#include <string>
+
 #if !HAVE_DECL_MALLOC
 extern PTR malloc ();          /* ARI: PTR */
 #endif
@@ -3156,49 +3158,25 @@ make_cleanup_free_char_ptr_vec (VEC (char_ptr) *char_ptr_vec)
   return make_cleanup (do_free_char_ptr_vec, char_ptr_vec);
 }
 
-/* Substitute all occurences of string FROM by string TO in *STRINGP.  *STRINGP
-   must come from xrealloc-compatible allocator and it may be updated.  FROM
-   needs to be delimited by IS_DIR_SEPARATOR or DIRNAME_SEPARATOR (or be
-   located at the start or end of *STRINGP.  */
+/* See utils.h.  */
 
 void
-substitute_path_component (char **stringp, const char *from, const char *to)
+substitute_path_component (std::string &str, const std::string &from,
+                          const std::string &to)
 {
-  char *string = *stringp, *s;
-  const size_t from_len = strlen (from);
-  const size_t to_len = strlen (to);
-
-  for (s = string;;)
+  for (size_t pos = str.find (from); pos != std::string::npos;
+       pos = str.find (from, pos + 1))
     {
-      s = strstr (s, from);
-      if (s == NULL)
-       break;
-
-      if ((s == string || IS_DIR_SEPARATOR (s[-1])
-          || s[-1] == DIRNAME_SEPARATOR)
-          && (s[from_len] == '\0' || IS_DIR_SEPARATOR (s[from_len])
-             || s[from_len] == DIRNAME_SEPARATOR))
+      char start, end;
+      start = str[pos - 1];
+      end = str[pos + from.length ()];
+      if ((pos == 0 || IS_DIR_SEPARATOR (start) || start == DIRNAME_SEPARATOR)
+         && (end == '\0' || IS_DIR_SEPARATOR (end)
+             || end == DIRNAME_SEPARATOR))
        {
-         char *string_new;
-
-         string_new
-           = (char *) xrealloc (string, (strlen (string) + to_len + 1));
-
-         /* Relocate the current S pointer.  */
-         s = s - string + string_new;
-         string = string_new;
-
-         /* Replace from by to.  */
-         memmove (&s[to_len], &s[from_len], strlen (&s[from_len]) + 1);
-         memcpy (s, to, to_len);
-
-         s += to_len;
+         str.replace (pos, from.length (), to);
        }
-      else
-       s++;
     }
-
-  *stringp = string;
 }
 
 #ifdef HAVE_WAITPID
index f138702b3a430a5c5cc305ebf5d68b0e86ecc0ac..d32114edb6e003d64199ab2cbce0f503df00328c 100644 (file)
@@ -132,8 +132,13 @@ extern char *gdb_abspath (const char *);
 extern int gdb_filename_fnmatch (const char *pattern, const char *string,
                                 int flags);
 
-extern void substitute_path_component (char **stringp, const char *from,
-                                      const char *to);
+/* Substitute all occurences of string FROM by string TO in STR.  FROM
+   needs to be delimited by IS_DIR_SEPARATOR or DIRNAME_SEPARATOR (or be
+   located at the start or end of STR).  */
+
+extern void substitute_path_component (std::string &str,
+                                      const std::string &from,
+                                      const std::string &to);
 
 char *ldirname (const char *filename);