All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.counter.impl.function.CompareAndSwapFunction Maven / Gradle / Ivy

package org.infinispan.counter.impl.function;

import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Collections;
import java.util.Set;

import org.infinispan.commons.logging.LogFactory;
import org.infinispan.commons.marshall.AdvancedExternalizer;
import org.infinispan.counter.api.CounterState;
import org.infinispan.counter.impl.entries.CounterKey;
import org.infinispan.counter.impl.entries.CounterValue;
import org.infinispan.counter.impl.externalizers.ExternalizerIds;
import org.infinispan.functional.impl.CounterConfigurationMetaParam;
import org.infinispan.counter.logging.Log;
import org.infinispan.functional.EntryView;

/**
 * The compare-and-swap function to update the {@link CounterValue}.
 * 

* It returns the previous value and it is considered successful when the return value is the {@code expect}ed. *

* For a bounded counter (if the current value is equal to the {@code expect}ed), if the {@code value} is outside the * bounds, it returns {@link CounterState#LOWER_BOUND_REACHED} or {@link CounterState#UPPER_BOUND_REACHED} if the lower * bound or upper bound is violated. * * @author Pedro Ruivo * @since 9.2 */ public class CompareAndSwapFunction extends BaseFunction { public static final AdvancedExternalizer EXTERNALIZER = new Externalizer(); private static final Log log = LogFactory.getLog(CompareAndSwapFunction.class, Log.class); private final long expect; private final long value; public CompareAndSwapFunction(long expect, long value) { this.expect = expect; this.value = value; } @Override Object apply(EntryView.ReadWriteEntryView entryView, CounterConfigurationMetaParam metadata) { return FunctionHelper.compareAndSwap(entryView, entryView.get(), metadata, expect, value); } @Override protected Log getLog() { return log; } private static class Externalizer implements AdvancedExternalizer { @Override public Set> getTypeClasses() { return Collections.singleton(CompareAndSwapFunction.class); } @Override public Integer getId() { return ExternalizerIds.CAS_FUNCTION; } @Override public void writeObject(ObjectOutput output, CompareAndSwapFunction object) throws IOException { output.writeLong(object.expect); output.writeLong(object.value); } @Override public CompareAndSwapFunction readObject(ObjectInput input) throws IOException, ClassNotFoundException { return new CompareAndSwapFunction(input.readLong(), input.readLong()); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy