src/Pure/Concurrent/simple_thread.ML
author wenzelm
Tue, 10 Nov 2009 23:15:15 +0100
changeset 33602 d25e6bd6ca95
parent 33220 11a1af478dac
child 33605 f91ec14e20b6
permissions -rw-r--r--
exported SimpleThread.attributes;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Concurrent/simple_thread.ML
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     3
28577
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
     4
Simplified thread operations.
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     5
*)
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     6
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     7
signature SIMPLE_THREAD =
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
     8
sig
33602
d25e6bd6ca95 exported SimpleThread.attributes;
wenzelm
parents: 33220
diff changeset
     9
  val attributes: bool -> Thread.threadAttribute list
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    10
  val fork: bool -> (unit -> unit) -> Thread.thread
28550
422e9bd169ac added fail-safe interrupt;
wenzelm
parents: 28241
diff changeset
    11
  val interrupt: Thread.thread -> unit
28577
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    12
  val synchronized: string -> Mutex.mutex -> (unit -> 'a) -> 'a
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    13
end;
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    14
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    15
structure SimpleThread: SIMPLE_THREAD =
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    16
struct
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    17
33602
d25e6bd6ca95 exported SimpleThread.attributes;
wenzelm
parents: 33220
diff changeset
    18
fun attributes interrupts =
d25e6bd6ca95 exported SimpleThread.attributes;
wenzelm
parents: 33220
diff changeset
    19
  if interrupts then Multithreading.public_interrupts else Multithreading.no_interrupts;
d25e6bd6ca95 exported SimpleThread.attributes;
wenzelm
parents: 33220
diff changeset
    20
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    21
fun fork interrupts body =
33220
11a1af478dac SimpleThread.fork: uniform handling of outermost Interrupt, which is not an error and should not produce exception trace;
wenzelm
parents: 32295
diff changeset
    22
  Thread.fork (fn () => exception_trace (fn () => body () handle Exn.Interrupt => ()),
33602
d25e6bd6ca95 exported SimpleThread.attributes;
wenzelm
parents: 33220
diff changeset
    23
    attributes interrupts);
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    24
28550
422e9bd169ac added fail-safe interrupt;
wenzelm
parents: 28241
diff changeset
    25
fun interrupt thread = Thread.interrupt thread handle Thread _ => ();
422e9bd169ac added fail-safe interrupt;
wenzelm
parents: 28241
diff changeset
    26
28577
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    27
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    28
(* basic synchronization *)
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    29
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    30
fun synchronized name lock e = Exn.release (uninterruptible (fn restore_attributes => fn () =>
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    31
  let
32051
82a9875b8707 synchronized: tuned tracing;
wenzelm
parents: 29564
diff changeset
    32
    val immediate =
82a9875b8707 synchronized: tuned tracing;
wenzelm
parents: 29564
diff changeset
    33
      if Mutex.trylock lock then true
28577
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    34
      else
32184
cfa0ef0c0c5f simplified/unified Multithreading.tracing_time;
wenzelm
parents: 32051
diff changeset
    35
        let
cfa0ef0c0c5f simplified/unified Multithreading.tracing_time;
wenzelm
parents: 32051
diff changeset
    36
          val _ = Multithreading.tracing 5 (fn () => name ^ ": locking ...");
32185
57ecfab3bcfe added Multithreading.real_time;
wenzelm
parents: 32184
diff changeset
    37
          val time = Multithreading.real_time Mutex.lock lock;
32186
8026b73cd357 tuned tracing;
wenzelm
parents: 32185
diff changeset
    38
          val _ = Multithreading.tracing_time true time
32185
57ecfab3bcfe added Multithreading.real_time;
wenzelm
parents: 32184
diff changeset
    39
            (fn () => name ^ ": locked after " ^ Time.toString time);
32184
cfa0ef0c0c5f simplified/unified Multithreading.tracing_time;
wenzelm
parents: 32051
diff changeset
    40
        in false end;
28577
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    41
    val result = Exn.capture (restore_attributes e) ();
32051
82a9875b8707 synchronized: tuned tracing;
wenzelm
parents: 29564
diff changeset
    42
    val _ =
32184
cfa0ef0c0c5f simplified/unified Multithreading.tracing_time;
wenzelm
parents: 32051
diff changeset
    43
      if immediate then () else Multithreading.tracing 5 (fn () => name ^ ": unlocking ...");
28577
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    44
    val _ = Mutex.unlock lock;
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    45
  in result end) ());
bd2456e0d944 added generic combinator for synchronized evaluation (formerly in future.ML);
wenzelm
parents: 28550
diff changeset
    46
28241
de20fccf6509 Simplified thread fork interface.
wenzelm
parents:
diff changeset
    47
end;