Commit aace0509 authored by Du, Changbin's avatar Du, Changbin Committed by Linus Torvalds

lib/parser.c: add match_wildcard() function

match_wildcard function is a simple implementation of wildcard
matching algorithm. It only supports two usual wildcardes:
    '*' - matches zero or more characters
    '?' - matches one character
This algorithm is safe since it is non-recursive.
Signed-off-by: default avatarDu, Changbin <changbin.du@gmail.com>
Cc: Jason Baron <jbaron@akamai.com>
Cc: Joe Perches <joe@perches.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 0d9dfc23
...@@ -29,5 +29,6 @@ int match_token(char *, const match_table_t table, substring_t args[]); ...@@ -29,5 +29,6 @@ int match_token(char *, const match_table_t table, substring_t args[]);
int match_int(substring_t *, int *result); int match_int(substring_t *, int *result);
int match_octal(substring_t *, int *result); int match_octal(substring_t *, int *result);
int match_hex(substring_t *, int *result); int match_hex(substring_t *, int *result);
bool match_wildcard(const char *pattern, const char *str);
size_t match_strlcpy(char *, const substring_t *, size_t); size_t match_strlcpy(char *, const substring_t *, size_t);
char *match_strdup(const substring_t *); char *match_strdup(const substring_t *);
...@@ -192,6 +192,56 @@ int match_hex(substring_t *s, int *result) ...@@ -192,6 +192,56 @@ int match_hex(substring_t *s, int *result)
return match_number(s, result, 16); return match_number(s, result, 16);
} }
/**
* match_wildcard: - parse if a string matches given wildcard pattern
* @pattern: wildcard pattern
* @str: the string to be parsed
*
* Description: Parse the string @str to check if matches wildcard
* pattern @pattern. The pattern may contain two type wildcardes:
* '*' - matches zero or more characters
* '?' - matches one character
* If it's matched, return true, else return false.
*/
bool match_wildcard(const char *pattern, const char *str)
{
const char *s = str;
const char *p = pattern;
bool star = false;
while (*s) {
switch (*p) {
case '?':
s++;
p++;
break;
case '*':
star = true;
str = s;
if (!*++p)
return true;
pattern = p;
break;
default:
if (*s == *p) {
s++;
p++;
} else {
if (!star)
return false;
str++;
s = str;
p = pattern;
}
break;
}
}
if (*p == '*')
++p;
return !*p;
}
/** /**
* match_strlcpy: - Copy the characters from a substring_t to a sized buffer * match_strlcpy: - Copy the characters from a substring_t to a sized buffer
* @dest: where to copy to * @dest: where to copy to
...@@ -235,5 +285,6 @@ EXPORT_SYMBOL(match_token); ...@@ -235,5 +285,6 @@ EXPORT_SYMBOL(match_token);
EXPORT_SYMBOL(match_int); EXPORT_SYMBOL(match_int);
EXPORT_SYMBOL(match_octal); EXPORT_SYMBOL(match_octal);
EXPORT_SYMBOL(match_hex); EXPORT_SYMBOL(match_hex);
EXPORT_SYMBOL(match_wildcard);
EXPORT_SYMBOL(match_strlcpy); EXPORT_SYMBOL(match_strlcpy);
EXPORT_SYMBOL(match_strdup); EXPORT_SYMBOL(match_strdup);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment