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

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

There is a newer version: 15.1.0.Dev05
Show newest version
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.marshall.AdvancedExternalizer;
import org.infinispan.counter.api.CounterConfiguration;
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.functional.EntryView;

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

* It has the same semantic as {@link CompareAndSwapFunction} but it creates the {@link CounterValue} if it doesn't * exist. * * @author Pedro Ruivo * @see CompareAndSwapFunction * @since 9.2 */ public class CreateAndCASFunction extends BaseCreateFunction { public static final AdvancedExternalizer EXTERNALIZER = new Externalizer(); private final long expect; private final long value; public CreateAndCASFunction(CounterConfiguration configuration, long expect, long value) { super(configuration); this.expect = expect; this.value = value; } @Override Object apply(EntryView.ReadWriteEntryView entryView, CounterValue currentValue, CounterConfigurationMetaParam metadata) { return FunctionHelper.compareAndSwap(entryView, currentValue, metadata, expect, value); } private static class Externalizer implements AdvancedExternalizer { @Override public Set> getTypeClasses() { return Collections.singleton(CreateAndCASFunction.class); } @Override public Integer getId() { return ExternalizerIds.CREATE_CAS_FUNCTION; } @Override public void writeObject(ObjectOutput output, CreateAndCASFunction object) throws IOException { output.writeObject(object.configuration); output.writeLong(object.expect); output.writeLong(object.value); } @Override public CreateAndCASFunction readObject(ObjectInput input) throws IOException, ClassNotFoundException { return new CreateAndCASFunction<>((CounterConfiguration) input.readObject(), input.readLong(), input.readLong()); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy