All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.activemq.leveldb.replicated.groups.ChangeListener.scala Maven / Gradle / Ivy

There is a newer version: 6.1.2
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.activemq.leveldb.replicated.groups

import org.slf4j.{Logger, LoggerFactory}
import java.util.concurrent.TimeUnit


/**
 * 

* Callback interface used to get notifications of changes * to a cluster group. *

* * @author Hiram Chirino */ trait ChangeListener { def changed:Unit def connected:Unit def disconnected:Unit } object ChangeListenerSupport { val LOG: Logger = LoggerFactory.getLogger(classOf[ChangeListenerSupport]) } /** *

*

* * @author Hiram Chirino */ trait ChangeListenerSupport { var listeners = List[ChangeListener]() def connected:Boolean def add(listener: ChangeListener): Unit = { val connected = this.synchronized { listeners ::= listener this.connected } if (connected) { listener.connected } } def remove(listener: ChangeListener): Unit = this.synchronized { listeners = listeners.filterNot(_ == listener) } def fireConnected() = { val listeners = this.synchronized { this.listeners } check_elapsed_time { for (listener <- listeners) { listener.connected } } } def fireDisconnected() = { val listeners = this.synchronized { this.listeners } check_elapsed_time { for (listener <- listeners) { listener.disconnected } } } def fireChanged() = { val listeners = this.synchronized { this.listeners } val start = System.nanoTime() check_elapsed_time { for (listener <- listeners) { listener.changed } } } def check_elapsed_time[T](func: => T):T = { val start = System.nanoTime() try { func } finally { val end = System.nanoTime() val elapsed = TimeUnit.NANOSECONDS.toMillis(end-start) if( elapsed > 100 ) { ChangeListenerSupport.LOG.warn("listeners are taking too long to process the events") } } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy