/* regextype.c -- Decode the name of a regular expression syntax into am
option name.
Copyright (C) 2005-2022 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
/* Written by James Youngman, . */
/* config.h must be included first. */
#include
/* system headers. */
#include
#include
#include
/* gnulib headers. */
#include "quote.h"
#include "regex.h"
#include "regextype.h"
#include "xalloc.h"
/* findutils headers */
#include "system.h"
#include "die.h"
struct tagRegexTypeMap
{
const char *name;
int context;
int option_val;
};
static struct tagRegexTypeMap regex_map[] =
{
{ "findutils-default", CONTEXT_FINDUTILS, RE_SYNTAX_EMACS|RE_DOT_NEWLINE },
{ "ed", CONTEXT_GENERIC, RE_SYNTAX_ED },
{ "emacs", CONTEXT_ALL, RE_SYNTAX_EMACS },
{ "gnu-awk", CONTEXT_ALL, RE_SYNTAX_GNU_AWK },
{ "grep", CONTEXT_ALL, RE_SYNTAX_GREP },
{ "posix-awk", CONTEXT_ALL, RE_SYNTAX_POSIX_AWK },
{ "awk", CONTEXT_ALL, RE_SYNTAX_AWK },
{ "posix-basic", CONTEXT_ALL, RE_SYNTAX_POSIX_BASIC },
{ "posix-egrep", CONTEXT_ALL, RE_SYNTAX_POSIX_EGREP },
{ "egrep", CONTEXT_ALL, RE_SYNTAX_EGREP },
{ "posix-extended", CONTEXT_ALL, RE_SYNTAX_POSIX_EXTENDED },
{ "posix-minimal-basic", CONTEXT_GENERIC, RE_SYNTAX_POSIX_MINIMAL_BASIC },
{ "sed", CONTEXT_GENERIC, RE_SYNTAX_SED },
/* ,{ "posix-common", CONTEXT_GENERIC, _RE_SYNTAX_POSIX_COMMON } */
};
enum { N_REGEX_MAP_ENTRIES = sizeof (regex_map)/sizeof (regex_map[0]) };
int
get_regex_type (const char *s)
{
unsigned i;
size_t msglen;
char *buf, *p;
msglen = 0u;
for (i=0u; i 0u)
{
strcpy (p, ", ");
p += 2;
}
p += sprintf (p, "%s", quote (regex_map[i].name));
}
die (EXIT_FAILURE, 0,
_("Unknown regular expression type %s; valid types are %s."),
quote (s),
buf);
/*NOTREACHED*/
return -1;
}
const char *
get_regex_type_name (unsigned int ix)
{
if (ix < N_REGEX_MAP_ENTRIES)
return regex_map[ix].name;
else
return NULL;
}
int
get_regex_type_flags (unsigned int ix)
{
if (ix < N_REGEX_MAP_ENTRIES)
return regex_map[ix].option_val;
else
return -1;
}
unsigned int get_regex_type_context (unsigned int ix)
{
if (ix < N_REGEX_MAP_ENTRIES)
return regex_map[ix].context;
else
return 0u;
}
int
get_regex_type_synonym (unsigned int ix, unsigned int context)
{
unsigned i;
int flags;
if (ix >= N_REGEX_MAP_ENTRIES)
return -1;
flags = regex_map[ix].option_val;
/* Terminate the loop before we get to IX, so that we always
consistently choose the same entry as a synonym (rather than
stating that x and y are synonyms of each other). */
for (i=0u; i