2020-03-15 14:14:01 +01:00
|
|
|
use std::collections::HashSet;
|
|
|
|
|
2020-04-22 18:10:26 +02:00
|
|
|
use bat::assets::HighlightingAssets;
|
2020-03-15 14:14:01 +01:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn no_duplicate_extensions() {
|
2020-04-24 08:46:01 +02:00
|
|
|
const KNOWN_EXCEPTIONS: &[&str] = &[
|
2020-03-15 14:14:01 +01: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 16:48:27 +01:00
|
|
|
let assets = HighlightingAssets::from_binary();
|
2020-03-15 14:14:01 +01:00
|
|
|
|
|
|
|
let mut extensions = HashSet::new();
|
|
|
|
|
2020-03-21 20:01:36 +01:00
|
|
|
for syntax in assets.syntaxes() {
|
2020-03-15 14:14:01 +01: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
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|