diff --git a/prost-build/Cargo.toml b/prost-build/Cargo.toml index 721a1dff1..f361c9bbe 100644 --- a/prost-build/Cargo.toml +++ b/prost-build/Cargo.toml @@ -32,6 +32,7 @@ tempfile = "3" once_cell = "1.17.1" regex = { version = "1.8.1", default-features = false, features = ["std", "unicode-bool"] } +# feature: format prettyplease = { version = "0.2", optional = true } syn = { version = "2", features = ["full"], optional = true } diff --git a/prost-build/src/config.rs b/prost-build/src/config.rs index 670c0befe..25717183d 100644 --- a/prost-build/src/config.rs +++ b/prost-build/src/config.rs @@ -49,6 +49,7 @@ pub struct Config { pub(crate) skip_protoc_run: bool, pub(crate) include_file: Option, pub(crate) prost_path: Option, + #[cfg(feature = "format")] pub(crate) fmt: bool, } @@ -736,9 +737,7 @@ impl Config { } /// Configures the code generator to format the output code via `prettyplease`. - /// - /// By default, this is enabled but if the `format` feature is not enabled this does - /// nothing. + #[cfg(feature = "format")] pub fn format(&mut self, enabled: bool) -> &mut Self { self.fmt = enabled; self @@ -1056,6 +1055,7 @@ impl Config { } } + #[cfg(feature = "format")] if self.fmt { self.fmt_modules(&mut modules); } @@ -1080,9 +1080,6 @@ impl Config { *buf = formatted; } } - - #[cfg(not(feature = "format"))] - fn fmt_modules(&mut self, _: &mut HashMap) {} } impl default::Default for Config { @@ -1110,6 +1107,7 @@ impl default::Default for Config { skip_protoc_run: false, include_file: None, prost_path: None, + #[cfg(feature = "format")] fmt: true, } }