src/Tools/Graphview/mutator_event.scala
author haftmann
Mon, 23 Mar 2015 19:05:14 +0100
changeset 59815 cce82e360c2f
parent 59442 9f45b95d3543
child 61590 94ab348eaab2
permissions -rw-r--r--
explicit commutative additive inverse operation; more explicit focal point for commutative monoids with an inverse operation

/*  Title:      Tools/Graphview/mutator_event.scala
    Author:     Markus Kaiser, TU Muenchen
    Author:     Makarius

Events for dialog synchronization.
*/

package isabelle.graphview


import isabelle._


object Mutator_Event
{
  sealed abstract class Message
  case class Add(m: Mutator.Info) extends Message
  case class New_List(m: List[Mutator.Info]) extends Message

  type Receiver = PartialFunction[Message, Unit]

  class Bus
  {
    private val receivers = Synchronized(List.empty[Receiver])

    def += (r: Receiver) { receivers.change(Library.insert(r)) }
    def -= (r: Receiver) { receivers.change(Library.remove(r)) }
    def event(x: Message) { receivers.value.reverse.foreach(r => r(x)) }
  }
}