2020-03-15 13:14:01 +00:00
|
|
|
use std::collections::HashSet;
|
|
|
|
|
2020-04-22 16:10:26 +00:00
|
|
|
use bat::assets::HighlightingAssets;
|
2020-03-15 13:14:01 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn no_duplicate_extensions() {
|
2020-04-24 06:46:01 +00:00
|
|
|
const KNOWN_EXCEPTIONS: &[&str] = &[
|
2020-03-15 13:14:01 +00:00
|
|
|
// The '.h' extension currently appears in multiple syntaxes: C, C++, Objective C,
|
|
|
|
// Objective C++
|
|
|
|
"h",
|
|
|
|
// In addition to the standard Haskell syntax in 'Packages', we also ship the 'Cabal'
|
|
|
|
// syntax which comes with a "Haskell (improved)" syntax.
|
|
|
|
"hs",
|
|
|
|
// In addition to the standard JavaScript syntax in 'Packages', we also ship the
|
|
|
|
// 'Javascript (Babel)' syntax.
|
|
|
|
"js",
|
|
|
|
// The "Ruby Haml" syntax also comes with a '.sass' extension. However, we make sure
|
|
|
|
// that 'sass' is mapped to the 'Sass' syntax.
|
|
|
|
"sass",
|
|
|
|
];
|
|
|
|
|
2020-03-21 15:48:27 +00:00
|
|
|
let assets = HighlightingAssets::from_binary();
|
2020-03-15 13:14:01 +00:00
|
|
|
|
|
|
|
let mut extensions = HashSet::new();
|
|
|
|
|
2020-03-21 19:01:36 +00:00
|
|
|
for syntax in assets.syntaxes() {
|
2020-03-15 13:14:01 +00:00
|
|
|
for extension in &syntax.file_extensions {
|
|
|
|
assert!(
|
|
|
|
KNOWN_EXCEPTIONS.contains(&extension.as_str()) || extensions.insert(extension),
|
|
|
|
"File extension / pattern \"{}\" appears twice in the syntax set",
|
|
|
|
extension
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|