--- /dev/null
+/*
+ * Copyright 2000-2015 JetBrains s.r.o.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.intellij.diff;
+
+import com.intellij.diff.requests.DiffRequest;
+import com.intellij.openapi.extensions.ExtensionPointName;
+import org.jetbrains.annotations.CalledInAwt;
+import org.jetbrains.annotations.NotNull;
+
+public abstract class DiffExtension {
+ public static final ExtensionPointName<DiffExtension> EP_NAME = ExtensionPointName.create("com.intellij.diff.DiffExtension");
+
+ @CalledInAwt
+ public abstract void onViewerCreated(@NotNull FrameDiffTool.DiffViewer viewer,
+ @NotNull DiffContext context,
+ @NotNull DiffRequest request);
+}
DiffViewer viewer = frameTool.createComponent(myContext, myActiveRequest);
+ for (DiffExtension extension : DiffExtension.EP_NAME.getExtensions()) {
+ extension.onViewerCreated(viewer, myContext, myActiveRequest);
+ }
+
DiffViewerWrapper wrapper = myActiveRequest.getUserData(DiffViewerWrapper.KEY);
if (wrapper == null) {
return new DefaultState(viewer, frameTool);
<extensionPoint qualifiedName="com.intellij.diff.DiffTool" interface="com.intellij.diff.DiffTool"/>
<extensionPoint qualifiedName="com.intellij.diff.merge.MergeTool" interface="com.intellij.diff.merge.MergeTool"/>
+ <extensionPoint qualifiedName="com.intellij.diff.DiffExtension" interface="com.intellij.diff.DiffExtension"/>
<extensionPoint name="testStatusListener" interface="com.intellij.execution.testframework.TestStatusListener"/>
<extensionPoint name="runConfigurationBeforeRunProviderDelegate" interface="com.intellij.execution.impl.RunConfigurationBeforeRunProviderDelegate"/>