Commit a89227d7 authored by Masahiro Yamada's avatar Masahiro Yamada

modpost: use fnmatch() to simplify match()

Replace the own implementation for wildcard (glob) matching with
a function call to fnmatch().

Also, change the return type to 'bool'.
Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
parent 8c9ce89c
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#define _GNU_SOURCE #define _GNU_SOURCE
#include <elf.h> #include <elf.h>
#include <fnmatch.h>
#include <stdio.h> #include <stdio.h>
#include <ctype.h> #include <ctype.h>
#include <string.h> #include <string.h>
...@@ -710,29 +711,6 @@ static char *get_modinfo(struct elf_info *info, const char *tag) ...@@ -710,29 +711,6 @@ static char *get_modinfo(struct elf_info *info, const char *tag)
return get_next_modinfo(info, tag, NULL); return get_next_modinfo(info, tag, NULL);
} }
/**
* Test if string s ends in string sub
* return 0 if match
**/
static int strrcmp(const char *s, const char *sub)
{
int slen, sublen;
if (!s || !sub)
return 1;
slen = strlen(s);
sublen = strlen(sub);
if ((slen == 0) || (sublen == 0))
return 1;
if (sublen > slen)
return 1;
return memcmp(s + slen - sublen, sub, sublen);
}
static const char *sym_name(struct elf_info *elf, Elf_Sym *sym) static const char *sym_name(struct elf_info *elf, Elf_Sym *sym)
{ {
if (sym) if (sym)
...@@ -741,48 +719,22 @@ static const char *sym_name(struct elf_info *elf, Elf_Sym *sym) ...@@ -741,48 +719,22 @@ static const char *sym_name(struct elf_info *elf, Elf_Sym *sym)
return "(unknown)"; return "(unknown)";
} }
/* The pattern is an array of simple patterns. /*
* "foo" will match an exact string equal to "foo" * Check whether the 'string' argument matches one of the 'patterns',
* "*foo" will match a string that ends with "foo" * an array of shell wildcard patterns (glob).
* "foo*" will match a string that begins with "foo" *
* "*foo*" will match a string that contains "foo" * Return true is there is a match.
*/ */
static int match(const char *sym, const char * const pat[]) static bool match(const char *string, const char *const patterns[])
{ {
const char *p; const char *pattern;
while (*pat) {
const char *endp;
p = *pat++;
endp = p + strlen(p) - 1;
/* "*foo*" */ while ((pattern = *patterns++)) {
if (*p == '*' && *endp == '*') { if (!fnmatch(pattern, string, 0))
char *bare = NOFAIL(strndup(p + 1, strlen(p) - 2)); return true;
char *here = strstr(sym, bare);
free(bare);
if (here != NULL)
return 1;
}
/* "*foo" */
else if (*p == '*') {
if (strrcmp(sym, p + 1) == 0)
return 1;
}
/* "foo*" */
else if (*endp == '*') {
if (strncmp(sym, p, strlen(p) - 1) == 0)
return 1;
}
/* no wildcards */
else {
if (strcmp(p, sym) == 0)
return 1;
}
} }
/* no match */
return 0; return false;
} }
/* sections that we do not want to do full section mismatch check on */ /* sections that we do not want to do full section mismatch check on */
......
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