aboutsummaryrefslogtreecommitdiff
path: root/flow-samples
diff options
context:
space:
mode:
authorJakob Odersky <jodersky@gmail.com>2015-05-24 13:35:42 +0200
committerJakob Odersky <jodersky@gmail.com>2015-05-24 15:53:33 +0200
commit0ffc19859dccdb752ce16e6b9264b02312064a3d (patch)
tree07dd67b8f6bfa4157cc45629fab66ca379545b99 /flow-samples
parentde9db5ec62a649fa36963d9fe01543bd612c0105 (diff)
downloadakka-serial-0ffc19859dccdb752ce16e6b9264b02312064a3d.tar.gz
akka-serial-0ffc19859dccdb752ce16e6b9264b02312064a3d.tar.bz2
akka-serial-0ffc19859dccdb752ce16e6b9264b02312064a3d.zip
add watcher sample
Diffstat (limited to 'flow-samples')
-rw-r--r--flow-samples/watcher/src/main/scala/com/github/jodersky/flow/samples/watcher/main.scala50
1 files changed, 50 insertions, 0 deletions
diff --git a/flow-samples/watcher/src/main/scala/com/github/jodersky/flow/samples/watcher/main.scala b/flow-samples/watcher/src/main/scala/com/github/jodersky/flow/samples/watcher/main.scala
new file mode 100644
index 0000000..92cc3ad
--- /dev/null
+++ b/flow-samples/watcher/src/main/scala/com/github/jodersky/flow/samples/watcher/main.scala
@@ -0,0 +1,50 @@
+package com.github.jodersky.flow
+package samples.watcher
+
+import akka.actor.{ Actor, ActorLogging, ActorSystem, Props }
+import akka.io.IO
+import scala.io.StdIn
+
+class Watcher extends Actor with ActorLogging {
+ import context._
+
+ val ports = List(
+ "/dev/ttyUSB\\d+",
+ "/dev/ttyACM\\d+",
+ "/dev/cu\\d+",
+ "/dev/ttyS\\d+"
+ )
+
+ override def preStart() = {
+ val cmd = Serial.Watch()
+ IO(Serial) ! cmd //watch for new devices
+ log.info(s"Watching ${cmd.directory} for new devices.")
+ }
+
+ def receive = {
+
+ case Serial.CommandFailed(w: Serial.Watch, err) =>
+ log.error(err, s"Could not get a watch on ${w.directory}.")
+ context stop self
+
+ case Serial.Connected(path) =>
+ log.info(s"New device: ${path}")
+ ports.find(path matches _) match {
+ case Some(port) => log.info(s"Device is a serial device.")
+ case None => log.warning(s"Device is NOT serial device.")
+ }
+
+ }
+
+}
+
+object Main {
+
+ def main(args: Array[String]): Unit = {
+ val system = ActorSystem("flow")
+ val watcher = system.actorOf(Props(classOf[Watcher]), name = "watcher")
+ StdIn.readLine()
+ system.shutdown()
+ }
+
+}