| 35 |
size_t len_line; |
size_t len_line; |
| 36 |
char *p = bwf_pattern_str; |
char *p = bwf_pattern_str; |
| 37 |
int line_id = 0; |
int line_id = 0; |
|
int errorcode; |
|
|
PCRE2_SIZE erroroffset; |
|
| 38 |
|
|
| 39 |
if (filename == NULL) |
if (filename == NULL) |
| 40 |
{ |
{ |
| 91 |
|
|
| 92 |
fclose(fp); |
fclose(fp); |
| 93 |
|
|
| 94 |
#ifdef _DEBUG |
log_debug("Debug: bwf_pattern_str: %s\n", bwf_pattern_str); |
| 95 |
log_error("Debug: bwf_pattern_str: %s\n", bwf_pattern_str); |
|
| 96 |
#endif |
return 0; |
| 97 |
|
} |
| 98 |
|
|
| 99 |
|
int bwf_compile(void) |
| 100 |
|
{ |
| 101 |
|
int errorcode; |
| 102 |
|
PCRE2_SIZE erroroffset; |
| 103 |
|
|
| 104 |
bwf_unload(); |
bwf_cleanup(); |
| 105 |
|
|
| 106 |
bwf_code = pcre2_compile((PCRE2_SPTR)bwf_pattern_str, PCRE2_ZERO_TERMINATED, PCRE2_CASELESS, &errorcode, &erroroffset, NULL); |
bwf_code = pcre2_compile((PCRE2_SPTR)bwf_pattern_str, PCRE2_ZERO_TERMINATED, PCRE2_CASELESS, &errorcode, &erroroffset, NULL); |
| 107 |
if (bwf_code == NULL) |
if (bwf_code == NULL) |
| 108 |
{ |
{ |
| 109 |
log_error("pcre2_compile() error: %d", errorcode); |
log_error("pcre2_compile() error: %d", errorcode); |
| 110 |
return -4; |
return -1; |
| 111 |
} |
} |
| 112 |
|
|
| 113 |
return 0; |
return 0; |
| 114 |
} |
} |
| 115 |
|
|
| 116 |
void bwf_unload(void) |
void bwf_cleanup(void) |
| 117 |
{ |
{ |
| 118 |
if (bwf_code != NULL) |
if (bwf_code != NULL) |
| 119 |
{ |
{ |
| 170 |
} |
} |
| 171 |
else |
else |
| 172 |
{ |
{ |
| 173 |
#ifdef _DEBUG |
log_debug("Debug: match pattern #%d of %d at offsets [%d, %d]\n", |
|
log_error("Debug: match pattern #%d of %d at offsets [%d, %d]\n", |
|
| 174 |
i, match_count, ovector[i * 2], ovector[i * 2 + 1] - ovector[i * 2]); |
i, match_count, ovector[i * 2], ovector[i * 2 + 1] - ovector[i * 2]); |
|
#endif |
|
| 175 |
memset(str + ovector[i * 2], c_mask, ovector[i * 2 + 1] - ovector[i * 2]); |
memset(str + ovector[i * 2], c_mask, ovector[i * 2 + 1] - ovector[i * 2]); |
| 176 |
total_match_count++; |
total_match_count++; |
| 177 |
startoffset = ovector[i * 2 + 1]; |
startoffset = ovector[i * 2 + 1]; |