diff options
Diffstat (limited to 'org.eclipse.egit.ui/src/org/eclipse/egit/ui/internal/actions/FetchAction.java')
-rw-r--r-- | org.eclipse.egit.ui/src/org/eclipse/egit/ui/internal/actions/FetchAction.java | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/org.eclipse.egit.ui/src/org/eclipse/egit/ui/internal/actions/FetchAction.java b/org.eclipse.egit.ui/src/org/eclipse/egit/ui/internal/actions/FetchAction.java new file mode 100644 index 0000000000..f4bb26887b --- /dev/null +++ b/org.eclipse.egit.ui/src/org/eclipse/egit/ui/internal/actions/FetchAction.java @@ -0,0 +1,52 @@ +/******************************************************************************* + * Copyright (C) 2008, Marek Zawirski <marek.zawirski@gmail.com> + * + * 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 + *******************************************************************************/ +package org.eclipse.egit.ui.internal.actions; + +import java.net.URISyntaxException; + +import org.eclipse.core.runtime.IStatus; +import org.eclipse.core.runtime.Status; +import org.eclipse.egit.ui.Activator; +import org.eclipse.egit.ui.UIText; +import org.eclipse.egit.ui.internal.fetch.FetchWizard; +import org.eclipse.jface.action.IAction; +import org.eclipse.jface.dialogs.ErrorDialog; +import org.eclipse.jface.wizard.WizardDialog; +import org.eclipse.jgit.lib.Repository; + +/** + * Action for displaying fetch wizard - allowing selection of specifications for + * fetch, and fetching objects/refs from another repository. + */ +public class FetchAction extends RepositoryAction { + @Override + public void run(IAction action) { + final Repository repository = getRepository(true); + if (repository == null) + return; + + final FetchWizard fetchWizard; + try { + fetchWizard = new FetchWizard(repository); + } catch (URISyntaxException x) { + ErrorDialog.openError(getShell(), UIText.FetchAction_wrongURITitle, + UIText.FetchAction_wrongURIMessage, new Status( + IStatus.ERROR, Activator.getPluginId(), x + .getMessage(), x)); + return; + } + final WizardDialog dialog = new WizardDialog(getShell(), fetchWizard); + dialog.open(); + } + + @Override + public boolean isEnabled() { + return getRepository(false) != null; + } +} |