diff options
author | Eike Stepper | 2009-07-06 07:28:05 +0000 |
---|---|---|
committer | Eike Stepper | 2009-07-06 07:28:05 +0000 |
commit | 18636909bc2e64e32e8585db5a44b24fae9b4d3b (patch) | |
tree | 3a1c7cba62e05200d17d280cd7fcf1309276a7ce /plugins/org.eclipse.emf.cdo.net4j/src/org/eclipse/emf/cdo/internal/net4j/protocol/CommitNotificationIndication.java | |
parent | 908391dfe8836023bf5500654328e03e4581f867 (diff) | |
download | cdo-18636909bc2e64e32e8585db5a44b24fae9b4d3b.tar.gz cdo-18636909bc2e64e32e8585db5a44b24fae9b4d3b.tar.xz cdo-18636909bc2e64e32e8585db5a44b24fae9b4d3b.zip |
[282481] Provide an EmbeddedSessionProtocol
https://bugs.eclipse.org/bugs/show_bug.cgi?id=282481
Diffstat (limited to 'plugins/org.eclipse.emf.cdo.net4j/src/org/eclipse/emf/cdo/internal/net4j/protocol/CommitNotificationIndication.java')
-rw-r--r-- | plugins/org.eclipse.emf.cdo.net4j/src/org/eclipse/emf/cdo/internal/net4j/protocol/CommitNotificationIndication.java | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/plugins/org.eclipse.emf.cdo.net4j/src/org/eclipse/emf/cdo/internal/net4j/protocol/CommitNotificationIndication.java b/plugins/org.eclipse.emf.cdo.net4j/src/org/eclipse/emf/cdo/internal/net4j/protocol/CommitNotificationIndication.java new file mode 100644 index 0000000000..e90fc37b33 --- /dev/null +++ b/plugins/org.eclipse.emf.cdo.net4j/src/org/eclipse/emf/cdo/internal/net4j/protocol/CommitNotificationIndication.java @@ -0,0 +1,110 @@ +/*************************************************************************** + * Copyright (c) 2004 - 2009 Eike Stepper (Berlin, Germany) 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: + * Eike Stepper - initial API and implementation + * Simon McDuff - http://bugs.eclipse.org/233490 + **************************************************************************/ +package org.eclipse.emf.cdo.internal.net4j.protocol; + +import org.eclipse.emf.cdo.common.id.CDOID; +import org.eclipse.emf.cdo.common.id.CDOIDAndVersion; +import org.eclipse.emf.cdo.common.io.CDODataInput; +import org.eclipse.emf.cdo.common.model.CDOPackageUnit; +import org.eclipse.emf.cdo.common.protocol.CDOProtocolConstants; +import org.eclipse.emf.cdo.common.revision.delta.CDORevisionDelta; +import org.eclipse.emf.cdo.internal.net4j.bundle.OM; +import org.eclipse.emf.cdo.spi.common.model.InternalCDOPackageRegistry; +import org.eclipse.emf.cdo.spi.common.model.InternalCDOPackageUnit; + + +import org.eclipse.net4j.util.om.trace.ContextTracer; + +import org.eclipse.emf.spi.cdo.InternalCDOSession; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + +/** + * @author Eike Stepper + */ +public class CommitNotificationIndication extends CDOClientIndication +{ + private static final ContextTracer TRACER = new ContextTracer(OM.DEBUG_PROTOCOL, CommitNotificationIndication.class); + + public CommitNotificationIndication(CDOClientProtocol protocol) + { + super(protocol, CDOProtocolConstants.SIGNAL_COMMIT_NOTIFICATION); + } + + @Override + protected void indicating(CDODataInput in) throws IOException + { + long timeStamp = in.readLong(); + if (TRACER.isEnabled()) + { + TRACER.format("Read timeStamp: {0,date} {0,time}", timeStamp); //$NON-NLS-1$ + } + + CDOPackageUnit[] packageUnits = in.readCDOPackageUnits(null); + InternalCDOPackageRegistry packageRegistry = getSession().getPackageRegistry(); + for (int i = 0; i < packageUnits.length; i++) + { + packageRegistry.putPackageUnit((InternalCDOPackageUnit)packageUnits[i]); + } + + int size = in.readInt(); + if (TRACER.isEnabled()) + { + TRACER.format("Reading {0} dirty IDs", size); //$NON-NLS-1$ + } + + InternalCDOSession session = getSession(); + Set<CDOIDAndVersion> dirtyOIDs = new HashSet<CDOIDAndVersion>(); + for (int i = 0; i < size; i++) + { + CDOIDAndVersion dirtyOID = in.readCDOIDAndVersion(); + if (TRACER.isEnabled()) + { + TRACER.format("Read dirty ID: {0}", dirtyOID); //$NON-NLS-1$ + } + + dirtyOIDs.add(dirtyOID); + } + + size = in.readInt(); + if (TRACER.isEnabled()) + { + TRACER.format("Reading {0} Deltas", size); //$NON-NLS-1$ + } + + List<CDORevisionDelta> deltas = new ArrayList<CDORevisionDelta>(); + for (int i = 0; i < size; i++) + { + CDORevisionDelta revisionDelta = in.readCDORevisionDelta(); + deltas.add(revisionDelta); + } + + size = in.readInt(); + if (TRACER.isEnabled()) + { + TRACER.format("Reading {0} Detach Objects", size); //$NON-NLS-1$ + } + + List<CDOID> detachedObjects = new ArrayList<CDOID>(); + for (int i = 0; i < size; i++) + { + detachedObjects.add(in.readCDOID()); + } + + session.handleCommitNotification(timeStamp, Arrays.asList(packageUnits), dirtyOIDs, detachedObjects, deltas, null); + } +} |