use crate::LINE_END;
use lazy_static::lazy_static;
use regex::Regex;
pub const ITEM: &str = "\\item";
pub const DOC_BEGIN: &str = "\\begin{document}";
pub const DOC_END: &str = "\\end{document}";
pub const ENV_BEGIN: &str = "\\begin{";
pub const ENV_END: &str = "\\end{";
pub const EXTENSIONS: [&str; 4] = [".tex", ".bib", ".sty", ".cls"];
const VERBATIMS: [&str; 5] =
["verbatim", "Verbatim", "lstlisting", "minted", "comment"];
const SPLITTING: [&str; 6] = [
r"\\begin\{",
r"\\end\{",
r"\\item(?:$|[^a-zA-Z])",
r"\\(?:sub){0,2}section\*?\{",
r"\\chapter\*?\{",
r"\\part\*?\{",
];
lazy_static! {
pub static ref SPLITTING_STRING: String = [
"(",
SPLITTING.join("|").as_str(),
")"
].concat();
pub static ref RE_NEWLINES: Regex =
Regex::new(&format!(r"{LINE_END}{LINE_END}({LINE_END})+")).unwrap();
pub static ref RE_TRAIL: Regex =
Regex::new(&format!(r" +{LINE_END}")).unwrap();
pub static ref VERBATIMS_BEGIN: Vec<String> = VERBATIMS
.iter()
.map(|l| format!("\\begin{{{l}}}"))
.collect();
pub static ref VERBATIMS_END: Vec<String> =
VERBATIMS.iter().map(|l| format!("\\end{{{l}}}")).collect();
pub static ref RE_SPLITTING: Regex = Regex::new(
SPLITTING_STRING.as_str()
)
.unwrap();
pub static ref RE_SPLITTING_SHARED_LINE: Regex = Regex::new(
[r"(:?\S.*?)", "(:?", SPLITTING_STRING.as_str(), ".*)"]
.concat().as_str()
)
.unwrap();
pub static ref RE_SPLITTING_SHARED_LINE_CAPTURE: Regex = Regex::new(
[r"(?P<prev>\S.*?)", "(?P<env>", SPLITTING_STRING.as_str(), ".*)"]
.concat().as_str()
)
.unwrap();
}