src/Pure/Concurrent/counter.scala
author wenzelm
Fri, 05 Jul 2013 23:10:18 +0200
changeset 52537 4b5941730bd8
parent 46712 8650d9a95736
child 56685 535d59d4ed12
permissions -rw-r--r--
more uniform Counter in ML and Scala;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43660
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Concurrent/counter.scala
45673
cd41e3903fbf separate compilation of PIDE vs. Pure sources, which enables independent Scala library;
wenzelm
parents: 45667
diff changeset
     2
    Module:     PIDE
43660
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     3
    Author:     Makarius
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     4
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     5
Synchronized counter for unique identifiers < 0.
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     6
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     7
NB: ML ticks forwards, JVM ticks backwards.
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     8
*/
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
     9
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    10
package isabelle
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    11
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    12
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    13
object Counter
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    14
{
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    15
  type ID = Long
52537
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents: 46712
diff changeset
    16
  def make(): Counter = new Counter
43660
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    17
}
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    18
46712
8650d9a95736 prefer final ADTs -- prevent ooddities;
wenzelm
parents: 45673
diff changeset
    19
final class Counter private
43660
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    20
{
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    21
  private var count: Counter.ID = 0
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    22
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    23
  def apply(): Counter.ID = synchronized {
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    24
    require(count > java.lang.Long.MIN_VALUE)
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    25
    count -= 1
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    26
    count
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    27
  }
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    28
}
bfc0bb115fa1 explicit class Counter;
wenzelm
parents:
diff changeset
    29