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:
parent
784c453a4f
commit
2d6960b456
4 changed files with 20 additions and 34 deletions
|
@ -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.
|
||||||
|
|
|
@ -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. */
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue