summaryrefslogtreecommitdiff
path: root/src/dotnet-library/scala/concurrent/Pid.scala
blob: 6fa1f24123a3de0d757379a4a37a91aeab822f22 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/*                     __                                               *\
**     ________ ___   / /  ___     Scala API                            **
**    / __/ __// _ | / /  / _ |    (c) 2003-2006, LAMP/EPFL             **
**  __\ \/ /__/ __ |/ /__/ __ |                                         **
** /____/\___/_/ |_/____/_/ | |                                         **
**                          |/                                          **
\*                                                                      */

// $Id$


package scala.concurrent

/**
 * The class <code>Pid</code> provides process identifiers
 * to thread-based actors.
 *
 * @author Philipp Haller
 * @version 1.0
 */
class Pid(actor: Actor) {
  private var target = actor

  def !(msg: MailBox#Message) = target send msg

  def spawn(body: Actor => Unit): Pid = {
    val a = new Actor {
      override def run: Unit = body(this)
    }
    a.start
    a.self
  }

  def spawnReceive(cases: PartialFunction[MailBox#Message, Unit]) = {
    val a = new Actor {
      override def run: Unit = receive(cases)
    }
    a.start
    a.self
  }

  override def hashCode() = target.hashCode()

  override def equals(that: Any) =
    this.hashCode() == that.hashCode()

  override def toString() = "Pid(" + target + ")"
}