2016-11-27 15:54:35 +00:00
|
|
|
extern crate handlebars;
|
2017-08-10 23:05:17 +00:00
|
|
|
extern crate ignore;
|
|
|
|
extern crate serde_json;
|
2016-11-27 15:54:35 +00:00
|
|
|
|
2017-02-15 19:42:08 +00:00
|
|
|
use std::ffi::OsStr;
|
2018-05-12 09:54:48 +00:00
|
|
|
use std::fs::{self, File};
|
|
|
|
use std::path::Path;
|
2019-10-30 19:31:24 +00:00
|
|
|
use std::{cmp, env, error};
|
2017-02-15 19:42:08 +00:00
|
|
|
|
|
|
|
use handlebars::Handlebars;
|
2018-05-12 09:54:48 +00:00
|
|
|
use ignore::Walk;
|
2019-10-30 19:31:24 +00:00
|
|
|
use serde_json::Value;
|
2016-11-27 15:54:35 +00:00
|
|
|
|
2019-07-19 07:00:45 +00:00
|
|
|
fn main() -> Result<(), Box<dyn error::Error>> {
|
2018-05-12 09:54:48 +00:00
|
|
|
let out_dir = env::var_os("OUT_DIR").expect("No OUT_DIR variable.");
|
|
|
|
generate_languages(&out_dir)?;
|
|
|
|
generate_tests(&out_dir)?;
|
|
|
|
|
|
|
|
Ok(())
|
2016-11-27 15:54:35 +00:00
|
|
|
}
|
|
|
|
|
2019-10-30 19:31:24 +00:00
|
|
|
fn generate_languages(out_dir: &OsStr) -> Result<(), Box<dyn error::Error>> {
|
2017-08-10 23:05:17 +00:00
|
|
|
let handlebars = {
|
|
|
|
let mut h = Handlebars::new();
|
|
|
|
h.register_escape_fn(handlebars::no_escape);
|
|
|
|
h
|
|
|
|
};
|
|
|
|
|
2018-05-12 09:54:48 +00:00
|
|
|
let mut json: Value = serde_json::from_reader(File::open(&"languages.json")?)?;
|
2017-08-10 23:05:17 +00:00
|
|
|
|
2019-10-30 19:31:24 +00:00
|
|
|
for (_key, ref mut item) in json
|
|
|
|
.get_mut("languages")
|
|
|
|
.unwrap()
|
|
|
|
.as_object_mut()
|
|
|
|
.unwrap()
|
|
|
|
.iter_mut()
|
2018-01-26 13:17:55 +00:00
|
|
|
{
|
|
|
|
macro_rules! sort_prop {
|
|
|
|
($prop:expr) => {{
|
|
|
|
if let Some(ref mut prop) = item.get_mut($prop) {
|
|
|
|
prop.as_array_mut()
|
|
|
|
.unwrap()
|
|
|
|
.sort_unstable_by(compare_json_str_len)
|
|
|
|
}
|
2019-10-30 19:31:24 +00:00
|
|
|
}};
|
2018-01-26 13:17:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sort_prop!("quotes");
|
|
|
|
sort_prop!("multi_line");
|
|
|
|
}
|
|
|
|
|
2017-08-10 23:05:17 +00:00
|
|
|
let output = Path::new(&out_dir).join("language_type.rs");
|
2018-05-12 09:54:48 +00:00
|
|
|
let mut source_template = File::open(&"src/language/language_type.hbs.rs")?;
|
|
|
|
let mut output_file = File::create(&output)?;
|
2016-11-27 15:54:35 +00:00
|
|
|
|
2019-10-30 19:31:24 +00:00
|
|
|
handlebars.render_template_source_to_write(&mut source_template, &json, &mut output_file)?;
|
2018-05-12 09:54:48 +00:00
|
|
|
Ok(())
|
2017-02-15 19:42:08 +00:00
|
|
|
}
|
|
|
|
|
2018-05-12 09:54:48 +00:00
|
|
|
fn compare_json_str_len(a: &Value, b: &Value) -> cmp::Ordering {
|
2018-01-26 13:17:55 +00:00
|
|
|
let a = a.as_array().expect("a as array");
|
|
|
|
let b = b.as_array().expect("b as array");
|
|
|
|
|
|
|
|
let max_a_size = a.iter().map(|e| e.as_str().unwrap().len()).max().unwrap();
|
|
|
|
let max_b_size = b.iter().map(|e| e.as_str().unwrap().len()).max().unwrap();
|
|
|
|
|
|
|
|
max_b_size.cmp(&max_a_size)
|
|
|
|
}
|
|
|
|
|
2019-07-19 07:00:45 +00:00
|
|
|
fn generate_tests(out_dir: &OsStr) -> Result<(), Box<dyn error::Error>> {
|
2018-05-12 09:54:48 +00:00
|
|
|
// Length of string literal below by number of languages
|
|
|
|
const INITIAL_BUFFER_SIZE: usize = 989 * 130;
|
|
|
|
let mut string = String::with_capacity(INITIAL_BUFFER_SIZE);
|
2017-02-15 19:42:08 +00:00
|
|
|
|
2019-10-30 19:31:24 +00:00
|
|
|
let walker = Walk::new("./tests/data/").filter(|p| match p {
|
|
|
|
&Ok(ref p) => {
|
|
|
|
if let Ok(ref p) = p.metadata() {
|
|
|
|
p.is_file()
|
|
|
|
} else {
|
|
|
|
false
|
|
|
|
}
|
2017-02-15 19:42:08 +00:00
|
|
|
}
|
2019-10-30 19:31:24 +00:00
|
|
|
_ => false,
|
2017-02-15 19:42:08 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
for path in walker {
|
2018-05-12 09:54:48 +00:00
|
|
|
let path = path?;
|
2017-02-15 19:42:08 +00:00
|
|
|
let path = path.path();
|
|
|
|
|
2017-06-05 14:28:52 +00:00
|
|
|
let name = path.file_stem().unwrap().to_str().unwrap().to_lowercase();
|
2017-02-15 19:42:08 +00:00
|
|
|
|
2019-10-30 19:31:24 +00:00
|
|
|
string.push_str(&format!(
|
|
|
|
r#"
|
2017-02-15 19:42:08 +00:00
|
|
|
#[test]
|
|
|
|
fn {0}() {{
|
|
|
|
let mut languages = Languages::new();
|
2019-01-10 09:53:24 +00:00
|
|
|
languages.get_statistics(&["{1}"], &[], &Config::default());
|
2017-06-05 14:28:52 +00:00
|
|
|
|
|
|
|
if languages.len() != 1 {{
|
|
|
|
panic!("wrong languages detected: expected just {0}, found {{:?}}",
|
|
|
|
languages.into_iter().collect::<Vec<_>>());
|
|
|
|
}}
|
|
|
|
|
|
|
|
let (name, language) = languages.into_iter().next().unwrap();
|
|
|
|
|
2018-05-12 09:35:23 +00:00
|
|
|
let contents = fs::read_to_string("{1}").unwrap();
|
2017-02-15 19:42:08 +00:00
|
|
|
|
2017-06-05 14:28:52 +00:00
|
|
|
assert_eq!(get_digit!(LINES, contents), language.lines);
|
|
|
|
println!("{{}} LINES MATCH", name);
|
|
|
|
assert_eq!(get_digit!(CODE, contents), language.code);
|
|
|
|
println!("{{}} CODE MATCH", name);
|
|
|
|
assert_eq!(get_digit!(COMMENTS, contents), language.comments);
|
|
|
|
println!("{{}} COMMENTS MATCH", name);
|
|
|
|
assert_eq!(get_digit!(BLANKS, contents), language.blanks);
|
|
|
|
println!("{{}} BLANKS MATCH", name);
|
2017-02-15 19:42:08 +00:00
|
|
|
}}
|
2019-10-30 19:31:24 +00:00
|
|
|
"#,
|
|
|
|
name,
|
|
|
|
path.display()
|
|
|
|
));
|
2017-02-15 19:42:08 +00:00
|
|
|
}
|
|
|
|
|
2018-05-12 09:54:48 +00:00
|
|
|
Ok(fs::write(Path::new(&out_dir).join("tests.rs"), string)?)
|
2016-11-27 15:54:35 +00:00
|
|
|
}
|