public class ApplyDeltaCommand extends AbstractDataWriteCommand
Modifier and Type | Field and Description |
---|---|
static int |
COMMAND_ID |
key
flags
Constructor and Description |
---|
ApplyDeltaCommand() |
ApplyDeltaCommand(Object deltaAwareValueKey,
Delta delta,
Collection<Object> keys) |
Modifier and Type | Method and Description |
---|---|
Object |
acceptVisitor(InvocationContext ctx,
Visitor visitor)
Accept a visitor, and return the result of accepting this visitor.
|
boolean |
equals(Object o) |
byte |
getCommandId()
Used by marshallers to convert this command into an id for streaming.
|
Object[] |
getCompositeKeys() |
Delta |
getDelta() |
Object[] |
getKeys() |
Object[] |
getParameters()
Used by marshallers to stream this command across a network
|
ValueMatcher |
getValueMatcher() |
int |
hashCode() |
boolean |
ignoreCommandOnStatus(ComponentStatus status)
Similar to
VisitableCommand.shouldInvoke(InvocationContext) but evaluated by InvocationContextInterceptor . |
boolean |
isConditional()
Certain commands only work based on a certain condition or state of the cache.
|
boolean |
isSuccessful()
Some commands may want to provide information on whether the command was successful or not.
|
Object |
perform(InvocationContext ctx)
Performs an application of delta on a specified entry
|
void |
setParameters(int commandId,
Object[] args)
Used by the
CommandsFactory to create a command from raw data read off a stream. |
void |
setValueMatcher(ValueMatcher valueMatcher) |
String |
toString() |
void |
updateStatusFromRemoteResponse(Object remoteResponse)
Used for conditional commands, to update the status of the command on the originator
based on the result of its execution on the primary owner.
|
canBlock, getAffectedKeys, isReturnValueExpected
getKey, setKey, shouldInvoke
getMetadata, getTopologyId, setMetadata, setTopologyId
getFlags, hasFlag, setFlags, setFlags
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
shouldInvoke
getTopologyId, setTopologyId
getMetadata, setMetadata
getFlags, hasFlag, setFlags, setFlags
getKey
public static final int COMMAND_ID
public ApplyDeltaCommand()
public ApplyDeltaCommand(Object deltaAwareValueKey, Delta delta, Collection<Object> keys)
public Delta getDelta()
public Object perform(InvocationContext ctx) throws Throwable
ctx
- invocation contextThrowable
- in the event of problems.public byte getCommandId()
ReplicableCommand
public String toString()
toString
in class AbstractDataCommand
public Object[] getParameters()
ReplicableCommand
getParameters
in interface ReplicableCommand
getParameters
in class AbstractDataCommand
public void setParameters(int commandId, Object[] args)
ReplicableCommand
CommandsFactory
to create a command from raw data read off a stream.setParameters
in interface ReplicableCommand
setParameters
in class AbstractDataCommand
commandId
- command id to set. This is usually unused but *could* be used in the event of a command having
multiple IDs, such as PutKeyValueCommand
.args
- object array of argspublic Object acceptVisitor(InvocationContext ctx, Visitor visitor) throws Throwable
VisitableCommand
ctx
- invocation contextvisitor
- visitor to acceptThrowable
- in the event of problemspublic Object[] getKeys()
public Object[] getCompositeKeys()
public boolean ignoreCommandOnStatus(ComponentStatus status)
VisitableCommand
VisitableCommand.shouldInvoke(InvocationContext)
but evaluated by InvocationContextInterceptor
.
Commands can opt to be discarded in case the cache status is not suited (as InvalidateCommand
)ignoreCommandOnStatus
in interface VisitableCommand
ignoreCommandOnStatus
in class AbstractDataCommand
public boolean equals(Object o)
equals
in class AbstractDataCommand
public int hashCode()
hashCode
in class AbstractDataCommand
public boolean isSuccessful()
WriteCommand
public boolean isConditional()
WriteCommand
ConcurrentMap.putIfAbsent(Object, Object)
only does anything if a condition is met, i.e., the entry in
question is not already present. This method tests whether the command in question is conditional or not.public ValueMatcher getValueMatcher()
public void setValueMatcher(ValueMatcher valueMatcher)
valueMatcher
- The new value matching policy.public void updateStatusFromRemoteResponse(Object remoteResponse)
WriteCommand
Copyright © 2014 JBoss, a division of Red Hat. All Rights Reserved.