File: Server.scala

package info (click to toggle)
scala 2.9.2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 67,208 kB
  • sloc: java: 27,488; xml: 4,412; python: 2,297; sh: 734; makefile: 16; ansic: 6
file content (27 lines) | stat: -rw-r--r-- 563 bytes parent folder | download | duplicates (2)
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
/*
 *  @author Stephane Micheloud
 */

import scala.actors.Actor._
import scala.actors.remote.RemoteActor._

object Server extends ServerConsole {
  private def computation(f: Int => Int): Int = {
    //some time-consuming task
    f(2)
  }
  def main(args: Array[String]) {
    actor {
      classLoader = serverClassLoader
      alive(args(0).toInt)
      register('Server, self)
      loopWhile(isRunning) {
        react {
          case f: (Int => Int) =>
            val result = computation(f)
            sender ! result
        }
      }
    }
  }
}