Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'bundles/org.eclipse.team.cvs.core/src/org/eclipse/team/internal/ccvs/core/subscribers/CVSMergeSyncInfo.java')
-rw-r--r--bundles/org.eclipse.team.cvs.core/src/org/eclipse/team/internal/ccvs/core/subscribers/CVSMergeSyncInfo.java63
1 files changed, 63 insertions, 0 deletions
diff --git a/bundles/org.eclipse.team.cvs.core/src/org/eclipse/team/internal/ccvs/core/subscribers/CVSMergeSyncInfo.java b/bundles/org.eclipse.team.cvs.core/src/org/eclipse/team/internal/ccvs/core/subscribers/CVSMergeSyncInfo.java
new file mode 100644
index 000000000..049b544f6
--- /dev/null
+++ b/bundles/org.eclipse.team.cvs.core/src/org/eclipse/team/internal/ccvs/core/subscribers/CVSMergeSyncInfo.java
@@ -0,0 +1,63 @@
+/*
+ * Created on Jun 18, 2003
+ *
+ * To change the template for this generated file go to
+ * Window>Preferences>Java>Code Generation>Code and Comments
+ */
+package org.eclipse.team.internal.ccvs.core.subscribers;
+
+import org.eclipse.core.resources.IResource;
+import org.eclipse.core.runtime.IProgressMonitor;
+import org.eclipse.team.core.TeamException;
+import org.eclipse.team.core.subscribers.SyncInfo;
+import org.eclipse.team.core.subscribers.TeamSubscriber;
+import org.eclipse.team.core.sync.IRemoteResource;
+
+/**
+ * @author JLemieux
+ *
+ * To change the template for this generated type comment go to
+ * Window>Preferences>Java>Code Generation>Code and Comments
+ */
+public class CVSMergeSyncInfo extends CVSSyncInfo {
+
+ /* (non-Javadoc)
+ * @see org.eclipse.team.internal.ccvs.core.CVSSyncInfo#handleDeletionConflicts(int)
+ */
+ protected int handleDeletionConflicts(int kind) {
+ // (see bug 40053).
+ if(kind == (SyncInfo.CONFLICTING | SyncInfo.DELETION | SyncInfo.PSEUDO_CONFLICT)) {
+ return SyncInfo.IN_SYNC;
+ }
+ return kind;
+ }
+
+ protected int calculateKind(IProgressMonitor progress) throws TeamException {
+ // Report merged resources as in-sync
+ if (((CVSMergeSubscriber)getSubscriber()).isMerged(getLocal())) {
+ return IN_SYNC;
+ }
+
+ int kind = super.calculateKind(progress);
+
+ // Report outgoing resources as in-sync
+ if((kind & DIRECTION_MASK) == OUTGOING) {
+ return IN_SYNC;
+ }
+
+ return kind;
+ }
+
+ public CVSMergeSyncInfo(IResource local, IRemoteResource base, IRemoteResource remote, TeamSubscriber subscriber, IProgressMonitor monitor) throws TeamException {
+ super(local, base, remote, subscriber, monitor);
+ }
+
+ /* (non-Javadoc)
+ * @see org.eclipse.team.internal.ccvs.core.CVSSyncInfo#makeOutgoing(org.eclipse.core.runtime.IProgressMonitor)
+ */
+ public void makeOutgoing(IProgressMonitor monitor) throws TeamException {
+ // Make the resource outgoing by marking it as merged with the subscriber
+ CVSMergeSubscriber subscriber = (CVSMergeSubscriber)getSubscriber();
+ subscriber.merged(new IResource[] {getLocal() });
+ }
+}

Back to the top