1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
use crate::directive::{directive, Directive};
use globset::{Error, Glob};
use nom::{char, map_res, named, tag, take_until1, types::CompleteStr, ws};
#[derive(Debug, PartialEq)]
pub struct PerFile {
pub glob: Glob,
pub directive: Directive,
}
fn str_to_glob(s: &str) -> Result<Glob, Error> {
let mut glob_str = s.trim().to_string();
if !glob_str.starts_with("*") {
glob_str = format!("*{}", glob_str);
}
Glob::new(&glob_str)
}
named!(pub(crate) per_file<CompleteStr, PerFile>, ws!(do_parse!(
tag!("per-file") >>
glob: map_res!(take_until1!("="), |ref s: CompleteStr| str_to_glob(s)) >>
char!('=') >>
directive: directive >>
(PerFile{glob, directive})
)));
#[cfg(test)]
mod tests {
use super::*;
fn create_per_file(glob_str: &str, directive: Directive) -> PerFile {
PerFile {
glob: Glob::new(glob_str).unwrap(),
directive,
}
}
#[test]
fn glob_star_directive() {
let (rem, parsed) = per_file(CompleteStr("per-file *.rs = *")).unwrap();
assert_eq!(parsed, create_per_file("*.rs", Directive::StarGlob));
assert!(rem.is_empty());
}
#[test]
fn compatability_glob() {
let (rem, parsed) = per_file(CompleteStr("per-file Cargo.toml = *")).unwrap();
assert_eq!(parsed, create_per_file("*Cargo.toml", Directive::StarGlob));
assert!(rem.is_empty());
}
#[test]
fn glob_ws_extra() {
let (rem, parsed) = per_file(CompleteStr("per-file *.rs = *")).unwrap();
assert_eq!(parsed, create_per_file("*.rs", Directive::StarGlob));
assert!(rem.is_empty());
}
#[test]
fn glob_ws_reduced() {
let (rem, parsed) = per_file(CompleteStr("per-file*.rs=*")).unwrap();
assert_eq!(parsed, create_per_file("*.rs", Directive::StarGlob));
assert!(rem.is_empty());
}
#[test]
fn invalid_glob() {
assert!(per_file(CompleteStr("per-file invalid-{glob = owner")).is_err());
}
}