From 8ed538ae2d6332a838db7f288bcf91ecc9b650a4 Mon Sep 17 00:00:00 2001 From: Muhammad Mominul Huque Date: Fri, 26 Oct 2018 19:08:21 +0600 Subject: [PATCH 1/2] initial implementation --- .cargo/config | 1 + crates/tools/src/lib.rs | 9 +++++---- crates/tools/src/main.rs | 19 ++++++++++++------- 3 files changed, 18 insertions(+), 11 deletions(-) diff --git a/.cargo/config b/.cargo/config index fd32471ea432..c0be661fd608 100644 --- a/.cargo/config +++ b/.cargo/config @@ -3,6 +3,7 @@ gen-syntax = "run --package tools -- gen-syntax" gen-tests = "run --package tools -- gen-tests" install-code = "run --package tools -- install-code" +format = "run --package tools -- format" render-test = "run --package ra_cli -- render-test" parse = "run --package ra_cli -- parse" diff --git a/crates/tools/src/lib.rs b/crates/tools/src/lib.rs index 7c5410d3c786..91c35b9e133e 100644 --- a/crates/tools/src/lib.rs +++ b/crates/tools/src/lib.rs @@ -12,9 +12,9 @@ pub use teraron::{Mode, Verify, Overwrite}; pub type Result = ::std::result::Result; -pub const GRAMMAR: &str = "ra_syntax/src/grammar.ron"; -pub const SYNTAX_KINDS: &str = "ra_syntax/src/syntax_kinds/generated.rs.tera"; -pub const AST: &str = "ra_syntax/src/ast/generated.rs.tera"; +pub const GRAMMAR: &str = "crates/ra_syntax/src/grammar.ron"; +pub const SYNTAX_KINDS: &str = "crates/ra_syntax/src/syntax_kinds/generated.rs.tera"; +pub const AST: &str = "crates/ra_syntax/src/ast/generated.rs.tera"; #[derive(Debug)] pub struct Test { @@ -75,7 +75,8 @@ pub fn generate(mode: Mode) -> Result<()> { pub fn project_root() -> PathBuf { Path::new(&std::env::var("CARGO_MANIFEST_DIR").unwrap()) - .parent() + .ancestors() + .nth(2) .unwrap() .to_path_buf() } diff --git a/crates/tools/src/main.rs b/crates/tools/src/main.rs index fdb443690bd9..bc5ad6fa8d1c 100644 --- a/crates/tools/src/main.rs +++ b/crates/tools/src/main.rs @@ -13,7 +13,7 @@ use std::{ process::Command, }; use tools::{ - collect_tests, Result, Test, generate, Mode, Overwrite, Verify, + collect_tests, Result, Test, generate, Mode, Overwrite, Verify, project_root, }; const GRAMMAR_DIR: &str = "./crates/ra_syntax/src/grammar"; @@ -31,6 +31,7 @@ fn main() -> Result<()> { .subcommand(SubCommand::with_name("gen-syntax")) .subcommand(SubCommand::with_name("gen-tests")) .subcommand(SubCommand::with_name("install-code")) + .subcommand(SubCommand::with_name("format")) .get_matches(); let mode = if matches.is_present("verify") { Verify @@ -41,6 +42,7 @@ fn main() -> Result<()> { ("install-code", _) => install_code_extension()?, ("gen-tests", _) => gen_tests(mode)?, ("gen-syntax", _) => generate(Overwrite)?, + ("format", _) => run_rustfmt()?, _ => unreachable!(), } Ok(()) @@ -146,12 +148,7 @@ fn install_code_extension() -> Result<()> { fn run(cmdline: &'static str, dir: &str) -> Result<()> { eprintln!("\nwill run: {}", cmdline); - let manifest_dir = env!("CARGO_MANIFEST_DIR"); - let project_dir = Path::new(manifest_dir) - .ancestors() - .nth(2) - .unwrap() - .join(dir); + let project_dir = project_root().join(dir); let mut args = cmdline.split_whitespace(); let exec = args.next().unwrap(); let status = Command::new(exec) @@ -163,3 +160,11 @@ fn run(cmdline: &'static str, dir: &str) -> Result<()> { } Ok(()) } + +fn run_rustfmt() -> Result<()> { + // Use beta toolchain for 2018 edition. + run("rustup install beta", ".")?; + run("rustup component add rustfmt-preview --toolchain beta", ".")?; + run("rustup run beta -- cargo fmt", ".")?; + Ok(()) +} From 20175c2e5b7042f9b183c4bc4350cfa33031b82e Mon Sep 17 00:00:00 2001 From: Muhammad Mominul Huque Date: Thu, 1 Nov 2018 01:50:43 +0600 Subject: [PATCH 2/2] Various changes Pin to a specific toolchain version Format checking functionality Add a test to check the code formatting. Remove macro_use attribute --- crates/tools/src/lib.rs | 29 +++++++++++++++++++++++++++++ crates/tools/src/main.rs | 30 +++--------------------------- crates/tools/tests/cli.rs | 9 ++++++++- 3 files changed, 40 insertions(+), 28 deletions(-) diff --git a/crates/tools/src/lib.rs b/crates/tools/src/lib.rs index 91c35b9e133e..29c46c7c4d1b 100644 --- a/crates/tools/src/lib.rs +++ b/crates/tools/src/lib.rs @@ -4,9 +4,11 @@ extern crate teraron; use std::{ path::{Path, PathBuf}, + process::Command, }; use itertools::Itertools; +use failure::bail; pub use teraron::{Mode, Verify, Overwrite}; @@ -15,6 +17,7 @@ pub type Result = ::std::result::Result; pub const GRAMMAR: &str = "crates/ra_syntax/src/grammar.ron"; pub const SYNTAX_KINDS: &str = "crates/ra_syntax/src/syntax_kinds/generated.rs.tera"; pub const AST: &str = "crates/ra_syntax/src/ast/generated.rs.tera"; +const TOOLCHAIN: &str = "beta-2018-10-30"; #[derive(Debug)] pub struct Test { @@ -80,3 +83,29 @@ pub fn project_root() -> PathBuf { .unwrap() .to_path_buf() } + +pub fn run(cmdline: &str, dir: &str) -> Result<()> { + eprintln!("\nwill run: {}", cmdline); + let project_dir = project_root().join(dir); + let mut args = cmdline.split_whitespace(); + let exec = args.next().unwrap(); + let status = Command::new(exec) + .args(args) + .current_dir(project_dir) + .status()?; + if !status.success() { + bail!("`{}` exited with {}", cmdline, status); + } + Ok(()) +} + +pub fn run_rustfmt(mode: Mode) -> Result<()> { + run(&format!("rustup install {}", TOOLCHAIN), ".")?; + run(&format!("rustup component add rustfmt-preview --toolchain {}", TOOLCHAIN), ".")?; + if mode == Verify { + run(&format!("rustup run {} -- cargo fmt -- --check", TOOLCHAIN), ".")?; + } else { + run(&format!("rustup run {} -- cargo fmt", TOOLCHAIN), ".")?; + } + Ok(()) +} diff --git a/crates/tools/src/main.rs b/crates/tools/src/main.rs index bc5ad6fa8d1c..91675bbf0c80 100644 --- a/crates/tools/src/main.rs +++ b/crates/tools/src/main.rs @@ -1,5 +1,4 @@ extern crate clap; -#[macro_use] extern crate failure; extern crate tools; extern crate walkdir; @@ -10,11 +9,11 @@ use std::{ collections::HashMap, fs, path::{Path, PathBuf}, - process::Command, }; use tools::{ - collect_tests, Result, Test, generate, Mode, Overwrite, Verify, project_root, + collect_tests, Result, Test, generate, Mode, Overwrite, Verify, run, run_rustfmt, }; +use failure::bail; const GRAMMAR_DIR: &str = "./crates/ra_syntax/src/grammar"; const INLINE_TESTS_DIR: &str = "./crates/ra_syntax/tests/data/parser/inline"; @@ -42,7 +41,7 @@ fn main() -> Result<()> { ("install-code", _) => install_code_extension()?, ("gen-tests", _) => gen_tests(mode)?, ("gen-syntax", _) => generate(Overwrite)?, - ("format", _) => run_rustfmt()?, + ("format", _) => run_rustfmt(Overwrite)?, _ => unreachable!(), } Ok(()) @@ -145,26 +144,3 @@ fn install_code_extension() -> Result<()> { } Ok(()) } - -fn run(cmdline: &'static str, dir: &str) -> Result<()> { - eprintln!("\nwill run: {}", cmdline); - let project_dir = project_root().join(dir); - let mut args = cmdline.split_whitespace(); - let exec = args.next().unwrap(); - let status = Command::new(exec) - .args(args) - .current_dir(project_dir) - .status()?; - if !status.success() { - bail!("`{}` exited with {}", cmdline, status); - } - Ok(()) -} - -fn run_rustfmt() -> Result<()> { - // Use beta toolchain for 2018 edition. - run("rustup install beta", ".")?; - run("rustup component add rustfmt-preview --toolchain beta", ".")?; - run("rustup run beta -- cargo fmt", ".")?; - Ok(()) -} diff --git a/crates/tools/tests/cli.rs b/crates/tools/tests/cli.rs index 5de52fc2b8df..8c53a8230451 100644 --- a/crates/tools/tests/cli.rs +++ b/crates/tools/tests/cli.rs @@ -1,7 +1,7 @@ extern crate tools; use tools::{ - generate, Verify + generate, Verify, run_rustfmt, }; #[test] @@ -10,3 +10,10 @@ fn verify_template_generation() { panic!("{}. Please update it by running `cargo gen-syntax`", error); } } + +#[test] +fn check_code_formatting() { + if let Err(error) = run_rustfmt(Verify) { + panic!("{}. Please format the code by running `cargo format`", error); + } +}