/******************************************************************************* * 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.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 RefreshRepositoryJob. */ public class RefreshRepositoryJob extends Job { /** The crawledRepository. */ private final CrawledRepository crawledRepository; /** The Constant JOB_ID. */ private static final String JOB_ID = "DWS: refreshing crawledRepository "; /** * Instantiates a new refresh crawledRepository job. * * @param crawledRepository the crawledRepository */ public RefreshRepositoryJob(CrawledRepository crawledRepository) { super(JOB_ID + crawledRepository.getUID()); this.crawledRepository = crawledRepository; this.setPriority(Job.LONG); 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, "Refresh of crawledRepository: \"" + crawledRepository.getUID() + "\" was successful."); try { monitor.beginTask("Refreshing crawledRepository " + crawledRepository.getUID(), 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()); } if (modelItemEvent.getEventType() == ModelItemEvent.EventType.PRE_UPDATE_CHILD) { if (modelItemEvent.getTargetItem() != null && modelItemEvent.getSourceItem() != null) { fMonitor.subTask("Updating " + modelItemEvent.getTargetItem().getUID() +" in " +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.refreshRepository(crawledRepository, externalInterruptionFlagSetter,modelItemListener); if (monitor.isCanceled()) { result = new StatusInfo(IStatus.WARNING, "Refresh of crawledRepository: \"" + crawledRepository.getUID() + "\" was canceled. It may not be complete."); } } catch (Exception e) { result = new StatusInfo(IStatus.ERROR, "Refresh of crawledRepository: \"" + crawledRepository.getUID() + "\" failed: " + 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); } }