public abstract class ProfileChangeOperation extends Object implements IProfileChangeJob
IStatus result = op.resolveModal(monitor); if (result.isOK()) op.getProvisioningJob(null).runModal(monitor); else { // interpret the result }To perform the resolution synchronously and the provisioning job in the background:
IStatus status = op.resolveModal(monitor); if (status.isOK()) { ProvisioningJob job = op.getProvisioningJob(monitor); job.schedule(); } else { // interpret the result }To resolve in the background and perform the job when it is complete:
ProvisioningJob job = op.getResolveJob(monitor); job.addJobChangeListener(new JobChangeAdapter() { public void done (JobChangeEvent event) { if (event.getResult().isOK() { op.getProvisioningJob(monitor).schedule(); } else { // interpret the result } } }); job.schedule();In general, it is expected that clients create a new ProfileChangeOperation if the resolution result of the current operation is not satisfactory. However, subclasses may prescribe a different life cycle where appropriate. When retrieving the resolution and provisioning jobs managed by this operation, a client may supply a progress monitor to be used by the job. When the job is run by the platform job manager, both the platform job manager progress indicator and the monitor supplied by the client will be updated.
Modifier | Constructor and Description |
---|---|
protected |
ProfileChangeOperation(ProvisioningSession session)
Create an operation using the provided provisioning session.
|
Modifier and Type | Method and Description |
---|---|
protected abstract void |
computeProfileChangeRequest(MultiStatus status,
IProgressMonitor monitor)
Compute the profile change request for this operation, adding any relevant intermediate status
to the supplied status.
|
IProfileChangeRequest |
getProfileChangeRequest()
Return the profile change request that describes the receiver.
|
String |
getProfileId()
Return the string id of the profile involved in this job.
|
ProvisioningContext |
getProvisioningContext()
Get the provisioning context that will be used to resolve and perform the provisioning for
the operation.
|
ProvisioningJob |
getProvisioningJob(IProgressMonitor monitor)
Return a provisioning job that can be used to perform the resolved operation.
|
protected abstract String |
getProvisioningJobName()
Return an appropriate name for the provisioning job.
|
IProvisioningPlan |
getProvisioningPlan()
Return the provisioning plan obtained by resolving the receiver.
|
String |
getResolutionDetails()
Return a string that can be used to describe the results of the resolution
to a client.
|
String |
getResolutionDetails(IInstallableUnit iu)
Return a string that describes the specific resolution results
related to the supplied
IInstallableUnit . |
IStatus |
getResolutionResult()
Return a status indicating the result of resolving this
operation.
|
ProvisioningJob |
getResolveJob(IProgressMonitor monitor)
Return a job that can be used to resolve this operation in the background.
|
protected abstract String |
getResolveJobName()
Return an appropriate name for the resolution job.
|
boolean |
hasResolved()
Return a boolean indicating whether the operation has been resolved.
|
protected void |
prepareToResolve()
Perform any processing that must occur just before resolving this operation.
|
IStatus |
resolveModal(IProgressMonitor monitor)
Resolve the operation in the current thread using the specified progress
monitor.
|
void |
setProfileId(String id)
Set the id of the profile that will be modified by this operation.
|
void |
setProvisioningContext(ProvisioningContext context)
Set the provisioning context that should be used to resolve and perform the provisioning for
the operation.
|
protected void |
updateJobProvisioningContexts(org.eclipse.equinox.internal.p2.operations.PlannerResolutionJob job,
ProvisioningContext context) |
protected ProfileChangeOperation(ProvisioningSession session)
session
- the provisioning session providing the servicespublic final IStatus resolveModal(IProgressMonitor monitor)
monitor
- the progress monitor to usepublic void setProfileId(String id)
id
- the profile idpublic final ProvisioningJob getResolveJob(IProgressMonitor monitor)
monitor
- a progress monitor that should be used to report the job's progress in addition
to the standard job progress reporting. Can be null
. If provided, this monitor
will be called from a background thread.protected void prepareToResolve()
protected abstract void computeProfileChangeRequest(MultiStatus status, IProgressMonitor monitor)
status
- a multi-status to be used to add relevant status. If a profile change request cannot
be computed for any reason, a status should be added to explain the problem.monitor
- the progress monitor to use for computing the profile change requestprotected abstract String getResolveJobName()
protected abstract String getProvisioningJobName()
public IStatus getResolutionResult()
null
return indicates that
resolving has not occurred yet.null
if resolution has not yet occurred.public String getResolutionDetails()
null
if the
operation has not been resolved.public String getResolutionDetails(IInstallableUnit iu)
IInstallableUnit
.iu
- the IInstallableUnit for which resolution details are requestednull
if
there are no specific results available for the installable unit.public IProvisioningPlan getProvisioningPlan()
null
if the operation
has not been resolved, or if a plan could not be obtained when attempting to
resolve. If the plan is null and the operation has been resolved, then the
resolution result will explain the problem.hasResolved()
,
getResolutionResult()
public IProfileChangeRequest getProfileChangeRequest()
null
if the operation
has not been resolved, or if a profile change request could not be assembled given
the operation's state. If the profile change request is null and the operation has
been resolved, the the resolution result will explain the problem.hasResolved()
,
getResolutionResult()
public ProvisioningJob getProvisioningJob(IProgressMonitor monitor)
Job.setUser(boolean)
,
Job.setSystem(boolean)
, or Job.setProperty(QualifiedName, Object)
,
before scheduling it.monitor
- a progress monitor that should be used to report the job's progress in addition
to the standard job progress reporting. Can be null
. If provided, this monitor
will be called from a background thread.null
if the operation has not been resolved, or if a plan could not be obtained when attempting to
resolve. If the job is null and the operation has been resolved, then the resolution result
will explain the problem.hasResolved()
,
getResolutionResult()
public void setProvisioningContext(ProvisioningContext context)
context
- the provisioning context.public ProvisioningContext getProvisioningContext()
public String getProfileId()
IProfileChangeJob
getProfileId
in interface IProfileChangeJob
public boolean hasResolved()
false
while resolution is taking place if it is performed
in the background.true
if the operation has been resolved, false
if it has not resolved.protected void updateJobProvisioningContexts(org.eclipse.equinox.internal.p2.operations.PlannerResolutionJob job, ProvisioningContext context)
Copyright (c) 2000, 2015 Eclipse Contributors and others. All rights reserved.Guidelines for using Eclipse APIs.