1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-11 08:33:43 -05:00

feat(fmt): add ability to configure semicolons (#17292)

Allows to change behavior of `deno fmt` to use "ASI" setting for
semicolons instead of always prefering them, this is done
by "--options-semi=asi" flag or `"semi": "asi"` setting
in the config file.
This commit is contained in:
Bartek Iwańczuk 2023-01-24 21:07:00 +01:00 committed by GitHub
parent abd9610530
commit e1c51f3c0d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 72 additions and 12 deletions

View file

@ -373,6 +373,13 @@ pub enum ProseWrap {
Preserve,
}
#[derive(Clone, Copy, Debug, Serialize, Deserialize)]
#[serde(deny_unknown_fields, rename_all = "camelCase")]
pub enum SemiColons {
Prefer,
Asi,
}
#[derive(Clone, Debug, Default, Serialize, Deserialize)]
#[serde(default, deny_unknown_fields, rename_all = "camelCase")]
pub struct FmtOptionsConfig {
@ -381,6 +388,7 @@ pub struct FmtOptionsConfig {
pub indent_width: Option<u8>,
pub single_quote: Option<bool>,
pub prose_wrap: Option<ProseWrap>,
pub semi_colons: Option<SemiColons>,
}
#[derive(Clone, Debug, Default, Deserialize)]

View file

@ -131,6 +131,7 @@ pub struct FmtFlags {
pub indent_width: Option<NonZeroU8>,
pub single_quote: Option<bool>,
pub prose_wrap: Option<String>,
pub semi_colons: Option<String>,
}
#[derive(Clone, Debug, Eq, PartialEq)]
@ -1214,6 +1215,13 @@ Ignore formatting a file by adding an ignore comment at the top of the file:
.possible_values(["always", "never", "preserve"])
.help("Define how prose should be wrapped. Defaults to always."),
)
.arg(
Arg::new("options-semi")
.long("options-semi")
.takes_value(true)
.possible_values(["prefer", "asi"])
.help("Use semi colons. Defaults to prefer."),
)
}
fn init_subcommand<'a>() -> Command<'a> {
@ -2571,6 +2579,7 @@ fn fmt_parse(flags: &mut Flags, matches: &clap::ArgMatches) {
let prose_wrap = matches
.value_of("options-prose-wrap")
.map(ToString::to_string);
let semi_colons = matches.value_of("options-semi").map(ToString::to_string);
flags.subcommand = DenoSubcommand::Fmt(FmtFlags {
check: matches.is_present("check"),
@ -2581,6 +2590,7 @@ fn fmt_parse(flags: &mut Flags, matches: &clap::ArgMatches) {
indent_width,
single_quote,
prose_wrap,
semi_colons,
});
}
@ -3598,6 +3608,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
..Flags::default()
}
@ -3619,6 +3630,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
..Flags::default()
}
@ -3640,6 +3652,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
..Flags::default()
}
@ -3661,6 +3674,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
watch: Some(vec![]),
..Flags::default()
@ -3684,6 +3698,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
watch: Some(vec![]),
no_clear_screen: true,
@ -3714,6 +3729,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
watch: Some(vec![]),
..Flags::default()
@ -3736,6 +3752,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
config_flag: ConfigFlag::Path("deno.jsonc".to_string()),
..Flags::default()
@ -3765,6 +3782,7 @@ mod tests {
indent_width: None,
single_quote: None,
prose_wrap: None,
semi_colons: None,
}),
config_flag: ConfigFlag::Path("deno.jsonc".to_string()),
watch: Some(vec![]),
@ -3782,7 +3800,9 @@ mod tests {
"4",
"--options-single-quote",
"--options-prose-wrap",
"never"
"never",
"--options-semi",
"asi"
]);
assert_eq!(
r.unwrap(),
@ -3799,6 +3819,7 @@ mod tests {
indent_width: Some(NonZeroU8::new(4).unwrap()),
single_quote: Some(true),
prose_wrap: Some("never".to_string()),
semi_colons: Some("asi".to_string()),
}),
..Flags::default()
}

View file

@ -15,6 +15,7 @@ pub use config_file::FmtOptionsConfig;
pub use config_file::JsxImportSourceConfig;
pub use config_file::LintRulesConfig;
pub use config_file::ProseWrap;
pub use config_file::SemiColons;
pub use config_file::TsConfig;
pub use config_file::TsConfigForEmit;
pub use config_file::TsConfigType;
@ -199,6 +200,15 @@ fn resolve_fmt_options(
_ => unreachable!(),
});
}
if let Some(semi_colons) = &fmt_flags.semi_colons {
options.semi_colons = Some(match semi_colons.as_str() {
"prefer" => SemiColons::Prefer,
"asi" => SemiColons::Asi,
// validators in `flags.rs` makes other values unreachable
_ => unreachable!(),
});
}
}
options

View file

@ -321,6 +321,14 @@
"never",
"preserve"
]
},
"semiColons": {
"description": "Whether to prefer using semicolons.",
"default": "prefer",
"enum": [
"prefer",
"asi"
]
}
}
}

View file

@ -13,7 +13,8 @@
"lineWidth": 40,
"indentWidth": 8,
"singleQuote": true,
"proseWrap": "always"
"proseWrap": "always",
"semiColons": "asi"
}
}
}

View file

@ -4,33 +4,33 @@ Deno.test(
const response =
await fetch(
'http://localhost:4545/assets/fixture.json',
);
)
const response1 =
response.clone();
response.clone()
assert(
response !==
response1,
);
)
assertEquals(
response.status,
response1
.status,
);
)
assertEquals(
response.statusText,
response1
.statusText,
);
)
const u8a =
new Uint8Array(
await response
.arrayBuffer(),
);
)
const u8a1 =
new Uint8Array(
await response1
.arrayBuffer(),
);
)
for (
let i = 0;
i <
@ -40,7 +40,7 @@ Deno.test(
assertEquals(
u8a[i],
u8a1[i],
);
)
}
},
);
)

View file

@ -1,3 +1,3 @@
DEBUG RS - deno::args::config_file:529 - Config file found at '[WILDCARD]deno.jsonc'
DEBUG RS - [WILDCARD] - Config file found at '[WILDCARD]deno.jsonc'
[WILDCARD]
ok

View file

@ -12,6 +12,7 @@ use crate::args::FilesConfig;
use crate::args::FmtOptions;
use crate::args::FmtOptionsConfig;
use crate::args::ProseWrap;
use crate::args::SemiColons;
use crate::colors;
use crate::util::diff::diff;
use crate::util::file_watcher;
@ -511,6 +512,17 @@ fn get_resolved_typescript_config(
}
}
if let Some(semi_colons) = options.semi_colons {
builder.semi_colons(match semi_colons {
SemiColons::Prefer => {
dprint_plugin_typescript::configuration::SemiColons::Prefer
}
SemiColons::Asi => {
dprint_plugin_typescript::configuration::SemiColons::Asi
}
});
}
builder.build()
}