package org.infinispan.client.hotrod.impl.operations; import java.util.concurrent.atomic.AtomicInteger; import org.infinispan.client.hotrod.VersionedValue; import org.infinispan.client.hotrod.configuration.ClientIntelligence; import org.infinispan.client.hotrod.impl.VersionedValueImpl; import org.infinispan.client.hotrod.impl.protocol.Codec; import org.infinispan.client.hotrod.impl.protocol.HotRodConstants; import org.infinispan.client.hotrod.impl.transport.Transport; import org.infinispan.client.hotrod.impl.transport.TransportFactory; import org.infinispan.client.hotrod.logging.Log; import org.infinispan.client.hotrod.logging.LogFactory; import net.jcip.annotations.Immutable; /** * Corresponds to getWithVersion operation as described by * <a href="http://community.jboss.org/wiki/HotRodProtocol">Hot Rod protocol specification</a>. * * @author Mircea.Markus@jboss.com * @since 4.1 */ @Immutable @Deprecated public class GetWithVersionOperation<V> extends AbstractKeyOperation<VersionedValue<V>> { private static final Log log = LogFactory.getLog(GetWithVersionOperation.class); private static final boolean trace = log.isTraceEnabled(); public GetWithVersionOperation(Codec codec, TransportFactory transportFactory, Object key, byte[] keyBytes, byte[] cacheName, AtomicInteger topologyId, int flags, ClientIntelligence clientIntelligence) { super(codec, transportFactory, key, keyBytes, cacheName, topologyId, flags, clientIntelligence); } @Override protected VersionedValue<V> executeOperation(Transport transport) { short status = sendKeyOperation(keyBytes, transport, GET_WITH_VERSION, GET_WITH_VERSION_RESPONSE); VersionedValue<V> result = null; if (HotRodConstants.isNotExist(status)) { result = null; } else if (HotRodConstants.isSuccess(status)) { long version = transport.readLong(); if (trace) { log.tracef("Received version: %d", version); } V value = codec.readUnmarshallByteArray(transport, status); result = new VersionedValueImpl<V>(version, value); } return result; } }