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

Unified Diff: mojo/public/dart/third_party/analyzer/lib/src/plugin/engine_plugin.dart

Issue 1346773002: Stop running pub get at gclient sync time and fix build bugs (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 3 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: mojo/public/dart/third_party/analyzer/lib/src/plugin/engine_plugin.dart
diff --git a/mojo/public/dart/third_party/analyzer/lib/src/plugin/engine_plugin.dart b/mojo/public/dart/third_party/analyzer/lib/src/plugin/engine_plugin.dart
new file mode 100644
index 0000000000000000000000000000000000000000..30d67e3eee4ca240580937823e3674abe8a8105b
--- /dev/null
+++ b/mojo/public/dart/third_party/analyzer/lib/src/plugin/engine_plugin.dart
@@ -0,0 +1,167 @@
+// Copyright (c) 2015, 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 analyzer.src.plugin.engine_plugin;
+
+import 'package:analyzer/plugin/task.dart';
+import 'package:analyzer/src/generated/engine.dart'
+ show InternalAnalysisContext;
+import 'package:analyzer/src/task/dart.dart';
+import 'package:analyzer/src/task/dart_work_manager.dart';
+import 'package:analyzer/src/task/general.dart';
+import 'package:analyzer/src/task/html.dart';
+import 'package:analyzer/src/task/html_work_manager.dart';
+import 'package:analyzer/task/model.dart';
+import 'package:plugin/plugin.dart';
+
+/**
+ * A plugin that defines the extension points and extensions that are inherently
+ * defined by the analysis engine.
+ */
+class EnginePlugin implements Plugin {
+ /**
+ * The simple identifier of the extension point that allows plugins to
+ * register new analysis tasks with the analysis engine.
+ */
+ static const String TASK_EXTENSION_POINT = 'task';
+
+ /**
+ * The simple identifier of the extension point that allows plugins to
+ * register new work manager factories with the analysis engine.
+ */
+ static const String WORK_MANAGER_FACTORY_EXTENSION_POINT =
+ 'workManagerFactory';
+
+ /**
+ * The unique identifier of this plugin.
+ */
+ static const String UNIQUE_IDENTIFIER = 'analysis_engine.core';
+
+ /**
+ * The extension point that allows plugins to register new analysis tasks with
+ * the analysis engine.
+ */
+ ExtensionPoint taskExtensionPoint;
+
+ /**
+ * The extension point that allows plugins to register new work manager
+ * factories with the analysis engine.
+ */
+ ExtensionPoint workManagerFactoryExtensionPoint;
+
+ /**
+ * Initialize a newly created plugin.
+ */
+ EnginePlugin();
+
+ /**
+ * Return a list containing all of the task descriptors that were contributed.
+ */
+ List<TaskDescriptor> get taskDescriptors => taskExtensionPoint.extensions;
+
+ @override
+ String get uniqueIdentifier => UNIQUE_IDENTIFIER;
+
+ /**
+ * Return a list containing all of the work manager factories that were
+ * contributed.
+ */
+ List<WorkManagerFactory> get workManagerFactories =>
+ workManagerFactoryExtensionPoint.extensions;
+
+ @override
+ void registerExtensionPoints(RegisterExtensionPoint registerExtensionPoint) {
+ taskExtensionPoint =
+ registerExtensionPoint(TASK_EXTENSION_POINT, _validateTaskExtension);
+ workManagerFactoryExtensionPoint = registerExtensionPoint(
+ WORK_MANAGER_FACTORY_EXTENSION_POINT,
+ _validateWorkManagerFactoryExtension);
+ }
+
+ @override
+ void registerExtensions(RegisterExtension registerExtension) {
+ _registerTaskExtensions(registerExtension);
+ _registerWorkManagerFactoryExtensions(registerExtension);
+ }
+
+ void _registerTaskExtensions(RegisterExtension registerExtension) {
+ String taskId = TASK_EXTENSION_POINT_ID;
+ //
+ // Register general tasks.
+ //
+ registerExtension(taskId, GetContentTask.DESCRIPTOR);
+ //
+ // Register Dart tasks.
+ //
+ registerExtension(taskId, BuildCompilationUnitElementTask.DESCRIPTOR);
+ registerExtension(taskId, BuildDirectiveElementsTask.DESCRIPTOR);
+ registerExtension(taskId, BuildEnumMemberElementsTask.DESCRIPTOR);
+ registerExtension(taskId, BuildExportNamespaceTask.DESCRIPTOR);
+ registerExtension(taskId, BuildLibraryElementTask.DESCRIPTOR);
+ registerExtension(taskId, BuildPublicNamespaceTask.DESCRIPTOR);
+ registerExtension(taskId, BuildSourceExportClosureTask.DESCRIPTOR);
+ registerExtension(taskId, BuildSourceImportExportClosureTask.DESCRIPTOR);
+ registerExtension(taskId, BuildTypeProviderTask.DESCRIPTOR);
+ registerExtension(taskId, ComputeConstantDependenciesTask.DESCRIPTOR);
+ registerExtension(taskId, ComputeConstantValueTask.DESCRIPTOR);
+ registerExtension(taskId, ComputeInferableStaticVariableDependenciesTask.DESCRIPTOR);
+ registerExtension(taskId, ContainingLibrariesTask.DESCRIPTOR);
+ registerExtension(taskId, DartErrorsTask.DESCRIPTOR);
+ registerExtension(taskId, EvaluateUnitConstantsTask.DESCRIPTOR);
+ registerExtension(taskId, GatherUsedImportedElementsTask.DESCRIPTOR);
+ registerExtension(taskId, GatherUsedLocalElementsTask.DESCRIPTOR);
+ registerExtension(taskId, GenerateHintsTask.DESCRIPTOR);
+ registerExtension(taskId, InferStaticVariableTypesInUnitTask.DESCRIPTOR);
+ registerExtension(taskId, InferStaticVariableTypeTask.DESCRIPTOR);
+ registerExtension(taskId, LibraryErrorsReadyTask.DESCRIPTOR);
+ registerExtension(taskId, LibraryUnitErrorsTask.DESCRIPTOR);
+ registerExtension(taskId, ParseDartTask.DESCRIPTOR);
+ registerExtension(taskId, PartiallyResolveUnitReferencesTask.DESCRIPTOR);
+ registerExtension(taskId, ResolveLibraryReferencesTask.DESCRIPTOR);
+ registerExtension(taskId, ResolveLibraryTypeNamesTask.DESCRIPTOR);
+ registerExtension(taskId, ResolveUnitReferencesTask.DESCRIPTOR);
+ registerExtension(taskId, ResolveUnitTypeNamesTask.DESCRIPTOR);
+ registerExtension(taskId, ResolveVariableReferencesTask.DESCRIPTOR);
+ registerExtension(taskId, ScanDartTask.DESCRIPTOR);
+ registerExtension(taskId, VerifyUnitTask.DESCRIPTOR);
+ //
+ // Register HTML tasks.
+ //
+ registerExtension(taskId, DartScriptsTask.DESCRIPTOR);
+ registerExtension(taskId, HtmlErrorsTask.DESCRIPTOR);
+ registerExtension(taskId, ParseHtmlTask.DESCRIPTOR);
+ }
+
+ void _registerWorkManagerFactoryExtensions(
+ RegisterExtension registerExtension) {
+ String taskId = WORK_MANAGER_EXTENSION_POINT_ID;
+ registerExtension(taskId,
+ (InternalAnalysisContext context) => new DartWorkManager(context));
+ registerExtension(taskId,
+ (InternalAnalysisContext context) => new HtmlWorkManager(context));
+ }
+
+ /**
+ * Validate the given extension by throwing an [ExtensionError] if it is not a
+ * valid domain.
+ */
+ void _validateTaskExtension(Object extension) {
+ if (extension is! TaskDescriptor) {
+ String id = taskExtensionPoint.uniqueIdentifier;
+ throw new ExtensionError('Extensions to $id must be a TaskDescriptor');
+ }
+ }
+
+ /**
+ * Validate the given extension by throwing an [ExtensionError] if it is not a
+ * valid domain.
+ */
+ void _validateWorkManagerFactoryExtension(Object extension) {
+ if (extension is! WorkManagerFactory) {
+ String id = taskExtensionPoint.uniqueIdentifier;
+ throw new ExtensionError(
+ 'Extensions to $id must be a WorkManagerFactory');
+ }
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698