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

Unified Diff: pkg/analysis_services/lib/completion/completion_manager.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
« no previous file with comments | « pkg/analysis_services/LICENSE ('k') | pkg/analysis_services/lib/completion/completion_suggestion.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: pkg/analysis_services/lib/completion/completion_manager.dart
diff --git a/pkg/analysis_services/lib/completion/completion_manager.dart b/pkg/analysis_services/lib/completion/completion_manager.dart
deleted file mode 100644
index c9546056e1129f7e2c3e95551d552ad78e71af67..0000000000000000000000000000000000000000
--- a/pkg/analysis_services/lib/completion/completion_manager.dart
+++ /dev/null
@@ -1,104 +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;
-
-import 'dart:async';
-
-import 'package:analysis_services/completion/completion_suggestion.dart';
-import 'package:analysis_services/search/search_engine.dart';
-import 'package:analysis_services/src/completion/dart_completion_manager.dart';
-import 'package:analyzer/src/generated/engine.dart';
-import 'package:analyzer/src/generated/source.dart';
-
-/**
- * Manages `CompletionComputer`s for a given completion request.
- */
-abstract class CompletionManager {
-
- StreamController<CompletionResult> controller;
-
- /**
- * Compute completion results and append them to the stream.
- * Subclasses should override this method, append at least one result
- * to the [controller], and close the controller stream once complete.
- * Clients should not call this method directly as it is automatically called
- * when a client listens to the stream returned by [results].
- */
- void compute();
-
- /**
- * Generate a stream of code completion results.
- */
- Stream<CompletionResult> results() {
- controller = new StreamController<CompletionResult>(onListen: () {
- scheduleMicrotask(compute);
- });
- return controller.stream;
- }
-
- /**
- * Create a manager for the given request.
- */
- static CompletionManager create(AnalysisContext context, Source source,
- int offset, SearchEngine searchEngine) {
- if (context != null) {
- if (AnalysisEngine.isDartFileName(source.shortName)) {
- return new DartCompletionManager(context, searchEngine, source, offset);
- }
- if (AnalysisEngine.isHtmlFileName(source.shortName)) {
- //TODO (danrubel) implement
-// return new HtmlCompletionManager(context, searchEngine, source, offset);
- }
- }
- return new NoOpCompletionManager(source, offset);
- }
-}
-
-/**
- * Code completion result generated by an [CompletionManager].
- */
-class CompletionResult {
-
- /**
- * The length of the text to be replaced if the remainder of the identifier
- * containing the cursor is to be replaced when the suggestion is applied
- * (that is, the number of characters in the existing identifier).
- */
- final int replacementLength;
-
- /**
- * The offset of the start of the text to be replaced. This will be different
- * than the offset used to request the completion suggestions if there was a
- * portion of an identifier before the original offset. In particular, the
- * replacementOffset will be the offset of the beginning of said identifier.
- */
- final int replacementOffset;
-
- /**
- * The suggested completions.
- */
- final List<CompletionSuggestion> suggestions;
-
- /**
- * `true` if this is that last set of results that will be returned
- * for the indicated completion.
- */
- final bool last;
-
- CompletionResult(this.replacementOffset, this.replacementLength,
- this.suggestions, this.last);
-}
-
-class NoOpCompletionManager extends CompletionManager {
- final Source source;
- final int offset;
-
- NoOpCompletionManager(this.source, this.offset);
-
- @override
- void compute() {
- controller.add(new CompletionResult(offset, 0, [], true));
- }
-}
« no previous file with comments | « pkg/analysis_services/LICENSE ('k') | pkg/analysis_services/lib/completion/completion_suggestion.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698