blob: 93dbdeb96cde90f9b22995106cd4a4b9b1a04257 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005, 2008 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - Initial API and implementation
*******************************************************************************/
package org.eclipse.wst.server.core.internal;
import java.util.List;
import org.eclipse.core.runtime.IAdaptable;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.osgi.util.NLS;
import org.eclipse.wst.server.core.IModule;
import org.eclipse.wst.server.core.IServer;
import org.eclipse.wst.server.core.ServerCore;
/**
* Job to publish to a particular server.
*
* @deprecated - use API directly, it will kick off jobs as required
*/
public class PublishServerJob extends ChainedJob {
protected int kind;
protected boolean check;
protected List<IModule[]> modules;
protected IAdaptable info;
/**
* Create a new publishing job.
*
* @param server the server to publish to
* @param kind the kind of publish
* @param info the IAdaptable (or <code>null</code>) provided by the
* caller in order to supply UI information for prompting the
* user if necessary. When this parameter is not
* <code>null</code>, it should minimally contain an adapter
* for the Shell class.
*/
public PublishServerJob(IServer server, int kind, IAdaptable info) {
this(server, kind, null, info);
}
/**
* Create a new publishing job.
*
* @param server the server to publish to
* @param kind the kind of publish
* @param modules a list of modules to publish, or <code>null</code> to
* publish all modules
* @param info the IAdaptable (or <code>null</code>) provided by the
* caller in order to supply UI information for prompting the
* user if necessary. When this parameter is not
* <code>null</code>, it should minimally contain an adapter
* for the Shell class.
*/
public PublishServerJob(IServer server, int kind, List<IModule[]> modules, IAdaptable info) {
super(NLS.bind(Messages.publishing, server.getName()), server);
this.kind = kind;
this.modules = modules;
this.info = info;
}
/**
* Create a new publishing job.
*
* @param server the server to publish to
* @param kind the kind of publish
* @param check to check if auto-publishing is already covering the publish
*/
public PublishServerJob(IServer server, int kind, boolean check) {
this(server, kind, null, null);
this.check = check;
}
/**
* Create a new publishing job.
*
* @param server the server to publish to
* @deprecated use one of the other constructors instead
*/
public PublishServerJob(IServer server) {
this(server, IServer.PUBLISH_INCREMENTAL, true);
}
/**
* @see org.eclipse.core.runtime.jobs.Job#run(IProgressMonitor)
*/
protected IStatus run(IProgressMonitor monitor) {
//if (!getServer().shouldPublish())
// return Status.OK_STATUS;
if (check && !ServerCore.isAutoPublishing()) {
// don't run if we're auto-publishing and there is no need for a publish.
// can't execute this code in shouldRun() because it will cancel the job
// instead of returning immediately
return Status.OK_STATUS;
}
final IStatus[] status = new IStatus[1];
getServer().publish(kind, modules, info, new IServer.IOperationListener() {
public void done(IStatus result) {
status[0] = result;
}
});
while (status[0] == null & !monitor.isCanceled()) {
try {
Thread.sleep(200);
} catch (Exception e) {
// ignore
}
}
if (status[0] != null)
return status[0];
return Status.CANCEL_STATUS;
}
}