diff options
Diffstat (limited to 'bundles/org.eclipse.equinox.p2.ui.admin/src/org/eclipse/equinox/internal/p2/ui/admin/ArtifactRepositoryTracker.java')
-rw-r--r-- | bundles/org.eclipse.equinox.p2.ui.admin/src/org/eclipse/equinox/internal/p2/ui/admin/ArtifactRepositoryTracker.java | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/bundles/org.eclipse.equinox.p2.ui.admin/src/org/eclipse/equinox/internal/p2/ui/admin/ArtifactRepositoryTracker.java b/bundles/org.eclipse.equinox.p2.ui.admin/src/org/eclipse/equinox/internal/p2/ui/admin/ArtifactRepositoryTracker.java new file mode 100644 index 000000000..b4fbdba2d --- /dev/null +++ b/bundles/org.eclipse.equinox.p2.ui.admin/src/org/eclipse/equinox/internal/p2/ui/admin/ArtifactRepositoryTracker.java @@ -0,0 +1,83 @@ +/******************************************************************************* + * Copyright (c) 2009 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.equinox.internal.p2.ui.admin; + +import org.eclipse.equinox.p2.core.ProvisionException; + +import java.net.URI; +import org.eclipse.core.runtime.*; +import org.eclipse.equinox.internal.provisional.p2.repository.RepositoryEvent; +import org.eclipse.equinox.p2.operations.ProvisioningSession; +import org.eclipse.equinox.p2.operations.RepositoryTracker; +import org.eclipse.equinox.p2.repository.IRepository; +import org.eclipse.equinox.p2.ui.ProvisioningUI; + +public class ArtifactRepositoryTracker extends RepositoryTracker { + + ProvisioningUI ui; + + public ArtifactRepositoryTracker(ProvisioningUI ui) { + this.ui = ui; + } + + public URI[] getKnownRepositories(ProvisioningSession session) { + return session.getArtifactRepositoryManager().getKnownRepositories(getArtifactRepositoryFlags()); + } + + protected IStatus validateRepositoryLocationWithManager(ProvisioningSession session, URI location, IProgressMonitor monitor) { + return Status.OK_STATUS; + } + + public void addRepository(URI repoLocation, String nickname, ProvisioningSession session) { + ui.signalRepositoryOperationStart(); + try { + session.getArtifactRepositoryManager().addRepository(repoLocation); + if (nickname != null) + session.getArtifactRepositoryManager().setRepositoryProperty(repoLocation, IRepository.PROP_NICKNAME, nickname); + } finally { + ui.signalRepositoryOperationComplete(new RepositoryEvent(repoLocation, IRepository.TYPE_ARTIFACT, RepositoryEvent.ADDED, true), true); + } + } + + /* (non-Javadoc) + * @see org.eclipse.equinox.p2.operations.RepositoryTracker#removeRepositories(java.net.URI[], org.eclipse.equinox.p2.operations.ProvisioningSession) + */ + public void removeRepositories(URI[] repoLocations, ProvisioningSession session) { + ui.signalRepositoryOperationStart(); + try { + for (int i = 0; i < repoLocations.length; i++) { + session.getArtifactRepositoryManager().removeRepository(repoLocations[i]); + } + } finally { + ui.signalRepositoryOperationComplete(null, true); + } + } + + /* + * (non-Javadoc) + * @see org.eclipse.equinox.p2.operations.RepositoryTracker#refreshRepositories(java.net.URI[], org.eclipse.equinox.p2.operations.ProvisioningSession, org.eclipse.core.runtime.IProgressMonitor) + */ + public void refreshRepositories(URI[] locations, ProvisioningSession session, IProgressMonitor monitor) { + ui.signalRepositoryOperationStart(); + SubMonitor mon = SubMonitor.convert(monitor, locations.length * 100); + for (int i = 0; i < locations.length; i++) { + try { + session.getArtifactRepositoryManager().refreshRepository(locations[i], mon.newChild(100)); + } catch (ProvisionException e) { + //ignore problematic repositories when refreshing + } + } + // We have no idea how many repos may have been added/removed as a result of + // refreshing these, this one, so we do not use a specific repository event to represent it. + ui.signalRepositoryOperationComplete(null, true); + } +}
\ No newline at end of file |