Remove cleanups from mi-cmd-var.c

This removes some cleanups from mi-cmd-var.c.  varobj_gen_name now
returns a string, simplifying mi_cmd_var_create.  In
mi_cmd_var_delete, a string copy is apparently unnecessary, so it's
simply removed.

gdb/ChangeLog
2017-09-29  Tom Tromey  <tom@tromey.com>

	* varobj.h (varobj_gen_name): Return std::string.
	* varobj.c (varobj_gen_name): Return std::string.
	* mi/mi-cmd-var.c (mi_cmd_var_create): Use std::string.
	(mi_cmd_var_delete): Don't copy "name".
This commit is contained in:
Tom Tromey 2017-05-03 17:26:47 -06:00
parent 784c453a4f
commit 2d6960b456
4 changed files with 20 additions and 34 deletions

View file

@ -1,3 +1,10 @@
2017-09-29 Tom Tromey <tom@tromey.com>
* varobj.h (varobj_gen_name): Return std::string.
* varobj.c (varobj_gen_name): Return std::string.
* mi/mi-cmd-var.c (mi_cmd_var_create): Use std::string.
(mi_cmd_var_delete): Don't copy "name".
2017-09-29 Tom Tromey <tom@tromey.com> 2017-09-29 Tom Tromey <tom@tromey.com>
* mi/mi-cmd-break.c (mi_argv_to_format): Return std::string. * mi/mi-cmd-break.c (mi_argv_to_format): Return std::string.

View file

@ -95,32 +95,24 @@ mi_cmd_var_create (const char *command, char **argv, int argc)
struct ui_out *uiout = current_uiout; struct ui_out *uiout = current_uiout;
CORE_ADDR frameaddr = 0; CORE_ADDR frameaddr = 0;
struct varobj *var; struct varobj *var;
char *name;
char *frame; char *frame;
char *expr; char *expr;
struct cleanup *old_cleanups;
enum varobj_type var_type; enum varobj_type var_type;
if (argc != 3) if (argc != 3)
error (_("-var-create: Usage: NAME FRAME EXPRESSION.")); error (_("-var-create: Usage: NAME FRAME EXPRESSION."));
name = xstrdup (argv[0]); frame = argv[1];
/* Add cleanup for name. Must be free_current_contents as name can expr = argv[2];
be reallocated. */
old_cleanups = make_cleanup (free_current_contents, &name);
frame = xstrdup (argv[1]);
make_cleanup (xfree, frame);
expr = xstrdup (argv[2]);
make_cleanup (xfree, expr);
const char *name = argv[0];
std::string gen_name;
if (strcmp (name, "-") == 0) if (strcmp (name, "-") == 0)
{ {
xfree (name); gen_name = varobj_gen_name ();
name = varobj_gen_name (); name = gen_name.c_str ();
} }
else if (!isalpha (*name)) else if (!isalpha (name[0]))
error (_("-var-create: name of object must begin with a letter")); error (_("-var-create: name of object must begin with a letter"));
if (strcmp (frame, "*") == 0) if (strcmp (frame, "*") == 0)
@ -146,8 +138,6 @@ mi_cmd_var_create (const char *command, char **argv, int argc)
print_varobj (var, PRINT_ALL_VALUES, 0 /* don't print expression */); print_varobj (var, PRINT_ALL_VALUES, 0 /* don't print expression */);
uiout->field_int ("has_more", varobj_has_more (var, 0)); uiout->field_int ("has_more", varobj_has_more (var, 0));
do_cleanups (old_cleanups);
} }
void void
@ -157,16 +147,12 @@ mi_cmd_var_delete (const char *command, char **argv, int argc)
struct varobj *var; struct varobj *var;
int numdel; int numdel;
int children_only_p = 0; int children_only_p = 0;
struct cleanup *old_cleanups;
struct ui_out *uiout = current_uiout; struct ui_out *uiout = current_uiout;
if (argc < 1 || argc > 2) if (argc < 1 || argc > 2)
error (_("-var-delete: Usage: [-c] EXPRESSION.")); error (_("-var-delete: Usage: [-c] EXPRESSION."));
name = xstrdup (argv[0]); name = argv[0];
/* Add cleanup for name. Must be free_current_contents as name can
be reallocated. */
old_cleanups = make_cleanup (free_current_contents, &name);
/* If we have one single argument it cannot be '-c' or any string /* If we have one single argument it cannot be '-c' or any string
starting with '-'. */ starting with '-'. */
@ -186,9 +172,7 @@ mi_cmd_var_delete (const char *command, char **argv, int argc)
if (strcmp (name, "-c") != 0) if (strcmp (name, "-c") != 0)
error (_("-var-delete: Invalid option.")); error (_("-var-delete: Invalid option."));
children_only_p = 1; children_only_p = 1;
do_cleanups (old_cleanups); name = argv[1];
name = xstrdup (argv[1]);
old_cleanups = make_cleanup (free_current_contents, &name);
} }
/* If we didn't error out, now NAME contains the name of the /* If we didn't error out, now NAME contains the name of the
@ -199,8 +183,6 @@ mi_cmd_var_delete (const char *command, char **argv, int argc)
numdel = varobj_delete (var, children_only_p); numdel = varobj_delete (var, children_only_p);
uiout->field_int ("ndeleted", numdel); uiout->field_int ("ndeleted", numdel);
do_cleanups (old_cleanups);
} }
/* Parse a string argument into a format value. */ /* Parse a string argument into a format value. */

View file

@ -435,17 +435,14 @@ varobj_create (const char *objname,
/* Generates an unique name that can be used for a varobj. */ /* Generates an unique name that can be used for a varobj. */
char * std::string
varobj_gen_name (void) varobj_gen_name (void)
{ {
static int id = 0; static int id = 0;
char *obj_name;
/* Generate a name for this object. */ /* Generate a name for this object. */
id++; id++;
obj_name = xstrprintf ("var%d", id); return string_printf ("var%d", id);
return obj_name;
} }
/* Given an OBJNAME, returns the pointer to the corresponding varobj. Call /* Given an OBJNAME, returns the pointer to the corresponding varobj. Call

View file

@ -233,7 +233,7 @@ extern struct varobj *varobj_create (const char *objname,
const char *expression, CORE_ADDR frame, const char *expression, CORE_ADDR frame,
enum varobj_type type); enum varobj_type type);
extern char *varobj_gen_name (void); extern std::string varobj_gen_name (void);
extern struct varobj *varobj_get_handle (const char *name); extern struct varobj *varobj_get_handle (const char *name);