From e4756cb4f6e66097638b9d101589358976be2ba8 Mon Sep 17 00:00:00 2001 From: Chetan Khilosiya Date: Tue, 23 Feb 2021 00:17:48 +0530 Subject: 7526: Rename crate assists to ide_assists. --- .../src/handlers/replace_string_with_char.rs | 137 --------------------- 1 file changed, 137 deletions(-) delete mode 100644 crates/assists/src/handlers/replace_string_with_char.rs (limited to 'crates/assists/src/handlers/replace_string_with_char.rs') diff --git a/crates/assists/src/handlers/replace_string_with_char.rs b/crates/assists/src/handlers/replace_string_with_char.rs deleted file mode 100644 index 317318c24..000000000 --- a/crates/assists/src/handlers/replace_string_with_char.rs +++ /dev/null @@ -1,137 +0,0 @@ -use syntax::{ast, AstToken, SyntaxKind::STRING}; - -use crate::{AssistContext, AssistId, AssistKind, Assists}; - -// Assist: replace_string_with_char -// -// Replace string with char. -// -// ``` -// fn main() { -// find("{$0"); -// } -// ``` -// -> -// ``` -// fn main() { -// find('{'); -// } -// ``` -pub(crate) fn replace_string_with_char(acc: &mut Assists, ctx: &AssistContext) -> Option<()> { - let token = ctx.find_token_syntax_at_offset(STRING).and_then(ast::String::cast)?; - let value = token.value()?; - let target = token.syntax().text_range(); - - if value.chars().take(2).count() != 1 { - return None; - } - - acc.add( - AssistId("replace_string_with_char", AssistKind::RefactorRewrite), - "Replace string with char", - target, - |edit| { - edit.replace(token.syntax().text_range(), format!("'{}'", value)); - }, - ) -} - -#[cfg(test)] -mod tests { - use crate::tests::{check_assist, check_assist_not_applicable, check_assist_target}; - - use super::*; - - #[test] - fn replace_string_with_char_target() { - check_assist_target( - replace_string_with_char, - r#" - fn f() { - let s = "$0c"; - } - "#, - r#""c""#, - ); - } - - #[test] - fn replace_string_with_char_assist() { - check_assist( - replace_string_with_char, - r#" - fn f() { - let s = "$0c"; - } - "#, - r##" - fn f() { - let s = 'c'; - } - "##, - ) - } - - #[test] - fn replace_string_with_char_assist_with_emoji() { - check_assist( - replace_string_with_char, - r#" - fn f() { - let s = "$0😀"; - } - "#, - r##" - fn f() { - let s = '😀'; - } - "##, - ) - } - - #[test] - fn replace_string_with_char_assist_not_applicable() { - check_assist_not_applicable( - replace_string_with_char, - r#" - fn f() { - let s = "$0test"; - } - "#, - ) - } - - #[test] - fn replace_string_with_char_works_inside_macros() { - check_assist( - replace_string_with_char, - r#" - fn f() { - format!($0"x", 92) - } - "#, - r##" - fn f() { - format!('x', 92) - } - "##, - ) - } - - #[test] - fn replace_string_with_char_works_func_args() { - check_assist( - replace_string_with_char, - r#" - fn f() { - find($0"x"); - } - "#, - r##" - fn f() { - find('x'); - } - "##, - ) - } -} -- cgit v1.2.3