use of org.eclipse.egit.ui.internal.repository.tree.RepositoryTreeNode in project egit by eclipse.
the class PushCommand method isEnabled.
@Override
public boolean isEnabled() {
List<RepositoryTreeNode> nodes = getSelectedNodes();
if (nodes.isEmpty())
return false;
Repository repository = nodes.get(0).getRepository();
for (RepositoryTreeNode node : nodes) {
if (repository != node.getRepository())
return false;
}
return selectedRepositoryHasHead();
}
use of org.eclipse.egit.ui.internal.repository.tree.RepositoryTreeNode in project egit by eclipse.
the class PushConfiguredRemoteCommand method execute.
@Override
public Object execute(ExecutionEvent event) throws ExecutionException {
RepositoryTreeNode node = getSelectedNodes(event).get(0);
RemoteConfig config = getRemoteConfig(node);
if (config == null) {
MessageDialog.openInformation(getShell(event), UIText.SimplePushActionHandler_NothingToPushDialogTitle, UIText.SimplePushActionHandler_NothingToPushDialogMessage);
return null;
}
new PushOperationUI(node.getRepository(), config.getName(), false).start();
return null;
}
use of org.eclipse.egit.ui.internal.repository.tree.RepositoryTreeNode in project egit by eclipse.
the class MergeCommand method execute.
@Override
public Object execute(final ExecutionEvent event) throws ExecutionException {
RepositoryTreeNode node = getSelectedNodes(event).get(0);
final Repository repository = node.getRepository();
if (!MergeActionHandler.checkMergeIsPossible(repository, getShell(event)) || LaunchFinder.shouldCancelBecauseOfRunningLaunches(repository, null)) {
return null;
}
BasicConfigurationDialog.show(repository);
String targetRef;
if (node instanceof RefNode) {
String refName = ((RefNode) node).getObject().getName();
try {
if (refName.equals(repository.getFullBranch()))
targetRef = null;
else
targetRef = refName;
} catch (IOException e) {
targetRef = null;
}
} else if (node instanceof TagNode)
targetRef = ((TagNode) node).getObject().getName();
else
targetRef = null;
final String refName;
final MergeOperation op;
if (targetRef != null) {
refName = targetRef;
op = new MergeOperation(repository, refName);
} else {
MergeTargetSelectionDialog mergeTargetSelectionDialog = new MergeTargetSelectionDialog(getShell(event), repository);
if (mergeTargetSelectionDialog.open() != IDialogConstants.OK_ID)
return null;
refName = mergeTargetSelectionDialog.getRefName();
op = new MergeOperation(repository, refName);
op.setSquash(mergeTargetSelectionDialog.isMergeSquash());
op.setFastForwardMode(mergeTargetSelectionDialog.getFastForwardMode());
op.setCommit(mergeTargetSelectionDialog.isCommit());
}
String jobname = NLS.bind(UIText.MergeAction_JobNameMerge, refName);
Job job = new WorkspaceJob(jobname) {
@Override
public IStatus runInWorkspace(IProgressMonitor monitor) {
try {
op.execute(monitor);
} catch (final CoreException e) {
return e.getStatus();
}
return Status.OK_STATUS;
}
};
job.setUser(true);
job.setRule(op.getSchedulingRule());
job.addJobChangeListener(new JobChangeAdapter() {
@Override
public void done(IJobChangeEvent jobEvent) {
IStatus result = jobEvent.getJob().getResult();
if (result.getSeverity() == IStatus.CANCEL)
Display.getDefault().asyncExec(new Runnable() {
@Override
public void run() {
// don't use getShell(event) here since
// the active shell has changed since the
// execution has been triggered.
Shell shell = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell();
MessageDialog.openInformation(shell, UIText.MergeAction_MergeCanceledTitle, UIText.MergeAction_MergeCanceledMessage);
}
});
else if (!result.isOK())
Activator.handleError(result.getMessage(), result.getException(), true);
else
Display.getDefault().asyncExec(new Runnable() {
@Override
public void run() {
Shell shell = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell();
MergeResultDialog.getDialog(shell, repository, op.getResult()).open();
}
});
}
});
job.schedule();
return null;
}
use of org.eclipse.egit.ui.internal.repository.tree.RepositoryTreeNode in project egit by eclipse.
the class OpenCommand method execute.
@Override
public Object execute(final ExecutionEvent event) throws ExecutionException {
final List<RepositoryTreeNode> nodes = getSelectedNodes(event);
if (nodes.isEmpty())
return null;
final RepositoryTreeNode node = nodes.get(0);
if (node instanceof RefNode || node instanceof TagNode)
return new CheckoutCommand().execute(event);
if (node instanceof FileNode)
return new OpenInEditorCommand().execute(event);
if (node instanceof StashedCommitNode) {
RepositoryCommit repositoryCommit = new RepositoryCommit(node.getRepository(), ((StashedCommitNode) node).getObject());
repositoryCommit.setStash(true);
CommitEditor.openQuiet(repositoryCommit);
}
return null;
}
use of org.eclipse.egit.ui.internal.repository.tree.RepositoryTreeNode in project egit by eclipse.
the class SynchronizeCommand method execute.
@Override
public Object execute(ExecutionEvent event) throws ExecutionException {
final RepositoryTreeNode node = getSelectedNodes(event).get(0);
final String refName = getRefName(node);
if (refName == null)
return null;
String secondRefName = Constants.HEAD;
if (getSelectedNodes(event).size() == 2) {
secondRefName = getRefName(getSelectedNodes(event).get(1));
if (secondRefName == null)
return null;
}
final String secondRefNameParam = secondRefName;
final boolean includeLocal = getSelectedNodes(event).size() == 1;
final Repository repo = node.getRepository();
Job job = new WorkspaceJob(NLS.bind(UIText.SynchronizeCommand_jobName, repo.getDirectory())) {
@Override
public IStatus runInWorkspace(IProgressMonitor monitor) {
GitSynchronizeData data;
try {
data = new GitSynchronizeData(repo, secondRefNameParam, refName, includeLocal);
Set<IProject> projects = data.getProjects();
IResource[] resources = projects.toArray(new IResource[projects.size()]);
GitModelSynchronize.launch(data, resources);
} catch (IOException e) {
Activator.logError(e.getMessage(), e);
}
return Status.OK_STATUS;
}
};
job.setUser(true);
job.schedule();
return null;
}
Aggregations