From 48b8178f46779078fc69e551417b4c8a9b370e7f Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Thu, 9 Nov 2023 11:15:08 -0800 Subject: [PATCH] Use normal JS comments within JSX tags and JSX expression blocks (#3290) This fix only required changing the `overrides` queries for JavaScript and TSX. I've made the fix in both the `zed2` and `zed` crates. Release Notes: - Fixed an issue in JavaScript and TSX files, where the 'toggle comments' command used the wrong comment syntax inside of JSX tags and expressions within JSX. --- crates/language/src/buffer_tests.rs | 54 +++++++++++++++++-- crates/language2/src/buffer_tests.rs | 54 +++++++++++++++++-- .../src/languages/javascript/overrides.scm | 7 ++- crates/zed/src/languages/tsx/overrides.scm | 7 ++- .../src/languages/javascript/overrides.scm | 7 ++- crates/zed2/src/languages/tsx/overrides.scm | 7 ++- 6 files changed, 122 insertions(+), 14 deletions(-) diff --git a/crates/language/src/buffer_tests.rs b/crates/language/src/buffer_tests.rs index b7e9001c6a..93da61e7a8 100644 --- a/crates/language/src/buffer_tests.rs +++ b/crates/language/src/buffer_tests.rs @@ -1692,14 +1692,25 @@ fn test_language_scope_at_with_javascript(cx: &mut AppContext) { r#" (jsx_element) @element (string) @string + [ + (jsx_opening_element) + (jsx_closing_element) + (jsx_expression) + ] @default "#, ) .unwrap(); - let text = r#"a["b"] = ;"#; + let text = r#" + a["b"] = + + { g() } + ; + "# + .unindent(); let buffer = - Buffer::new(0, cx.model_id() as u64, text).with_language(Arc::new(language), cx); + Buffer::new(0, cx.model_id() as u64, &text).with_language(Arc::new(language), cx); let snapshot = buffer.snapshot(); let config = snapshot.language_scope_at(0).unwrap(); @@ -1710,7 +1721,9 @@ fn test_language_scope_at_with_javascript(cx: &mut AppContext) { &[true, true] ); - let string_config = snapshot.language_scope_at(3).unwrap(); + let string_config = snapshot + .language_scope_at(text.find("b\"").unwrap()) + .unwrap(); assert_eq!(string_config.line_comment_prefix().unwrap().as_ref(), "// "); // Second bracket pair is disabled assert_eq!( @@ -1718,18 +1731,49 @@ fn test_language_scope_at_with_javascript(cx: &mut AppContext) { &[true, false] ); - let element_config = snapshot.language_scope_at(10).unwrap(); + // In between JSX tags: use the `element` override. + let element_config = snapshot + .language_scope_at(text.find("").unwrap()) + .unwrap(); assert_eq!(element_config.line_comment_prefix(), None); assert_eq!( element_config.block_comment_delimiters(), Some((&"{/*".into(), &"*/}".into())) ); - // Both bracket pairs are enabled assert_eq!( element_config.brackets().map(|e| e.1).collect::>(), &[true, true] ); + // Within a JSX tag: use the default config. + let tag_config = snapshot + .language_scope_at(text.find(" d=").unwrap() + 1) + .unwrap(); + assert_eq!(tag_config.line_comment_prefix().unwrap().as_ref(), "// "); + assert_eq!( + tag_config.brackets().map(|e| e.1).collect::>(), + &[true, true] + ); + + // In a JSX expression: use the default config. + let expression_in_element_config = snapshot + .language_scope_at(text.find("{").unwrap() + 1) + .unwrap(); + assert_eq!( + expression_in_element_config + .line_comment_prefix() + .unwrap() + .as_ref(), + "// " + ); + assert_eq!( + expression_in_element_config + .brackets() + .map(|e| e.1) + .collect::>(), + &[true, true] + ); + buffer }); } diff --git a/crates/language2/src/buffer_tests.rs b/crates/language2/src/buffer_tests.rs index d2d886dd84..d3af5b9885 100644 --- a/crates/language2/src/buffer_tests.rs +++ b/crates/language2/src/buffer_tests.rs @@ -1696,14 +1696,25 @@ fn test_language_scope_at_with_javascript(cx: &mut AppContext) { r#" (jsx_element) @element (string) @string + [ + (jsx_opening_element) + (jsx_closing_element) + (jsx_expression) + ] @default "#, ) .unwrap(); - let text = r#"a["b"] = ;"#; + let text = r#" + a["b"] = + + { g() } + ; + "# + .unindent(); let buffer = - Buffer::new(0, cx.entity_id().as_u64(), text).with_language(Arc::new(language), cx); + Buffer::new(0, cx.entity_id().as_u64(), &text).with_language(Arc::new(language), cx); let snapshot = buffer.snapshot(); let config = snapshot.language_scope_at(0).unwrap(); @@ -1714,7 +1725,9 @@ fn test_language_scope_at_with_javascript(cx: &mut AppContext) { &[true, true] ); - let string_config = snapshot.language_scope_at(3).unwrap(); + let string_config = snapshot + .language_scope_at(text.find("b\"").unwrap()) + .unwrap(); assert_eq!(string_config.line_comment_prefix().unwrap().as_ref(), "// "); // Second bracket pair is disabled assert_eq!( @@ -1722,18 +1735,49 @@ fn test_language_scope_at_with_javascript(cx: &mut AppContext) { &[true, false] ); - let element_config = snapshot.language_scope_at(10).unwrap(); + // In between JSX tags: use the `element` override. + let element_config = snapshot + .language_scope_at(text.find("").unwrap()) + .unwrap(); assert_eq!(element_config.line_comment_prefix(), None); assert_eq!( element_config.block_comment_delimiters(), Some((&"{/*".into(), &"*/}".into())) ); - // Both bracket pairs are enabled assert_eq!( element_config.brackets().map(|e| e.1).collect::>(), &[true, true] ); + // Within a JSX tag: use the default config. + let tag_config = snapshot + .language_scope_at(text.find(" d=").unwrap() + 1) + .unwrap(); + assert_eq!(tag_config.line_comment_prefix().unwrap().as_ref(), "// "); + assert_eq!( + tag_config.brackets().map(|e| e.1).collect::>(), + &[true, true] + ); + + // In a JSX expression: use the default config. + let expression_in_element_config = snapshot + .language_scope_at(text.find("{").unwrap() + 1) + .unwrap(); + assert_eq!( + expression_in_element_config + .line_comment_prefix() + .unwrap() + .as_ref(), + "// " + ); + assert_eq!( + expression_in_element_config + .brackets() + .map(|e| e.1) + .collect::>(), + &[true, true] + ); + buffer }); } diff --git a/crates/zed/src/languages/javascript/overrides.scm b/crates/zed/src/languages/javascript/overrides.scm index 8b43fdcfc5..eb0a33b067 100644 --- a/crates/zed/src/languages/javascript/overrides.scm +++ b/crates/zed/src/languages/javascript/overrides.scm @@ -8,6 +8,11 @@ [ (jsx_element) (jsx_fragment) +] @element + +[ + (jsx_opening_element) + (jsx_closing_element) (jsx_self_closing_element) (jsx_expression) -] @element +] @default diff --git a/crates/zed/src/languages/tsx/overrides.scm b/crates/zed/src/languages/tsx/overrides.scm index 8b43fdcfc5..eb0a33b067 100644 --- a/crates/zed/src/languages/tsx/overrides.scm +++ b/crates/zed/src/languages/tsx/overrides.scm @@ -8,6 +8,11 @@ [ (jsx_element) (jsx_fragment) +] @element + +[ + (jsx_opening_element) + (jsx_closing_element) (jsx_self_closing_element) (jsx_expression) -] @element +] @default diff --git a/crates/zed2/src/languages/javascript/overrides.scm b/crates/zed2/src/languages/javascript/overrides.scm index 8b43fdcfc5..eb0a33b067 100644 --- a/crates/zed2/src/languages/javascript/overrides.scm +++ b/crates/zed2/src/languages/javascript/overrides.scm @@ -8,6 +8,11 @@ [ (jsx_element) (jsx_fragment) +] @element + +[ + (jsx_opening_element) + (jsx_closing_element) (jsx_self_closing_element) (jsx_expression) -] @element +] @default diff --git a/crates/zed2/src/languages/tsx/overrides.scm b/crates/zed2/src/languages/tsx/overrides.scm index 8b43fdcfc5..eb0a33b067 100644 --- a/crates/zed2/src/languages/tsx/overrides.scm +++ b/crates/zed2/src/languages/tsx/overrides.scm @@ -8,6 +8,11 @@ [ (jsx_element) (jsx_fragment) +] @element + +[ + (jsx_opening_element) + (jsx_closing_element) (jsx_self_closing_element) (jsx_expression) -] @element +] @default