diff options
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.java | 63 |
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() }); + } +} |