Compare commits

...

3 Commits

Author SHA1 Message Date
Conrad Irwin
643a9e1be8 vim: Add vif/vaf (for Rust) 2024-10-30 10:15:29 -06:00
Peter Tripp
662a4440cc v0.161.x dev 2024-10-30 11:06:39 -04:00
Marshall Bowers
5dee43b05c dart: Extract to zed-extensions/dart repository (#19959)
This PR extracts the Dart extension to the
[zed-extensions/dart](https://github.com/zed-extensions/dart)
repository.

Release Notes:

- N/A
2024-10-30 11:00:06 -04:00
19 changed files with 47 additions and 601 deletions

9
Cargo.lock generated
View File

@@ -15033,7 +15033,7 @@ dependencies = [
[[package]]
name = "zed"
version = "0.160.0"
version = "0.161.0"
dependencies = [
"activity_indicator",
"anyhow",
@@ -15173,13 +15173,6 @@ dependencies = [
"zed_extension_api 0.1.0",
]
[[package]]
name = "zed_dart"
version = "0.1.2"
dependencies = [
"zed_extension_api 0.1.0",
]
[[package]]
name = "zed_deno"
version = "0.0.2"

View File

@@ -138,7 +138,6 @@ members = [
"extensions/astro",
"extensions/clojure",
"extensions/csharp",
"extensions/dart",
"extensions/deno",
"extensions/elixir",
"extensions/elm",

View File

@@ -404,7 +404,8 @@
"shift-b": "vim::CurlyBrackets",
"<": "vim::AngleBrackets",
">": "vim::AngleBrackets",
"a": "vim::Argument"
"a": "vim::Argument",
"f": "vim::OutlineObject"
}
},
{

View File

@@ -31,7 +31,8 @@
(visibility_modifier)? @context
(function_modifiers)? @context
"fn" @context
name: (_) @name) @item
name: (_) @name
body: (_ "{" @open (_)* "}" @close)) @item
(function_signature_item
(visibility_modifier)? @context

View File

@@ -4,7 +4,7 @@ use crate::{motion::right, state::Mode, Vim};
use editor::{
display_map::{DisplaySnapshot, ToDisplayPoint},
movement::{self, FindRange},
Bias, DisplayPoint, Editor,
Bias, DisplayPoint, Editor, ToOffset,
};
use itertools::Itertools;
@@ -29,6 +29,7 @@ pub enum Object {
AngleBrackets,
Argument,
Tag,
OutlineObject,
}
#[derive(Clone, Deserialize, PartialEq)]
@@ -54,7 +55,8 @@ actions!(
CurlyBrackets,
AngleBrackets,
Argument,
Tag
Tag,
OutlineObject
]
);
@@ -100,6 +102,9 @@ pub fn register(editor: &mut Editor, cx: &mut ViewContext<Vim>) {
Vim::action(editor, cx, |vim, _: &Argument, cx| {
vim.object(Object::Argument, cx)
});
Vim::action(editor, cx, |vim, _: &OutlineObject, cx| {
vim.object(Object::OutlineObject, cx)
});
}
impl Vim {
@@ -129,7 +134,8 @@ impl Object {
| Object::AngleBrackets
| Object::CurlyBrackets
| Object::SquareBrackets
| Object::Argument => true,
| Object::Argument
| Object::OutlineObject => true,
}
}
@@ -144,7 +150,8 @@ impl Object {
| Object::SquareBrackets
| Object::Tag
| Object::CurlyBrackets
| Object::AngleBrackets => true,
| Object::AngleBrackets
| Object::OutlineObject => true,
}
}
@@ -167,7 +174,8 @@ impl Object {
| Object::AngleBrackets
| Object::VerticalBars
| Object::Tag
| Object::Argument => Mode::Visual,
| Object::Argument
| Object::OutlineObject => Mode::Visual,
Object::Paragraph => Mode::VisualLine,
}
}
@@ -215,6 +223,7 @@ impl Object {
surrounding_markers(map, relative_to, around, self.is_multiline(), '<', '>')
}
Object::Argument => argument(map, relative_to, around),
Object::OutlineObject => outline_object(map, selection.start, selection.end, around),
}
}
@@ -564,6 +573,32 @@ fn argument(
}
}
fn outline_object(
map: &DisplaySnapshot,
start: DisplayPoint,
end: DisplayPoint,
around: bool,
) -> Option<Range<DisplayPoint>> {
println!("outline object!!!!");
let start_offset = start.to_offset(&map, Bias::Left);
let end_offset = end.to_offset(&map, Bias::Left);
let (_buffer_id, symbols) = map.buffer_snapshot.symbols_containing(start_offset, None)?;
for symbol in symbols.iter().rev() {
let range = if around {
&symbol.range
} else {
dbg!(symbol.body_range.as_ref()).unwrap_or(&symbol.range)
};
let start = range.start.to_offset(&map.buffer_snapshot);
let end = range.end.to_offset(&map.buffer_snapshot);
if start < start_offset && end > end_offset {
return Some(start.to_display_point(&map)..end.to_display_point(&map));
}
}
dbg!("none");
return None;
}
fn sentence(
map: &DisplaySnapshot,
relative_to: DisplayPoint,

View File

@@ -2,7 +2,7 @@
description = "The fast, collaborative code editor."
edition = "2021"
name = "zed"
version = "0.160.0"
version = "0.161.0"
publish = false
license = "GPL-3.0-or-later"
authors = ["Zed Team <hi@zed.dev>"]

View File

@@ -1,6 +1,6 @@
# Dart
Dart support is available through the [Dart extension](https://github.com/zed-industries/zed/tree/main/extensions/dart).
Dart support is available through the [Dart extension](https://github.com/zed-extensions/dart).
- Tree Sitter: [UserNobody14/tree-sitter-dart](https://github.com/UserNobody14/tree-sitter-dart)
- Language Server: [dart language-server](https://github.com/dart-lang/sdk)

View File

@@ -1,16 +0,0 @@
[package]
name = "zed_dart"
version = "0.1.2"
edition = "2021"
publish = false
license = "Apache-2.0"
[lints]
workspace = true
[lib]
path = "src/dart.rs"
crate-type = ["cdylib"]
[dependencies]
zed_extension_api = "0.1.0"

View File

@@ -1 +0,0 @@
../../LICENSE-APACHE

View File

@@ -1,6 +0,0 @@
## Roadmap
1. Add `dart run` command.
2. Add `dart test` command.
3. Add `flutter test --name` command, to allow running a single test or group of tests.
4. Auto hot reload Flutter app when files change.

View File

@@ -1,16 +0,0 @@
id = "dart"
name = "Dart"
description = "Dart support."
version = "0.1.2"
schema_version = 1
authors = ["Abdullah Alsigar <abdullah.alsigar@gmail.com>", "Flo <flo80@users.noreply.github.com>", "ybbond <hi@ybbond.id>"]
repository = "https://github.com/zed-industries/zed"
[language_servers.dart]
name = "Dart LSP"
language = "Dart"
languages = ["Dart"]
[grammars.dart]
repository = "https://github.com/UserNobody14/tree-sitter-dart"
commit = "6da46473ab8accb13da48113f4634e729a71d335"

View File

@@ -1,6 +0,0 @@
("(" @open ")" @close)
("[" @open "]" @close)
("{" @open "}" @close)
("<" @open ">" @close)
("\"" @open "\"" @close)
("'" @open "'" @close)

View File

@@ -1,15 +0,0 @@
name = "Dart"
grammar = "dart"
path_suffixes = ["dart"]
line_comments = ["// ", "/// "]
autoclose_before = ";:.,=}])>"
brackets = [
{ start = "{", end = "}", close = true, newline = true },
{ start = "[", end = "]", close = true, newline = true },
{ start = "(", end = ")", close = true, newline = true },
{ start = "<", end = ">", close = true, newline = false},
{ start = "\"", end = "\"", close = true, newline = false, not_in = ["string"] },
{ start = "'", end = "'", close = true, newline = false, not_in = ["string"] },
{ start = "/*", end = " */", close = true, newline = false, not_in = ["string", "comment"] },
{ start = "`", end = "`", close = true, newline = false, not_in = ["string", "comment"] },
]

View File

@@ -1,269 +0,0 @@
(dotted_identifier_list) @string
; Methods
; --------------------
(super) @function
(function_expression_body (identifier) @type)
; ((identifier)(selector (argument_part)) @function)
(((identifier) @function (#match? @function "^_?[a-z]"))
. (selector . (argument_part))) @function
; Annotations
; --------------------
(annotation
name: (identifier) @attribute)
; Operators and Tokens
; --------------------
(template_substitution
"$" @punctuation.special
"{" @punctuation.special
"}" @punctuation.special) @none
(template_substitution
"$" @punctuation.special
(identifier_dollar_escaped) @variable) @none
(escape_sequence) @string.escape
[
"@"
"=>"
".."
"??"
"=="
"?"
":"
"&&"
"%"
"<"
">"
"="
">="
"<="
"||"
(multiplicative_operator)
(increment_operator)
(is_operator)
(prefix_operator)
(equality_operator)
(additive_operator)
] @operator
[
"("
")"
"["
"]"
"{"
"}"
] @punctuation.bracket
; Delimiters
; --------------------
[
";"
"."
","
] @punctuation.delimiter
; Types
; --------------------
(class_definition
name: (identifier) @type)
(constructor_signature
name: (identifier) @type)
(scoped_identifier
scope: (identifier) @type)
(function_signature
name: (identifier) @function.method)
(getter_signature
(identifier) @function.method)
(setter_signature
name: (identifier) @function.method)
(enum_declaration
name: (identifier) @type)
(enum_constant
name: (identifier) @type)
(void_type) @type
((scoped_identifier
scope: (identifier) @type
name: (identifier) @type)
(#match? @type "^[a-zA-Z]"))
(type_identifier) @type
(type_alias
(type_identifier) @type.definition)
; Variables
; --------------------
; var keyword
(inferred_type) @keyword
((identifier) @type
(#match? @type "^_?[A-Z].*[a-z]"))
("Function" @type)
; properties
(unconditional_assignable_selector
(identifier) @property)
(conditional_assignable_selector
(identifier) @property)
; assignments
(assignment_expression
left: (assignable_expression) @variable)
(this) @variable.builtin
; Parameters
; --------------------
(formal_parameter
name: (identifier) @variable.parameter)
(named_argument
(label
(identifier) @variable.parameter))
; Literals
; --------------------
[
(hex_integer_literal)
(decimal_integer_literal)
(decimal_floating_point_literal)
; TODO: inaccessible nodes
; (octal_integer_literal)
; (hex_floating_point_literal)
] @number
(symbol_literal) @string.special.symbol
(string_literal) @string
(true) @boolean
(false) @boolean
(null_literal) @constant.builtin
(comment) @comment
(documentation_comment) @comment.documentation
; Keywords
; --------------------
[
"import"
"library"
"export"
"as"
"show"
"hide"
] @keyword.import
; Reserved words (cannot be used as identifiers)
[
(case_builtin)
"late"
"required"
"extension"
"on"
"class"
"enum"
"extends"
"in"
"is"
"new"
"super"
"with"
] @keyword
"return" @keyword.return
; Built in identifiers:
; alone these are marked as keywords
[
"deferred"
"factory"
"get"
"implements"
"interface"
"library"
"operator"
"mixin"
"part"
"set"
"typedef"
] @keyword
[
"async"
"async*"
"sync*"
"await"
"yield"
] @keyword.coroutine
[
(const_builtin)
(final_builtin)
"abstract"
"covariant"
"dynamic"
"external"
"static"
"final"
"base"
"sealed"
] @type.qualifier
; when used as an identifier:
((identifier) @variable.builtin
(#any-of? @variable.builtin
"abstract"
"as"
"covariant"
"deferred"
"dynamic"
"export"
"external"
"factory"
"Function"
"get"
"implements"
"import"
"interface"
"library"
"operator"
"mixin"
"part"
"set"
"static"
"typedef"))
[
"if"
"else"
"switch"
"default"
] @keyword.conditional
[
"try"
"throw"
"catch"
"finally"
(break_statement)
] @keyword.exception
[
"do"
"while"
"continue"
"for"
] @keyword.repeat

View File

@@ -1,3 +0,0 @@
(_ "[" "]" @end) @indent
(_ "{" "}" @end) @indent
(_ "(" ")" @end) @indent

View File

@@ -1,18 +0,0 @@
(class_definition
"class" @context
name: (_) @name) @item
(function_signature
name: (_) @name) @item
(getter_signature
"get" @context
name: (_) @name) @item
(setter_signature
"set" @context
name: (_) @name) @item
(enum_declaration
"enum" @context
name: (_) @name) @item

View File

@@ -1,45 +0,0 @@
; Flutter main
(
(
(import_or_export
(library_import
(import_specification
("import"
(configurable_uri
(uri
(string_literal) @_import
(#match? @_import "package:flutter/(material|widgets|cupertino).dart")
(#not-match? @_import "package:flutter_test/flutter_test.dart")
(#not-match? @_import "package:test/test.dart")
))))))
(
(function_signature
name: (_) @run
)
(#eq? @run "main")
)
(#set! tag flutter-main)
)
)
; Flutter test main
(
(
(import_or_export
(library_import
(import_specification
("import"
(configurable_uri
(uri
(string_literal) @_import
(#match? @_import "package:flutter_test/flutter_test.dart")
))))))
(
(function_signature
name: (_) @run
)
(#eq? @run "main")
)
(#set! tag flutter-test-main)
)
)

View File

@@ -1,26 +0,0 @@
[
{
"label": "flutter run",
"command": "flutter",
"args": ["run"],
"tags": ["flutter-main"]
},
{
"label": "fvm flutter run",
"command": "fvm flutter",
"args": ["run"],
"tags": ["flutter-main"]
},
{
"label": "flutter test $ZED_STEM",
"command": "flutter",
"args": ["test", "$ZED_FILE"],
"tags": ["flutter-test-main"]
},
{
"label": "fvm flutter test $ZED_STEM",
"command": "fvm flutter",
"args": ["test", "$ZED_FILE"],
"tags": ["flutter-test-main"]
}
]

View File

@@ -1,162 +0,0 @@
use zed::lsp::CompletionKind;
use zed::settings::LspSettings;
use zed::{CodeLabel, CodeLabelSpan};
use zed_extension_api::{self as zed, serde_json, Result};
struct DartBinary {
pub path: String,
pub args: Option<Vec<String>>,
}
struct DartExtension;
impl DartExtension {
fn language_server_binary(
&mut self,
_language_server_id: &zed::LanguageServerId,
worktree: &zed::Worktree,
) -> Result<DartBinary> {
let binary_settings = LspSettings::for_worktree("dart", worktree)
.ok()
.and_then(|lsp_settings| lsp_settings.binary);
let binary_args = binary_settings
.as_ref()
.and_then(|binary_settings| binary_settings.arguments.clone());
if let Some(path) = binary_settings.and_then(|binary_settings| binary_settings.path) {
return Ok(DartBinary {
path,
args: binary_args,
});
}
if let Some(path) = worktree.which("dart") {
return Ok(DartBinary {
path,
args: binary_args,
});
}
Err(
"dart must be installed from dart.dev/get-dart or pointed to by the LSP binary settings"
.to_string(),
)
}
}
impl zed::Extension for DartExtension {
fn new() -> Self {
Self
}
fn language_server_command(
&mut self,
language_server_id: &zed::LanguageServerId,
worktree: &zed::Worktree,
) -> Result<zed::Command> {
let dart_binary = self.language_server_binary(language_server_id, worktree)?;
Ok(zed::Command {
command: dart_binary.path,
args: dart_binary.args.unwrap_or_else(|| {
vec!["language-server".to_string(), "--protocol=lsp".to_string()]
}),
env: Default::default(),
})
}
fn language_server_workspace_configuration(
&mut self,
_language_server_id: &zed::LanguageServerId,
worktree: &zed::Worktree,
) -> Result<Option<serde_json::Value>> {
let settings = LspSettings::for_worktree("dart", worktree)
.ok()
.and_then(|lsp_settings| lsp_settings.settings.clone())
.unwrap_or_default();
Ok(Some(serde_json::json!({
"dart": settings
})))
}
fn label_for_completion(
&self,
_language_server_id: &zed::LanguageServerId,
completion: zed::lsp::Completion,
) -> Option<CodeLabel> {
let arrow = "";
match completion.kind? {
CompletionKind::Class => Some(CodeLabel {
filter_range: (0..completion.label.len()).into(),
spans: vec![CodeLabelSpan::literal(
completion.label,
Some("type".into()),
)],
code: String::new(),
}),
CompletionKind::Function | CompletionKind::Constructor | CompletionKind::Method => {
let mut parts = completion.detail.as_ref()?.split(arrow);
let (name, _) = completion.label.split_once('(')?;
let parameter_list = parts.next()?;
let return_type = parts.next()?;
let fn_name = " a";
let fat_arrow = " => ";
let call_expr = "();";
let code =
format!("{return_type}{fn_name}{parameter_list}{fat_arrow}{name}{call_expr}");
let parameter_list_start = return_type.len() + fn_name.len();
Some(CodeLabel {
spans: vec![
CodeLabelSpan::code_range(
code.len() - call_expr.len() - name.len()..code.len() - call_expr.len(),
),
CodeLabelSpan::code_range(
parameter_list_start..parameter_list_start + parameter_list.len(),
),
CodeLabelSpan::literal(arrow, None),
CodeLabelSpan::code_range(0..return_type.len()),
],
filter_range: (0..name.len()).into(),
code,
})
}
CompletionKind::Property => {
let class_start = "class A {";
let get = " get ";
let property_end = " => a; }";
let ty = completion.detail?;
let name = completion.label;
let code = format!("{class_start}{ty}{get}{name}{property_end}");
let name_start = class_start.len() + ty.len() + get.len();
Some(CodeLabel {
spans: vec![
CodeLabelSpan::code_range(name_start..name_start + name.len()),
CodeLabelSpan::literal(arrow, None),
CodeLabelSpan::code_range(class_start.len()..class_start.len() + ty.len()),
],
filter_range: (0..name.len()).into(),
code,
})
}
CompletionKind::Variable => {
let name = completion.label;
Some(CodeLabel {
filter_range: (0..name.len()).into(),
spans: vec![CodeLabelSpan::literal(name, Some("variable".into()))],
code: String::new(),
})
}
_ => None,
}
}
}
zed::register_extension!(DartExtension);