[augeas-devel] [PATCH] Add regexpi to XPath syntax for case insensitive regexps
Raphaël Pinson
raphael.pinson at camptocamp.com
Thu May 31 08:20:39 UTC 2012
Quite a few configuration files support case insensitive keys. This is the
case of the (newly committed) postgresql.conf.
With this new regexpi function, we can do things like this:
augtool> match /files/etc/postgresql/8.4/main/postgresql.conf/*[label() =~
regexp('default_text_search_config')]
(no matches)
augtool> match /files/etc/postgresql/8.4/main/postgresql.conf/*[label() =~
regexpi('default_text_search_config')]
/files/etc/postgresql/8.4/main/postgresql.conf/DEFAULT_teXt_search_config =
'pg_catalog.english'
Raphaël
On Thu, May 31, 2012 at 10:15 AM, Raphaël Pinson <
raphael.pinson at camptocamp.com> wrote:
> ---
> src/pathx.c | 25 ++++++++++++++++++-------
> 1 file changed, 18 insertions(+), 7 deletions(-)
>
> diff --git a/src/pathx.c b/src/pathx.c
> index c6aa4c4..1f8610a 100644
> --- a/src/pathx.c
> +++ b/src/pathx.c
> @@ -283,6 +283,7 @@ static void func_position(struct state *state);
> static void func_count(struct state *state);
> static void func_label(struct state *state);
> static void func_regexp(struct state *state);
> +static void func_regexpi(struct state *state);
> static void func_glob(struct state *state);
> static void func_int(struct state *state);
>
> @@ -306,6 +307,12 @@ static const struct func builtin_funcs[] = {
> { .name = "regexp", .arity = 1, .type = T_REGEXP,
> .arg_types = arg_types_nodeset,
> .impl = func_regexp },
> + { .name = "regexpi", .arity = 1, .type = T_REGEXP,
> + .arg_types = arg_types_string,
> + .impl = func_regexpi },
> + { .name = "regexpi", .arity = 1, .type = T_REGEXP,
> + .arg_types = arg_types_nodeset,
> + .impl = func_regexpi },
> { .name = "glob", .arity = 1, .type = T_REGEXP,
> .arg_types = arg_types_string,
> .impl = func_glob },
> @@ -689,7 +696,7 @@ static void func_int(struct state *state) {
> }
>
> static struct regexp *
> -nodeset_as_regexp(struct info *info, struct nodeset *ns, int glob) {
> +nodeset_as_regexp(struct info *info, struct nodeset *ns, int glob, int
> nocase) {
> struct regexp *result = NULL;
> struct regexp **rx = NULL;
> int used = 0;
> @@ -702,7 +709,7 @@ nodeset_as_regexp(struct info *info, struct nodeset
> *ns, int glob) {
> if (used == 0) {
> /* If the nodeset is empty, make sure we produce a regexp
> * that never matches anything */
> - result = make_regexp_unescape(info, "[^\001-\7ff]", 0);
> + result = make_regexp_unescape(info, "[^\001-\7ff]", nocase);
> } else {
> if (ALLOC_N(rx, ns->used) < 0)
> goto error;
> @@ -729,7 +736,7 @@ nodeset_as_regexp(struct info *info, struct nodeset
> *ns, int glob) {
> return result;
> }
>
> -static void func_regexp_or_glob(struct state *state, int glob) {
> +static void func_regexp_or_glob(struct state *state, int glob, int
> nocase) {
> value_ind_t vind = make_value(T_REGEXP, state);
> int r;
>
> @@ -742,9 +749,9 @@ static void func_regexp_or_glob(struct state *state,
> int glob) {
> if (glob)
> rx = make_regexp_from_glob(state->error->info, v->string);
> else
> - rx = make_regexp_unescape(state->error->info, v->string, 0);
> + rx = make_regexp_unescape(state->error->info, v->string,
> nocase);
> } else if (v->tag == T_NODESET) {
> - rx = nodeset_as_regexp(state->error->info, v->nodeset, glob);
> + rx = nodeset_as_regexp(state->error->info, v->nodeset, glob,
> nocase);
> } else {
> assert(0);
> }
> @@ -767,11 +774,15 @@ static void func_regexp_or_glob(struct state *state,
> int glob) {
> }
>
> static void func_regexp(struct state *state) {
> - func_regexp_or_glob(state, 0);
> + func_regexp_or_glob(state, 0, 0);
> +}
> +
> +static void func_regexpi(struct state *state) {
> + func_regexp_or_glob(state, 0, 1);
> }
>
> static void func_glob(struct state *state) {
> - func_regexp_or_glob(state, 1);
> + func_regexp_or_glob(state, 1, 0);
> }
>
> static bool coerce_to_bool(struct value *v) {
> --
> 1.7.9.5
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://listman.redhat.com/archives/augeas-devel/attachments/20120531/eb5d2b93/attachment.htm>
More information about the augeas-devel
mailing list