/******************************************************************************* * 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); } }