56685
|
1 |
/* Title: Pure/Concurrent/synchronized.scala
|
|
2 |
Module: PIDE
|
|
3 |
Author: Makarius
|
|
4 |
|
|
5 |
Synchronized variables.
|
|
6 |
*/
|
|
7 |
|
|
8 |
package isabelle
|
|
9 |
|
|
10 |
|
|
11 |
object Synchronized
|
|
12 |
{
|
|
13 |
def apply[A](init: A): Synchronized[A] = new Synchronized(init)
|
|
14 |
}
|
|
15 |
|
|
16 |
|
|
17 |
final class Synchronized[A] private(init: A)
|
|
18 |
{
|
|
19 |
private var state: A = init
|
|
20 |
def apply(): A = synchronized { state }
|
|
21 |
def >> (f: A => A) = synchronized { state = f(state) }
|
|
22 |
def >>>[B] (f: A => (B, A)): B = synchronized {
|
|
23 |
val (result, new_state) = f(state)
|
|
24 |
state = new_state
|
|
25 |
result
|
|
26 |
}
|
|
27 |
|
|
28 |
override def toString: String = state.toString
|
|
29 |
}
|