javadocs for RunConfigurationExtensionBase

This commit is contained in:
Dmitry Jemerov
2013-08-01 19:11:54 +02:00
parent 389a951264
commit b5734319aa

View File

@@ -29,28 +29,62 @@ import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
/**
* Allows a plugin to extend a run configuration created by another plugin.
*
* @author traff
*/
public abstract class RunConfigurationExtensionBase<T extends RunConfigurationBase> {
/**
* Returns the ID used to serialize the settings.
*
* @return the serialization ID (must be unique across all run configuration extensions).
*/
@NotNull
protected abstract String getSerializationId();
protected String getSerializationId() {
return getClass().getCanonicalName();
}
/**
* Loads the settings of this extension from the run configuration XML element. In memory, the settings can be placed into the
* userdata of the run configuration.
*
* @param runConfiguration the run configuration being deserialized.
* @param element the element with persisted settings.
*/
protected abstract void readExternal(@NotNull final T runConfiguration,
@NotNull final Element element) throws InvalidDataException;
/**
* Saves the settings of this extension to the run configuration XML element.
*
* @param runConfiguration the run configuration being serialized.
* @param element the element into which the settings should be persisted,
*/
protected abstract void writeExternal(@NotNull final T runConfiguration,
@NotNull final Element element) throws WriteExternalException;
/**
* Creates an editor for the settings of this extension. The editor is displayed as an additional tab of the run configuration options
* in the Run/Debug Configurations dialog.
*
* @param configuration the configuration being edited.
* @return the editor component, or null if this extension doesn't provide any UI for editing the settings.
*/
@Nullable
protected abstract <P extends T> SettingsEditor<P> createEditor(@NotNull final P configuration);
/**
* Returns the title of the tab in which the settings editor is displayed.
*
* @return the editor tab title, or null if this extension doesn't provide any UI for editing the settings.
*/
@Nullable
protected abstract String getEditorTitle();
/**
* @param configuration Run configuration
* @return True if extension in general applicable to given run configuration - just to attach settings tab, etc. But extension may be
* turned off in it's settings. E.g. RCov in general available for given run configuration, but may be turned off.
* turned off in its settings. E.g. RCov in general available for given run configuration, but may be turned off.
*/
protected abstract boolean isApplicableFor(@NotNull final T configuration);
@@ -58,39 +92,59 @@ public abstract class RunConfigurationExtensionBase<T extends RunConfigurationBa
*
* @param applicableConfiguration Applicable run configuration
* @param runnerSettings
* @return True if extension is tuned on in configuration extension settings.
* @return True if extension is turned on in configuration extension settings.
* E.g. RCov is turned on for given run configuration.
*/
protected abstract boolean isEnabledFor(@NotNull final T applicableConfiguration, @Nullable RunnerSettings runnerSettings);
/**
* Patches the command line of the process about to be started by the underlying run configuration.
*
* @param configuration the underlying run configuration.
* @param runnerSettings the runner-specific settings.
* @param cmdLine the command line of the process about to be started.
* @param runnerId the ID of the {@link com.intellij.execution.runners.ProgramRunner} used to start the process.
* @throws ExecutionException if there was an error configuring the command line and the execution should be canceled.
*/
protected abstract void patchCommandLine(@NotNull final T configuration,
RunnerSettings runnerSettings, @NotNull final GeneralCommandLine cmdLine,
@NotNull final String runnerId) throws ExecutionException;
/**
* Attaches the extension to a process that has been started.
*
* @param configuration the underlying run configuration.
* @param handler the ProcessHandler for the running process.
* @param runnerSettings the runner-specific settings.
*/
protected void attachToProcess(@NotNull final T configuration,
@NotNull final ProcessHandler handler,
RunnerSettings runnerSettings) {
}
/**
* Validate extensions after general configuration validation passed
*
* @param configuration
* @param isExecution
* @param <T>
* @param isExecution true if the configuration is about to be executed, false if the configuration settings are being edited.
* @throws com.intellij.execution.ExecutionException
*
*/
protected abstract void validateConfiguration(@NotNull final T configuration,
final boolean isExecution) throws Exception;
protected void validateConfiguration(@NotNull final T configuration, final boolean isExecution) throws Exception {
}
/**
* Setup extension settings for created run configuration
* Setup extension settings for a run configuration that has been created from context.
*
* @param configuration Configuration
* @param location
* @param configuration Configuration created from context.
* @param location the location from which the configuration was created.
*/
protected abstract void extendCreatedConfiguration(@NotNull final T configuration,
@NotNull final Location location);
protected void extendCreatedConfiguration(@NotNull final T configuration,
@NotNull final Location location) {
protected abstract void extendTemplateConfiguration(@NotNull final T configuration);
}
protected abstract void attachToProcess(@NotNull final T configuration,
@NotNull final ProcessHandler handler,
RunnerSettings runnerSettings);
protected void extendTemplateConfiguration(@NotNull final T configuration) {
}
}