mirror of
https://github.com/CrazyRedMachine/popnhax.git
synced 2024-11-23 22:00:57 +01:00
fix wildcard search
This commit is contained in:
parent
4c44fa2eff
commit
4f501cdd51
@ -12,7 +12,7 @@ static int max(int a, int b) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// The preprocessing function for Boyer Moore's bad character heuristic
|
// The preprocessing function for Boyer Moore's bad character heuristic
|
||||||
static void badCharHeuristic(const unsigned char *str, int size, int* badchar) {
|
static void badCharHeuristic(const unsigned char *str, int size, int* badchar, bool wildcards) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
// Initialize all occurrences as -1
|
// Initialize all occurrences as -1
|
||||||
@ -20,8 +20,27 @@ static void badCharHeuristic(const unsigned char *str, int size, int* badchar) {
|
|||||||
badchar[i] = -1;
|
badchar[i] = -1;
|
||||||
|
|
||||||
// Fill the actual value of last occurrence of a character
|
// Fill the actual value of last occurrence of a character
|
||||||
for (i = 0; i < size; i++)
|
if (wildcards)
|
||||||
badchar[(int) str[i]] = i;
|
{
|
||||||
|
int lastwildcard = -1;
|
||||||
|
for (i = 0; i < size; i++)
|
||||||
|
{
|
||||||
|
if (str[i] != '?')
|
||||||
|
badchar[(int) str[i]] = i;
|
||||||
|
else
|
||||||
|
lastwildcard = i;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < NO_OF_CHARS; i++)
|
||||||
|
{
|
||||||
|
if ( badchar[i] < lastwildcard )
|
||||||
|
badchar[i] = lastwildcard;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
for (i = 0; i < size; i++)
|
||||||
|
badchar[(int) str[i]] = i;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define DEBUG_SEARCH 0
|
#define DEBUG_SEARCH 0
|
||||||
@ -29,9 +48,9 @@ static void badCharHeuristic(const unsigned char *str, int size, int* badchar) {
|
|||||||
int _search(unsigned char *haystack, size_t haystack_size, const unsigned char *needle, size_t needle_size, int orig_offset, bool wildcards, int debug) {
|
int _search(unsigned char *haystack, size_t haystack_size, const unsigned char *needle, size_t needle_size, int orig_offset, bool wildcards, int debug) {
|
||||||
int badchar[NO_OF_CHARS];
|
int badchar[NO_OF_CHARS];
|
||||||
|
|
||||||
badCharHeuristic(needle, needle_size, badchar);
|
badCharHeuristic(needle, needle_size, badchar, wildcards);
|
||||||
|
|
||||||
int64_t s = 0; // s is shift of the pattern with respect to text
|
int64_t s = 0; // s is shift of the pattern with respect to text
|
||||||
while (s <= (haystack_size - needle_size)) {
|
while (s <= (haystack_size - needle_size)) {
|
||||||
int j = needle_size - 1;
|
int j = needle_size - 1;
|
||||||
if (debug == 2)
|
if (debug == 2)
|
||||||
|
Loading…
Reference in New Issue
Block a user