#![allow(unreachable_pub)] use std::str::FromStr; use crate::install::{ClientOpt, Malloc, ServerOpt}; xflags::xflags! { src "./src/flags.rs" /// Run custom build command. cmd xtask { /// Install rust-analyzer server or editor plugin. cmd install { /// Install only VS Code plugin. optional --client /// One of 'code', 'code-exploration', 'code-insiders', 'codium', or 'code-oss'. optional --code-bin name: String /// Install only the language server. optional --server /// Use mimalloc allocator for server optional --mimalloc /// Use jemalloc allocator for server optional --jemalloc /// build in release with debug info set to 2 optional --dev-rel } cmd fuzz-tests {} cmd release { optional --dry-run } cmd promote { optional --dry-run } cmd dist { optional --client-patch-version version: String } /// Read a changelog AsciiDoc file and update the GitHub Releases entry in Markdown. cmd publish-release-notes { /// Only run conversion and show the result. optional --dry-run /// Target changelog file. required changelog: String } cmd metrics { optional measurement_type: MeasurementType } /// Builds a benchmark version of rust-analyzer and puts it into `./target`. cmd bb { required suffix: String } cmd codegen { optional codegen_type: CodegenType optional --check } } } // generated start // The following code is generated by `xflags` macro. // Run `env UPDATE_XFLAGS=1 cargo build` to regenerate. #[derive(Debug)] pub struct Xtask { pub subcommand: XtaskCmd, } #[derive(Debug)] pub enum XtaskCmd { Install(Install), FuzzTests(FuzzTests), Release(Release), Promote(Promote), Dist(Dist), PublishReleaseNotes(PublishReleaseNotes), Metrics(Metrics), Bb(Bb), Codegen(Codegen), } #[derive(Debug)] pub struct Codegen { pub check: bool, pub codegen_type: Option, } #[derive(Debug, Default)] pub enum CodegenType { #[default] All, Grammar, AssistsDocTests, DiagnosticsDocs, LintDefinitions, } impl FromStr for CodegenType { type Err = String; fn from_str(s: &str) -> Result { match s { "all" => Ok(Self::All), "grammar" => Ok(Self::Grammar), "assists-doc-tests" => Ok(Self::AssistsDocTests), "diagnostics-docs" => Ok(Self::DiagnosticsDocs), "lints-definitions" => Ok(Self::LintDefinitions), _ => Err("Invalid option".to_owned()), } } } #[derive(Debug)] pub struct Install { pub client: bool, pub code_bin: Option, pub server: bool, pub mimalloc: bool, pub jemalloc: bool, pub dev_rel: bool, } #[derive(Debug)] pub struct FuzzTests; #[derive(Debug)] pub struct Release { pub dry_run: bool, } #[derive(Debug)] pub struct Promote { pub dry_run: bool, } #[derive(Debug)] pub struct Dist { pub client_patch_version: Option, } #[derive(Debug)] pub struct PublishReleaseNotes { pub changelog: String, pub dry_run: bool, } #[derive(Debug)] pub enum MeasurementType { Build, RustcTests, AnalyzeSelf, AnalyzeRipgrep, AnalyzeWebRender, AnalyzeDiesel, AnalyzeHyper, } impl FromStr for MeasurementType { type Err = String; fn from_str(s: &str) -> Result { match s { "build" => Ok(Self::Build), "rustc_tests" => Ok(Self::RustcTests), "self" => Ok(Self::AnalyzeSelf), "ripgrep-13.0.0" => Ok(Self::AnalyzeRipgrep), "webrender-2022" => Ok(Self::AnalyzeWebRender), "diesel-1.4.8" => Ok(Self::AnalyzeDiesel), "hyper-0.14.18" => Ok(Self::AnalyzeHyper), _ => Err("Invalid option".to_owned()), } } } impl AsRef for MeasurementType { fn as_ref(&self) -> &str { match self { Self::Build => "build", Self::RustcTests => "rustc_tests", Self::AnalyzeSelf => "self", Self::AnalyzeRipgrep => "ripgrep-13.0.0", Self::AnalyzeWebRender => "webrender-2022", Self::AnalyzeDiesel => "diesel-1.4.8", Self::AnalyzeHyper => "hyper-0.14.18", } } } #[derive(Debug)] pub struct Metrics { pub measurement_type: Option, } #[derive(Debug)] pub struct Bb { pub suffix: String, } impl Xtask { #[allow(dead_code)] pub fn from_env_or_exit() -> Self { Self::from_env_or_exit_() } #[allow(dead_code)] pub fn from_env() -> xflags::Result { Self::from_env_() } #[allow(dead_code)] pub fn from_vec(args: Vec) -> xflags::Result { Self::from_vec_(args) } } // generated end impl Install { pub(crate) fn server(&self) -> Option { if self.client && !self.server { return None; } let malloc = if self.mimalloc { Malloc::Mimalloc } else if self.jemalloc { Malloc::Jemalloc } else { Malloc::System }; Some(ServerOpt { malloc, dev_rel: self.dev_rel }) } pub(crate) fn client(&self) -> Option { if !self.client && self.server { return None; } Some(ClientOpt { code_bin: self.code_bin.clone() }) } }