[libvirt] [PATCH 11/12] util: use GRegex in virStringMatch
Peter Krempa
pkrempa at redhat.com
Thu Nov 14 16:13:42 UTC 2019
On Wed, Nov 13, 2019 at 16:48:52 +0100, Ján Tomko wrote:
> Signed-off-by: Ján Tomko <jtomko at redhat.com>
> ---
> src/util/virstring.c | 22 ++++++++--------------
> 1 file changed, 8 insertions(+), 14 deletions(-)
>
> diff --git a/src/util/virstring.c b/src/util/virstring.c
> index 3da793c87a..6add2278d8 100644
> --- a/src/util/virstring.c
> +++ b/src/util/virstring.c
> @@ -19,7 +19,6 @@
> #include <config.h>
>
> #include <glib/gprintf.h>
> -#include <regex.h>
> #include <locale.h>
>
> #include "c-ctype.h"
> @@ -1089,24 +1088,19 @@ bool
> virStringMatch(const char *str,
> const char *regexp)
> {
> - regex_t re;
> - int rv;
> + g_autoptr(GRegex) regex = NULL;
> + g_autoptr(GError) err = NULL;
>
> VIR_DEBUG("match '%s' for '%s'", str, regexp);
>
> - if ((rv = regcomp(&re, regexp, REG_EXTENDED | REG_NOSUB)) != 0) {
> - char error[100];
> - regerror(rv, &re, error, sizeof(error));
> - VIR_WARN("error while compiling regular expression '%s': %s",
> - regexp, error);
> - return false;
> + regex = g_regex_new(regexp, 0, 0, &err);
> + if (!regex) {
> + virReportError(VIR_ERR_INTERNAL_ERROR,
> + _("Failed to compile regex %s"), err->message);
> + return -1;
The function returns bool.
Additionally there is one non-test use of this function. Do you think we
should open-code it instead?
> }
>
> - rv = regexec(&re, str, 0, NULL, 0);
> -
> - regfree(&re);
> -
> - return rv == 0;
> + return g_regex_match(regex, str, 0, NULL);
> }
With the return value/error case sorted out:
Reviewed-by: Peter Krempa <pkrempa at redhat.com>
More information about the libvir-list
mailing list