Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEike Stepper2010-10-10 16:05:10 +0000
committerEike Stepper2010-10-10 16:05:10 +0000
commit8041e2af4910a99ad921911660d7cce2eb465b37 (patch)
tree5379dd7680510ec4ebcb20dc72b3fa667fd27258 /plugins/org.eclipse.emf.cdo.server.net4j
parentdb2383af68a82f716f22a55a02f9406620699283 (diff)
downloadcdo-8041e2af4910a99ad921911660d7cce2eb465b37.tar.gz
cdo-8041e2af4910a99ad921911660d7cce2eb465b37.tar.xz
cdo-8041e2af4910a99ad921911660d7cce2eb465b37.zip
[327405] Provide an offline CDOWorkspace with Checkout/Update/Commit workflows
https://bugs.eclipse.org/bugs/show_bug.cgi?id=327405
Diffstat (limited to 'plugins/org.eclipse.emf.cdo.server.net4j')
-rw-r--r--plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/CDOServerProtocol.java3
-rw-r--r--plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/HandleRevisionsIndication.java131
2 files changed, 134 insertions, 0 deletions
diff --git a/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/CDOServerProtocol.java b/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/CDOServerProtocol.java
index 8e6713829f..b3e6c151e4 100644
--- a/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/CDOServerProtocol.java
+++ b/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/CDOServerProtocol.java
@@ -281,6 +281,9 @@ public class CDOServerProtocol extends SignalProtocol<InternalSession> implement
case CDOProtocolConstants.SIGNAL_LOAD_MERGE_DATA:
return new LoadMergeDataIndication(this);
+ case CDOProtocolConstants.SIGNAL_HANDLE_REVISIONS:
+ return new HandleRevisionsIndication(this);
+
default:
return super.createSignalReactor(signalID);
}
diff --git a/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/HandleRevisionsIndication.java b/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/HandleRevisionsIndication.java
new file mode 100644
index 0000000000..d0ea6801ce
--- /dev/null
+++ b/plugins/org.eclipse.emf.cdo.server.net4j/src/org/eclipse/emf/cdo/server/internal/net4j/protocol/HandleRevisionsIndication.java
@@ -0,0 +1,131 @@
+/**
+ * Copyright (c) 2004 - 2010 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
+ */
+package org.eclipse.emf.cdo.server.internal.net4j.protocol;
+
+import org.eclipse.emf.cdo.common.branch.CDOBranch;
+import org.eclipse.emf.cdo.common.protocol.CDODataInput;
+import org.eclipse.emf.cdo.common.protocol.CDODataOutput;
+import org.eclipse.emf.cdo.common.protocol.CDOProtocolConstants;
+import org.eclipse.emf.cdo.common.revision.CDORevision;
+import org.eclipse.emf.cdo.common.revision.CDORevisionHandler;
+import org.eclipse.emf.cdo.common.util.CDOCommonUtil;
+import org.eclipse.emf.cdo.server.internal.net4j.bundle.OM;
+
+import org.eclipse.net4j.util.om.trace.ContextTracer;
+
+import org.eclipse.emf.ecore.EClass;
+
+import java.io.IOException;
+
+/**
+ * @author Eike Stepper
+ */
+public class HandleRevisionsIndication extends CDOReadIndication
+{
+ private static final ContextTracer TRACER = new ContextTracer(OM.DEBUG_PROTOCOL, HandleRevisionsIndication.class);
+
+ private EClass eClass;
+
+ private CDOBranch branch;
+
+ private boolean exactBranch;
+
+ private long timeStamp;
+
+ private boolean exactTime;
+
+ public HandleRevisionsIndication(CDOServerProtocol protocol)
+ {
+ super(protocol, CDOProtocolConstants.SIGNAL_HANDLE_REVISIONS);
+ }
+
+ @Override
+ protected void indicating(CDODataInput in) throws IOException
+ {
+ if (in.readBoolean())
+ {
+ eClass = (EClass)in.readCDOClassifierRefAndResolve();
+ if (TRACER.isEnabled())
+ {
+ TRACER.format("Read eClass: {0}", eClass); //$NON-NLS-1$
+ }
+ }
+
+ if (in.readBoolean())
+ {
+ branch = in.readCDOBranch();
+ if (TRACER.isEnabled())
+ {
+ TRACER.format("Read branch: {0}", branch); //$NON-NLS-1$
+ }
+
+ exactBranch = in.readBoolean();
+ if (TRACER.isEnabled())
+ {
+ TRACER.format("Read exactBranch: {0}", exactBranch); //$NON-NLS-1$
+ }
+ }
+
+ timeStamp = in.readLong();
+ if (TRACER.isEnabled())
+ {
+ TRACER.format("Read timeStamp: {0}", CDOCommonUtil.formatTimeStamp(timeStamp)); //$NON-NLS-1$
+ }
+
+ exactTime = in.readBoolean();
+ if (TRACER.isEnabled())
+ {
+ TRACER.format("Read exactTime: {0}", exactTime); //$NON-NLS-1$
+ }
+ }
+
+ @Override
+ protected void responding(final CDODataOutput out) throws IOException
+ {
+ final IOException[] ioException = { null };
+ final RuntimeException[] runtimeException = { null };
+
+ getRepository().handleRevisions(eClass, branch, exactBranch, timeStamp, exactTime, new CDORevisionHandler()
+ {
+ public boolean handleRevision(CDORevision revision)
+ {
+ try
+ {
+ out.writeBoolean(true);
+ out.writeCDORevision(revision, CDORevision.UNCHUNKED);
+ return true;
+ }
+ catch (IOException ex)
+ {
+ ioException[0] = ex;
+ }
+ catch (RuntimeException ex)
+ {
+ runtimeException[0] = ex;
+ }
+
+ return false;
+ }
+ });
+
+ if (ioException[0] != null)
+ {
+ throw ioException[0];
+ }
+
+ if (runtimeException[0] != null)
+ {
+ throw runtimeException[0];
+ }
+
+ out.writeBoolean(false);
+ }
+}

Back to the top