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

Unified Diff: mojo/public/dart/third_party/analyzer/lib/src/plugin/options_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/options_plugin.dart
diff --git a/mojo/public/dart/third_party/analyzer/lib/src/plugin/options_plugin.dart b/mojo/public/dart/third_party/analyzer/lib/src/plugin/options_plugin.dart
new file mode 100644
index 0000000000000000000000000000000000000000..1dea284aa418db185a88155051e9d2220f4bf362
--- /dev/null
+++ b/mojo/public/dart/third_party/analyzer/lib/src/plugin/options_plugin.dart
@@ -0,0 +1,51 @@
+// 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.options;
+
+import 'package:analyzer/plugin/options.dart';
+import 'package:plugin/plugin.dart';
+
+/// A plugin that defines the extension points and extensions that are defined
+/// by applications that want to consume options defined in the analysis
+/// options file.
+class OptionsPlugin implements Plugin {
+
+ /// The simple identifier of the extension point that allows plugins to
+ /// register new options processors.
+ static const String OPTIONS_PROCESSOR_EXTENSION_POINT = 'optionsProcessor';
+
+ /// The unique identifier of this plugin.
+ static const String UNIQUE_IDENTIFIER = 'options.core';
+
+ /// The extension point that allows plugins to register new options processors.
+ ExtensionPoint optionsProcessorExtensionPoint;
+
+ /// All contributed options processors.
+ List<OptionsProcessor> get optionsProcessors =>
+ optionsProcessorExtensionPoint.extensions;
+
+ @override
+ String get uniqueIdentifier => UNIQUE_IDENTIFIER;
+
+ @override
+ void registerExtensionPoints(RegisterExtensionPoint registerExtensionPoint) {
+ optionsProcessorExtensionPoint = registerExtensionPoint(
+ OPTIONS_PROCESSOR_EXTENSION_POINT, _validateOptionsProcessorExtension);
+ }
+
+ @override
+ void registerExtensions(RegisterExtension registerExtension) {
+ // There are no default extensions.
+ }
+
+ /// Validate the given extension by throwing an [ExtensionError] if it is not a
+ /// valid options processor.
+ void _validateOptionsProcessorExtension(Object extension) {
+ if (extension is! OptionsProcessor) {
+ String id = optionsProcessorExtensionPoint.uniqueIdentifier;
+ throw new ExtensionError('Extensions to $id must be an OptionsProcessor');
+ }
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698