gdb: remove uses of alloca in gdbtypes.c
authorSimon Marchi <simon.marchi@polymtl.ca>
Thu, 31 Aug 2023 19:56:10 +0000 (15:56 -0400)
committerSimon Marchi <simon.marchi@efficios.com>
Fri, 1 Sep 2023 01:28:48 +0000 (21:28 -0400)
Replace two uses of alloca with std::string.

Change-Id: I970ae3f450da407494d95668a57bba8796d6292b
Approved-by: Kevin Buettner <kevinb@redhat.com>
gdb/gdbtypes.c

index 59ddd75ab798073ba6f845c4189ecc948f024723..5e15ec64c41c04edeea7d92563c6e3711833743a 100644 (file)
@@ -1670,11 +1670,12 @@ struct type *
 lookup_unsigned_typename (const struct language_defn *language,
                          const char *name)
 {
-  char *uns = (char *) alloca (strlen (name) + 10);
+  std::string uns;
+  uns.reserve (strlen (name) + strlen ("unsigned "));
+  uns = "unsigned ";
+  uns += name;
 
-  strcpy (uns, "unsigned ");
-  strcpy (uns + 9, name);
-  return lookup_typename (language, uns, NULL, 0);
+  return lookup_typename (language, uns.c_str (), NULL, 0);
 }
 
 struct type *
@@ -1760,16 +1761,14 @@ struct type *
 lookup_template_type (const char *name, struct type *type, 
                      const struct block *block)
 {
-  struct symbol *sym;
-  char *nam = (char *) 
-    alloca (strlen (name) + strlen (type->name ()) + 4);
-
-  strcpy (nam, name);
-  strcat (nam, "<");
-  strcat (nam, type->name ());
-  strcat (nam, " >");  /* FIXME, extra space still introduced in gcc?  */
+  std::string nam;
+  nam.reserve (strlen (name) + strlen (type->name ()) + strlen ("< >"));
+  nam = name;
+  nam += "<";
+  nam += type->name ();
+  nam += " >"; /* FIXME, extra space still introduced in gcc?  */
 
-  sym = lookup_symbol (nam, block, VAR_DOMAIN, 0).symbol;
+  symbol *sym = lookup_symbol (nam.c_str (), block, VAR_DOMAIN, 0).symbol;
 
   if (sym == NULL)
     {