Skip to content

Commit

Permalink
[analysis_server] Show correct type for enum.values
Browse files Browse the repository at this point in the history
Fixes Dart-Code/Dart-Code#4877

Change-Id: Ie9b7f223f71c4c79c141ca69356340ef8b15aceb
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/350720
Reviewed-by: Brian Wilkerson <[email protected]>
Reviewed-by: Phil Quitslund <[email protected]>
Commit-Queue: Brian Wilkerson <[email protected]>
  • Loading branch information
DanTup authored and Commit Queue committed Feb 6, 2024
1 parent fd2c27f commit bdf4528
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 2 deletions.
20 changes: 18 additions & 2 deletions pkg/analysis_server/lib/src/computer/computer_hover.dart
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,10 @@ class DartUnitHoverComputer {
// element
var element = ElementLocator.locate(node);
if (element != null) {
// variable, if synthetic accessor
if (element is PropertyAccessorElement) {
// use the non-synthetic element to get things like dartdoc from the
// underlying field (and resolved type args), except for `enum.values`
// because that will resolve to the enum itself.
if (_useNonSyntheticElement(element)) {
element = element.nonSynthetic;
}
// description
Expand Down Expand Up @@ -255,6 +257,20 @@ class DartUnitHoverComputer {
return staticType?.getDisplayString(withNullability: true);
}

/// Whether to use the non-synthetic element for hover information.
///
/// Usually we want this because the non-synthetic element will include the
/// users DartDoc and show any type arguments as declared.
///
/// For enum.values, nonSynthetic returns the enum itself which causes
/// incorrect types to be shown and so we stick with the synthetic getter.
bool _useNonSyntheticElement(Element element) {
return element is PropertyAccessorElement &&
!(element.enclosingElement is EnumElement &&
element.name == 'values' &&
element.isSynthetic);
}

static Documentation? computeDocumentation(
DartdocDirectiveInfo dartdocInfo, Element elementBeingDocumented,
{bool includeSummary = false}) {
Expand Down
36 changes: 36 additions & 0 deletions pkg/analysis_server/test/lsp/hover_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,42 @@ class HoverTest extends AbstractLspAnalysisServerTest {
Future<void> test_dartDocPreference_unset() =>
assertDocumentation(null, includesSummary: true, includesFull: true);

Future<void> test_enum_member() async {
final content = '''
enum MyEnum { one }
void f() {
MyEnum.[!o^ne!];
}
''';
final expected = '''
```dart
MyEnum one
```
Type: `MyEnum`
*package:test/main.dart*''';
await assertStringContents(content, equals(expected));
}

Future<void> test_enum_values() async {
final content = '''
enum MyEnum { one }
void f() {
MyEnum.[!va^lues!];
}
''';
final expected = '''
```dart
List<MyEnum> get values
```
Type: `List<MyEnum>`
*package:test/main.dart*''';
await assertStringContents(content, equals(expected));
}

Future<void> test_forLoop_declaredVariable() async {
final content = '''
void f() {
Expand Down

0 comments on commit bdf4528

Please sign in to comment.