pekko/akka-docs/rst/scala/code/docs/ddata/TwoPhaseSet.scala
Patrik Nordwall da07a2e68e !cdd #17770 Use self recursive type in AbstractReplicatedData (Java API)
* complete the TwoPhaseSet java sample with serialization
2015-07-03 13:51:30 +02:00

29 lines
736 B
Scala

/**
* Copyright (C) 2015 Typesafe Inc. <http://www.typesafe.com>
*/
package docs.ddata
import akka.cluster.ddata.ReplicatedData
import akka.cluster.ddata.GSet
//#twophaseset
case class TwoPhaseSet(
adds: GSet[String] = GSet.empty,
removals: GSet[String] = GSet.empty)
extends ReplicatedData {
type T = TwoPhaseSet
def add(element: String): TwoPhaseSet =
copy(adds = adds.add(element))
def remove(element: String): TwoPhaseSet =
copy(removals = removals.add(element))
def elements: Set[String] = adds.elements -- removals.elements
override def merge(that: TwoPhaseSet): TwoPhaseSet =
copy(
adds = this.adds.merge(that.adds),
removals = this.removals.merge(that.removals))
}
//#twophaseset