Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(784)

Unified Diff: pkg/analysis_services/lib/src/completion/local_computer.dart

Issue 484733003: Import analysis_services.dart into analysis_server.dart. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: pkg/analysis_services/lib/src/completion/local_computer.dart
diff --git a/pkg/analysis_services/lib/src/completion/local_computer.dart b/pkg/analysis_services/lib/src/completion/local_computer.dart
deleted file mode 100644
index f65b775a45b529ce3217b48188ff30a6c30be9d2..0000000000000000000000000000000000000000
--- a/pkg/analysis_services/lib/src/completion/local_computer.dart
+++ /dev/null
@@ -1,197 +0,0 @@
-// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
-// for details. All rights reserved. Use of this source code is governed by a
-// BSD-style license that can be found in the LICENSE file.
-
-library services.completion.computer.dart.local;
-
-import 'dart:async';
-
-import 'package:analysis_services/completion/completion_suggestion.dart';
-import 'package:analysis_services/src/completion/dart_completion_manager.dart';
-import 'package:analyzer/src/generated/ast.dart';
-
-/**
- * A computer for calculating `completion.getSuggestions` request results
- * for the local library in which the completion is requested.
- */
-class LocalComputer extends DartCompletionComputer {
-
- @override
- bool computeFast(DartCompletionRequest request) {
-
- // Find the specific child [AstNode] that contains the completion offset
- // and collect suggestions starting with that node
- request.node.accept(new _LocalVisitor(request));
-
- // If the unit is not a part and does not reference any parts
- // then work is complete
- return !request.unit.directives.any(
- (Directive directive) =>
- directive is PartOfDirective || directive is PartDirective);
- }
-
- @override
- Future<bool> computeFull(DartCompletionRequest request) {
- // TODO: implement computeFull
- // include results from part files that are included in the library
- return new Future.value(false);
- }
-}
-
-/**
- * A visitor for collecting suggestions from the most specific child [AstNode]
- * that contains the completion offset to the [CompilationUnit].
- */
-class _LocalVisitor extends GeneralizingAstVisitor<dynamic> {
- final DartCompletionRequest request;
-
- _LocalVisitor(this.request);
-
- @override
- visitBlock(Block node) {
- node.statements.forEach((Statement stmt) {
- if (stmt.offset < request.offset) {
- if (stmt is LabeledStatement) {
- stmt.labels.forEach((Label label) {
-// _addSuggestion(label.label, CompletionSuggestionKind.LABEL);
- });
- } else if (stmt is VariableDeclarationStatement) {
- stmt.variables.variables.forEach((VariableDeclaration varDecl) {
- if (varDecl.end < request.offset) {
- _addSuggestion(
- varDecl.name,
- CompletionSuggestionKind.LOCAL_VARIABLE);
- }
- });
- }
- }
- });
- visitNode(node);
- }
-
- @override
- visitCatchClause(CatchClause node) {
- _addSuggestion(node.exceptionParameter, CompletionSuggestionKind.PARAMETER);
- _addSuggestion(node.stackTraceParameter, CompletionSuggestionKind.PARAMETER);
- visitNode(node);
- }
-
- @override
- visitClassDeclaration(ClassDeclaration node) {
- node.members.forEach((ClassMember classMbr) {
- if (classMbr is FieldDeclaration) {
- _addSuggestions(classMbr.fields, CompletionSuggestionKind.FIELD);
- } else if (classMbr is MethodDeclaration) {
- _addSuggestion(classMbr.name, CompletionSuggestionKind.METHOD_NAME);
- }
- });
- visitNode(node);
- }
-
- @override
- visitCompilationUnit(CompilationUnit node) {
- node.directives.forEach((Directive directive) {
- if (directive is ImportDirective) {
- _addSuggestion(
- directive.prefix,
- CompletionSuggestionKind.LIBRARY_PREFIX);
- }
- });
- node.declarations.forEach((Declaration declaration) {
- if (declaration is ClassDeclaration) {
- _addSuggestion(declaration.name, CompletionSuggestionKind.CLASS);
- } else if (declaration is EnumDeclaration) {
-// _addSuggestion(d.name, CompletionSuggestionKind.ENUM);
- } else if (declaration is FunctionDeclaration) {
- _addSuggestion(declaration.name, CompletionSuggestionKind.FUNCTION);
- } else if (declaration is TopLevelVariableDeclaration) {
- _addSuggestions(
- declaration.variables,
- CompletionSuggestionKind.TOP_LEVEL_VARIABLE);
- } else if (declaration is ClassTypeAlias) {
- _addSuggestion(declaration.name, CompletionSuggestionKind.CLASS_ALIAS);
- } else if (declaration is FunctionTypeAlias) {
- _addSuggestion(
- declaration.name,
- CompletionSuggestionKind.FUNCTION_TYPE_ALIAS);
- }
- });
- }
-
- @override
- visitForEachStatement(ForEachStatement node) {
- _addSuggestion(node.identifier, CompletionSuggestionKind.LOCAL_VARIABLE);
- visitNode(node);
- }
-
- @override
- visitForStatement(ForStatement node) {
- _addSuggestions(node.variables, CompletionSuggestionKind.LOCAL_VARIABLE);
- visitNode(node);
- }
-
- @override
- visitFunctionDeclaration(FunctionDeclaration node) {
- // This is added by the compilation unit containing it
- //_addSuggestion(node.name, CompletionSuggestionKind.FUNCTION);
- visitNode(node);
- }
-
- @override
- visitFunctionExpression(FunctionExpression node) {
- node.parameters.parameters.forEach((FormalParameter param) {
- _addSuggestion(param.identifier, CompletionSuggestionKind.PARAMETER);
- });
- visitNode(node);
- }
-
- @override
- visitMethodDeclaration(MethodDeclaration node) {
- node.parameters.parameters.forEach((FormalParameter param) {
- if (param.identifier != null) {
- _addSuggestion(param.identifier, CompletionSuggestionKind.PARAMETER);
- }
- });
- visitNode(node);
- }
-
- @override
- visitNode(AstNode node) {
- node.parent.accept(this);
- }
-
- @override
- visitVariableDeclaration(VariableDeclaration node) {
- // Do not add suggestions if editing the name in a var declaration
- SimpleIdentifier name = node.name;
- if (name == null ||
- name.offset < request.offset ||
- request.offset > name.end) {
- visitNode(node);
- }
- }
-
- void _addSuggestion(SimpleIdentifier id, CompletionSuggestionKind kind) {
- if (id != null) {
- String completion = id.name;
- if (completion != null && completion.length > 0) {
- request.suggestions.add(
- new CompletionSuggestion(
- kind,
- CompletionRelevance.DEFAULT,
- completion,
- completion.length,
- 0,
- false,
- false));
- }
- }
- }
-
- void _addSuggestions(VariableDeclarationList variables,
- CompletionSuggestionKind kind) {
- variables.variables.forEach((VariableDeclaration varDecl) {
- _addSuggestion(varDecl.name, kind);
- });
- }
-}
« no previous file with comments | « pkg/analysis_services/lib/src/completion/keyword_computer.dart ('k') | pkg/analysis_services/lib/src/correction/assist.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698