get_regcomp_error.
* utils.c: Include gdb_regex.h.
(do_regfree_cleanup): New function.
(make_regfree_cleanup): Likewise.
(get_regcomp_error): Likewise.
* gdb_regex.h (make_regfree_cleanup, get_regcomp_error): Declare.
+2011-01-17 Tom Tromey <tromey@redhat.com>
+
+ * cli/cli-cmds.c (apropos_command): Free the compiled regex. Use
+ get_regcomp_error.
+ * utils.c: Include gdb_regex.h.
+ (do_regfree_cleanup): New function.
+ (make_regfree_cleanup): Likewise.
+ (get_regcomp_error): Likewise.
+ * gdb_regex.h (make_regfree_cleanup, get_regcomp_error): Declare.
+
2011-01-17 Tom Tromey <tromey@redhat.com>
* cli/cli-cmds.c (apropos_command): Fix formatting. Don't call
apropos_command (char *searchstr, int from_tty)
{
regex_t pattern;
- char errorbuffer[512];
+ int code;
if (searchstr == NULL)
error (_("REGEXP string is empty"));
- if (regcomp (&pattern, searchstr, REG_ICASE) == 0)
- apropos_cmd (gdb_stdout, cmdlist, &pattern, "");
+ code = regcomp (&pattern, searchstr, REG_ICASE);
+ if (code == 0)
+ {
+ struct cleanup *cleanups;
+
+ cleanups = make_regfree_cleanup (&pattern);
+ apropos_cmd (gdb_stdout, cmdlist, &pattern, "");
+ do_cleanups (cleanups);
+ }
else
{
- regerror (regcomp (&pattern, searchstr, REG_ICASE), NULL,
- errorbuffer, 512);
- error (_("Error in regular expression: %s"), errorbuffer);
+ char *err = get_regcomp_error (code, &pattern);
+
+ make_cleanup (xfree, err);
+ error (_("Error in regular expression: %s"), err);
}
}
\f
# include <regex.h>
#endif
+/* From utils.c. */
+struct cleanup *make_regfree_cleanup (regex_t *);
+char *get_regcomp_error (int, regex_t *);
+
#endif /* not GDB_REGEX_H */
#include "gdb_usleep.h"
#include "interps.h"
+#include "gdb_regex.h"
#if !HAVE_DECL_MALLOC
extern PTR malloc (); /* ARI: PTR */
}
\f
+/* A cleanup function that calls regfree. */
+
+static void
+do_regfree_cleanup (void *r)
+{
+ regfree (r);
+}
+
+/* Create a new cleanup that frees the compiled regular expression R. */
+
+struct cleanup *
+make_regfree_cleanup (regex_t *r)
+{
+ return make_cleanup (do_regfree_cleanup, r);
+}
+
+/* Return an xmalloc'd error message resulting from a regular
+ expression compilation failure. */
+
+char *
+get_regcomp_error (int code, regex_t *rx)
+{
+ size_t length = regerror (code, rx, NULL, 0);
+ char *result = xmalloc (length);
+
+ regerror (code, rx, result, length);
+ return result;
+}
+
+\f
+
/* This function supports the query, nquery, and yquery functions.
Ask user a y-or-n question and return 0 if answer is no, 1 if
answer is yes, or default the answer to the specified default