From 17d3623a4544f67d7f1b4432b7c69d6061f1c040 Mon Sep 17 00:00:00 2001 From: David Sherret Date: Fri, 1 Dec 2023 12:37:32 -0500 Subject: [PATCH] fix: remove trailing comma for single type param in default export (#589) --- src/generation/generate.rs | 13 ++++++++++--- tests/specs/general/Jsx_TrailingCommas.txt | 12 ++++++++++++ 2 files changed, 22 insertions(+), 3 deletions(-) diff --git a/src/generation/generate.rs b/src/generation/generate.rs index e1acbd54..220b815d 100644 --- a/src/generation/generate.rs +++ b/src/generation/generate.rs @@ -6063,10 +6063,17 @@ fn gen_type_parameters<'a>(node: TypeParamNode<'a>, context: &mut Context<'a>) - if type_params.start() == node.start() { // Use trailing commas for function expressions in a JSX file // if the absence of one would lead to a parsing ambiguity. - let is_jsx_fn_expr = context.is_jsx() && (node.parent().kind() == NodeKind::ArrowExpr || node.parent().parent().unwrap().kind() == NodeKind::FnExpr); + let parent = node.parent(); + let is_ambiguous_jsx_fn_expr = context.is_jsx() + && (parent.kind() == NodeKind::ArrowExpr || parent.parent().unwrap().kind() == NodeKind::FnExpr) + // not ambiguous in a default export + && !matches!( + parent.parent().and_then(|p| p.parent()).map(|p| p.kind()), + Some(NodeKind::ExportDefaultExpr | NodeKind::ExportDefaultDecl) + ); // Prevent "This syntax is reserved in files with the .mts or .cts extension." diagnostic. - let is_cts_mts_arrow_fn = matches!(context.media_type, MediaType::Cts | MediaType::Mts) && node.parent().kind() == NodeKind::ArrowExpr; - if is_jsx_fn_expr || is_cts_mts_arrow_fn { + let is_cts_mts_arrow_fn = matches!(context.media_type, MediaType::Cts | MediaType::Mts) && parent.kind() == NodeKind::ArrowExpr; + if is_ambiguous_jsx_fn_expr || is_cts_mts_arrow_fn { let children = type_params.children(); // It is not ambiguous if there are multiple type parameters. if children.len() == 1 && children[0].kind() == NodeKind::TsTypeParam { diff --git a/tests/specs/general/Jsx_TrailingCommas.txt b/tests/specs/general/Jsx_TrailingCommas.txt index b4a01098..d43ef5f3 100644 --- a/tests/specs/general/Jsx_TrailingCommas.txt +++ b/tests/specs/general/Jsx_TrailingCommas.txt @@ -15,6 +15,12 @@ const Test3 =
; function test() { } +// or export default +export default function test() { +} +export default function() { +} + // generic constraints are not ambiguous either const Test4 =

,>() => {}; const Test5 =

>() => {}; @@ -28,6 +34,12 @@ const Test3 =

; function test() { } +// or export default +export default function test() { +} +export default function() { +} + // generic constraints are not ambiguous either const Test4 =

>() => {}; const Test5 =

>() => {};