src/Pure/Concurrent/counter.ML
author wenzelm
Sat, 23 Nov 2013 12:59:12 +0100
changeset 54643 57aefb80b639
parent 52537 4b5941730bd8
child 62920 a5853334c179
permissions -rw-r--r--
more on GTK;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
52537
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Concurrent/counter.ML
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     3
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     4
Synchronized counter for unique identifiers > 0.
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     5
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     6
NB: ML ticks forwards, JVM ticks backwards.
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     7
*)
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     8
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
     9
signature COUNTER =
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    10
sig
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    11
  val make: unit -> unit -> int
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    12
end;
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    13
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    14
structure Counter: COUNTER =
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    15
struct
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    16
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    17
fun make () =
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    18
  let
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    19
    val counter = Synchronized.var "counter" (0: int);
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    20
    fun next () =
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    21
      Synchronized.change_result counter
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    22
        (fn i =>
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    23
          let val j = i + (1: int)
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    24
          in (j, j) end);
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    25
  in next end;
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    26
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    27
end;
4b5941730bd8 more uniform Counter in ML and Scala;
wenzelm
parents:
diff changeset
    28