/*******************************************************************************
* Copyright (c) 2008 Pierre-Antoine Grégoire.
* 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:
* Pierre-Antoine Grégoire - initial API and implementation
*******************************************************************************/
package org.org.eclipse.dws.core.internal.jobs;
import org.apache.log4j.Logger;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.jobs.Job;
import org.org.eclipse.core.utils.platform.jobs.BatchSimilarRule;
import org.org.eclipse.core.utils.platform.wizards.StatusInfo;
import org.org.eclipse.dws.core.DWSCorePlugin;
import org.org.eclipse.dws.core.internal.bridges.RepositoryModelPersistence;
import org.org.model.IModelItemListener;
import org.org.model.ModelItemEvent;
import org.org.repository.crawler.IExternalInterruptionFlagSetter;
import org.org.repository.crawler.InterruptionFlag;
import org.org.repository.crawler.maven2.model.CrawledRepository;
/**
* The Class AddPreciseGroupToRepositoryJob.
*/
public class AddPreciseGroupToRepositoryJob extends Job {
/** The logger. */
private Logger logger = Logger.getLogger(AddPreciseGroupToRepositoryJob.class);
/** The crawledRepository. */
private final CrawledRepository crawledRepository;
/** The group id. */
private final String groupId;
/** The Constant JOB_ID. */
private static final String JOB_ID = "DWS: adding group ";
/**
* Instantiates a new adds the precise group to crawledRepository job.
*
* @param crawledRepository
* the crawledRepository
* @param groupId
* the group id
*/
public AddPreciseGroupToRepositoryJob(CrawledRepository crawledRepository, String groupId) {
super(JOB_ID + groupId + " to " + crawledRepository.getUID());
this.crawledRepository = crawledRepository;
this.groupId = groupId;
this.setPriority(Job.SHORT);
this.setUser(true);
this.setRule(new BatchSimilarRule(Maven2Jobs.MAVEN2_REFRESH_JOB_FAMILY));
}
/*
* (non-Javadoc)
*
* @see org.eclipse.core.runtime.jobs.Job#run(org.eclipse.core.runtime.IProgressMonitor)
*/
/**
* @see org.eclipse.core.runtime.jobs.Job#run(org.eclipse.core.runtime.IProgressMonitor)
*/
@Override
protected IStatus run(IProgressMonitor monitor) {
IStatus result = new StatusInfo(IStatus.OK, "Group addition successful");
try {
monitor.beginTask("Adding group", 1000);
final IProgressMonitor fMonitor = monitor;
IModelItemListener modelItemListener = new IModelItemListener() {
public void changeOccured(ModelItemEvent modelItemEvent) {
if (modelItemEvent.getEventType() == ModelItemEvent.EventType.PRE_ADD_CHILD) {
if (modelItemEvent.getTargetItem() != null && modelItemEvent.getSourceItem() != null) {
fMonitor.subTask("Adding " + modelItemEvent.getTargetItem().getUID() + " to " + modelItemEvent.getSourceItem().getUID());
fMonitor.worked(1);
}
DWSCorePlugin.getDefault().notifyRepositoryModelUpdate(modelItemEvent.getTargetItem());
}
}
};
IExternalInterruptionFlagSetter externalInterruptionFlagSetter = new IExternalInterruptionFlagSetter() {
public InterruptionFlag processStatus() {
InterruptionFlag flag = new InterruptionFlag();
if (fMonitor.isCanceled()) {
flag.setCurrentStatus(InterruptionFlag.STOP);
}
return flag;
}
};
RepositoryModelPersistence.addPreciseGroupToRepository(crawledRepository, groupId, externalInterruptionFlagSetter, modelItemListener);
if (monitor.isCanceled()) {
result = new StatusInfo(IStatus.WARNING, "CrawledRepository browsing was canceled, it may not be complete.");
}
} catch (Exception e) {
logger.error(e.getMessage());
monitor.setCanceled(true);
result = new StatusInfo(IStatus.ERROR, "CrawledRepository browsing error: " + e.getMessage());
} finally {
monitor.done();
}
return result;
}
/*
* (non-Javadoc)
*
* @see org.eclipse.core.runtime.jobs.Job#belongsTo(java.lang.Object)
*/
/**
* @see org.eclipse.core.runtime.jobs.Job#belongsTo(java.lang.Object)
*/
@Override
public boolean belongsTo(Object family) {
return Maven2Jobs.MAVEN2_REFRESH_JOB_FAMILY.equals(family);
}
}