summaryrefslogtreecommitdiff
path: root/docs/examples/actors/pingpong.scala
blob: 679385abbe6ab7d5f04e2c8320397771684fe107 (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
49
50
51
52
53
54
55
56
57
58
package examples.actors

import scala.actors.Actor
import scala.actors.Actor._

case object SendPing
case object Ping
case object Pong
case object Stop

class Ping(count: int, pong: Actor) extends Actor {
  def act() {
    var pingsLeft = count
    loop {
      react {
        case SendPing =>
          pong ! Ping
          pingsLeft = pingsLeft - 1
        case Pong =>
          if (pingsLeft % 1000 == 0)
            Console.println("Ping: pong")
          if (pingsLeft > 0)
            self ! SendPing
          else {
            Console.println("Ping: stop")
            pong ! Stop
            exit('stop)
          }
      }
    }
  }
}

class Pong extends Actor {
  def act() {
    var pongCount = 0
    loop {
      react {
        case Ping =>
          if (pongCount % 1000 == 0)
            Console.println("Pong: ping "+pongCount)
          sender ! Pong
          pongCount = pongCount + 1
        case Stop =>
          Console.println("Pong: stop")
          exit('stop)
      }
    }
  }
}

object pingpong extends Application {
  val pong = new Pong
  val ping = new Ping(100000, pong)
  ping.start
  pong.start
  ping ! SendPing
}