blob: eaabc26669b265e003fda6004c0bb81e4c517b89 [file] [log] [blame]
// 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.
/**
* Support for client code that extends the analysis server by adding new
* occurrences contributors.
*
* Plugins can register occurrences contributors. The registered contributors
* will be used to get occurrence information any time the server is about to
* send an 'analysis.occurrences' notification.
*
* If a plugin wants to add occurrence information, it should implement the
* class [OccurrencesContributor] and then register the contributor by including
* code like the following in the plugin's registerExtensions method:
*
* @override
* void registerExtensions(RegisterExtension registerExtension) {
* ...
* registerExtension(
* OCCURRENCES_CONTRIBUTOR_EXTENSION_POINT_ID,
* new MyOccurrencesContributor());
* ...
* }
*/
library analysis_server.plugin.occurrences;
import 'package:analysis_server/analysis/occurrences_core.dart';
import 'package:analysis_server/src/plugin/server_plugin.dart';
import 'package:plugin/plugin.dart';
/**
* The identifier of the extension point that allows plugins to register
* occurrence information. The object used as an extension must be an
* [OccurrencesContributor].
*/
final String OCCURRENCES_CONTRIBUTOR_EXTENSION_POINT_ID = Plugin.join(
ServerPlugin.UNIQUE_IDENTIFIER,
ServerPlugin.OCCURRENCES_CONTRIBUTOR_EXTENSION_POINT);