2020-08-08 09:04:12 +03:00
|
|
|
module regex
|
|
|
|
import strings
|
|
|
|
|
|
|
|
// compile_opt compile RE pattern string
|
|
|
|
pub fn (mut re RE) compile_opt(pattern string) ? {
|
|
|
|
re_err,err_pos := re.impl_compile(pattern)
|
|
|
|
|
|
|
|
if re_err != compile_ok {
|
|
|
|
mut err_msg := strings.new_builder(300)
|
2020-12-18 07:57:31 +03:00
|
|
|
err_msg.write("\nquery: $pattern\n")
|
2020-12-04 13:43:19 +03:00
|
|
|
line := "-".repeat(err_pos)
|
2020-12-05 03:51:48 +03:00
|
|
|
err_msg.write("err : ${line}^\n")
|
|
|
|
err_str := re.get_parse_error_string(re_err)
|
|
|
|
err_msg.write("ERROR: $err_str\n")
|
2020-08-08 09:04:12 +03:00
|
|
|
return error_with_code(err_msg.str(), re_err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// new_regex create a RE of small size, usually sufficient for ordinary use
|
|
|
|
pub fn new() RE {
|
|
|
|
return impl_new_regex_by_size(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// new_regex_by_size create a RE of large size, mult specify the scale factor of the memory that will be allocated
|
|
|
|
pub fn new_by_size(mult int) RE {
|
|
|
|
return impl_new_regex_by_size(mult)
|
|
|
|
}
|
|
|
|
|
|
|
|
// regex_opt create new RE object from RE pattern string
|
|
|
|
pub fn regex_opt(pattern string) ?RE {
|
|
|
|
mut re := new()
|
|
|
|
re.compile_opt(pattern)?
|
|
|
|
return re
|
|
|
|
}
|