mirror of https://github.com/bsnes-emu/bsnes.git
111 lines
2.5 KiB
C++
Executable File
111 lines
2.5 KiB
C++
Executable File
#ifndef NALL_STRING_COMPARE_HPP
|
|
#define NALL_STRING_COMPARE_HPP
|
|
|
|
namespace nall {
|
|
|
|
char chrlower(char c) {
|
|
return (c >= 'A' && c <= 'Z') ? c + ('a' - 'A') : c;
|
|
}
|
|
|
|
char chrupper(char c) {
|
|
return (c >= 'a' && c <= 'z') ? c - ('a' - 'A') : c;
|
|
}
|
|
|
|
int stricmp(const char *str1, const char *str2) {
|
|
while(*str1) {
|
|
if(chrlower(*str1) != chrlower(*str2)) break;
|
|
str1++, str2++;
|
|
}
|
|
return (int)chrlower(*str1) - (int)chrlower(*str2);
|
|
}
|
|
|
|
bool wildcard(const char *s, const char *p) {
|
|
const char *cp = 0, *mp = 0;
|
|
while(*s && *p != '*') {
|
|
if(*p != '?' && *s != *p) return false;
|
|
p++, s++;
|
|
}
|
|
while(*s) {
|
|
if(*p == '*') {
|
|
if(!*++p) return true;
|
|
mp = p, cp = s + 1;
|
|
} else if(*p == '?' || *p == *s) {
|
|
p++, s++;
|
|
} else {
|
|
p = mp, s = cp++;
|
|
}
|
|
}
|
|
while(*p == '*') p++;
|
|
return !*p;
|
|
}
|
|
|
|
bool iwildcard(const char *s, const char *p) {
|
|
const char *cp = 0, *mp = 0;
|
|
while(*s && *p != '*') {
|
|
if(*p != '?' && chrlower(*s) != chrlower(*p)) return false;
|
|
p++, s++;
|
|
}
|
|
while(*s) {
|
|
if(*p == '*') {
|
|
if(!*++p) return true;
|
|
mp = p, cp = s + 1;
|
|
} else if(*p == '?' || chrlower(*p) == chrlower(*s)) {
|
|
p++, s++;
|
|
} else {
|
|
p = mp, s = cp++;
|
|
}
|
|
}
|
|
while(*p == '*') p++;
|
|
return !*p;
|
|
}
|
|
|
|
bool strbegin(const char *str, const char *key) {
|
|
int i, ssl = strlen(str), ksl = strlen(key);
|
|
|
|
if(ksl > ssl) return false;
|
|
return (!memcmp(str, key, ksl));
|
|
}
|
|
|
|
bool stribegin(const char *str, const char *key) {
|
|
int ssl = strlen(str), ksl = strlen(key);
|
|
|
|
if(ksl > ssl) return false;
|
|
for(int i = 0; i < ksl; i++) {
|
|
if(str[i] >= 'A' && str[i] <= 'Z') {
|
|
if(str[i] != key[i] && str[i]+0x20 != key[i])return false;
|
|
} else if(str[i] >= 'a' && str[i] <= 'z') {
|
|
if(str[i] != key[i] && str[i]-0x20 != key[i])return false;
|
|
} else {
|
|
if(str[i] != key[i])return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
bool strend(const char *str, const char *key) {
|
|
int ssl = strlen(str), ksl = strlen(key);
|
|
|
|
if(ksl > ssl) return false;
|
|
return (!memcmp(str + ssl - ksl, key, ksl));
|
|
}
|
|
|
|
bool striend(const char *str, const char *key) {
|
|
int ssl = strlen(str), ksl = strlen(key);
|
|
|
|
if(ksl > ssl) return false;
|
|
for(int i = ssl - ksl, z = 0; i < ssl; i++, z++) {
|
|
if(str[i] >= 'A' && str[i] <= 'Z') {
|
|
if(str[i] != key[z] && str[i]+0x20 != key[z])return false;
|
|
} else if(str[i] >= 'a' && str[i] <= 'z') {
|
|
if(str[i] != key[z] && str[i]-0x20 != key[z])return false;
|
|
} else {
|
|
if(str[i] != key[z])return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|