OLD | NEW |
| (Empty) |
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | |
2 // for details. All rights reserved. Use of this source code is governed by a | |
3 // BSD-style license that can be found in the LICENSE file. | |
4 | |
5 library analyzer.src.plugin.command_line_plugin; | |
6 | |
7 import 'package:analyzer/plugin/command_line.dart'; | |
8 import 'package:plugin/plugin.dart'; | |
9 | |
10 /** | |
11 * A plugin that defines the extension points and extensions that are defined by | |
12 * command-line applications using the analysis engine. | |
13 */ | |
14 class CommandLinePlugin implements Plugin { | |
15 /** | |
16 * The simple identifier of the extension point that allows plugins to | |
17 * register new parser contributors. | |
18 */ | |
19 static const String PARSER_CONTRIBUTOR_EXTENSION_POINT = 'parserContributor'; | |
20 | |
21 /** | |
22 * The simple identifier of the extension point that allows plugins to | |
23 * register new result processors. | |
24 */ | |
25 static const String RESULT_PROCESSOR_EXTENSION_POINT = 'resultProcessor'; | |
26 | |
27 /** | |
28 * The unique identifier of this plugin. | |
29 */ | |
30 static const String UNIQUE_IDENTIFIER = 'command_line.core'; | |
31 | |
32 /** | |
33 * The extension point that allows plugins to register new parser | |
34 * contributors. | |
35 */ | |
36 ExtensionPoint parserContributorExtensionPoint; | |
37 | |
38 /** | |
39 * The extension point that allows plugins to register new result processors. | |
40 */ | |
41 ExtensionPoint resultProcessorExtensionPoint; | |
42 | |
43 /** | |
44 * Initialize a newly created plugin. | |
45 */ | |
46 CommandLinePlugin(); | |
47 | |
48 /** | |
49 * Return a list containing all of the parser contributors that were | |
50 * contributed. | |
51 */ | |
52 List<ArgParserContributor> get parserContributors => | |
53 parserContributorExtensionPoint.extensions; | |
54 | |
55 /** | |
56 * Return a list containing all of the result processors that were | |
57 * contributed. | |
58 */ | |
59 List<ArgResultsProcessor> get resultProcessors => | |
60 resultProcessorExtensionPoint.extensions; | |
61 | |
62 @override | |
63 String get uniqueIdentifier => UNIQUE_IDENTIFIER; | |
64 | |
65 @override | |
66 void registerExtensionPoints(RegisterExtensionPoint registerExtensionPoint) { | |
67 parserContributorExtensionPoint = registerExtensionPoint( | |
68 PARSER_CONTRIBUTOR_EXTENSION_POINT, | |
69 _validateParserContributorExtension); | |
70 resultProcessorExtensionPoint = registerExtensionPoint( | |
71 RESULT_PROCESSOR_EXTENSION_POINT, _validateResultProcessorExtension); | |
72 } | |
73 | |
74 @override | |
75 void registerExtensions(RegisterExtension registerExtension) { | |
76 // There are no default extensions. | |
77 } | |
78 | |
79 /** | |
80 * Validate the given extension by throwing an [ExtensionError] if it is not a | |
81 * valid parser contributor. | |
82 */ | |
83 void _validateParserContributorExtension(Object extension) { | |
84 if (extension is! ArgParserContributor) { | |
85 String id = parserContributorExtensionPoint.uniqueIdentifier; | |
86 throw new ExtensionError( | |
87 'Extensions to $id must be an ArgParserContributor'); | |
88 } | |
89 } | |
90 | |
91 /** | |
92 * Validate the given extension by throwing an [ExtensionError] if it is not a | |
93 * valid result processor. | |
94 */ | |
95 void _validateResultProcessorExtension(Object extension) { | |
96 if (extension is! ArgResultsProcessor) { | |
97 String id = resultProcessorExtensionPoint.uniqueIdentifier; | |
98 throw new ExtensionError( | |
99 'Extensions to $id must be an ArgResultsProcessor'); | |
100 } | |
101 } | |
102 } | |
OLD | NEW |