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

com.google.web.bindery.event.shared.EventBus Maven / Gradle / Ivy

/*
 * Copyright 2011 Google Inc.
 * 
 * Licensed 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 com.google.web.bindery.event.shared;

import com.google.web.bindery.event.shared.Event.Type;

/**
 * Dispatches {@link Event}s to interested parties. Eases decoupling by allowing
 * objects to interact without having direct dependencies upon one another, and
 * without requiring event sources to deal with maintaining handler lists. There
 * will typically be one EventBus per application, broadcasting events that may
 * be of general interest.
 * 
 * @see SimpleEventBus
 * @see ResettableEventBus
 * @see com.google.web.bindery.event.shared.testing.CountingEventBus
 */
public abstract class EventBus {

  /**
   * Invokes {@code event.dispatch} with {@code handler}.
   * 

* Protected to allow EventBus implementations in different packages to * dispatch events even though the {@code event.dispatch} method is protected. */ protected static void dispatchEvent(Event event, H handler) { event.dispatch(handler); } /** * Sets {@code source} as the source of {@code event}. *

* Protected to allow EventBus implementations in different packages to set an * event source even though the {@code event.setSource} method is protected. */ protected static void setSourceOfEvent(Event event, Object source) { event.setSource(source); } /** * Adds an unfiltered handler to receive events of this type from all sources. *

* It is rare to call this method directly. More typically an {@link Event} * subclass will provide a static register method, or a widget * will accept handlers directly. * * @param The type of handler * @param type the event type associated with this handler * @param handler the handler * @return the handler registration, can be stored in order to remove the * handler later */ public abstract HandlerRegistration addHandler(Type type, H handler); /** * Adds a handler to receive events of this type from the given source. *

* It is rare to call this method directly. More typically a {@link Event} * subclass will provide a static register method, or a widget * will accept handlers directly. * * @param The type of handler * @param type the event type associated with this handler * @param source the source associated with this handler * @param handler the handler * @return the handler registration, can be stored in order to remove the * handler later */ public abstract HandlerRegistration addHandlerToSource(Type type, Object source, H handler); /** * Fires the event from no source. Only unfiltered handlers will receive it. *

* Any exceptions thrown by handlers will be bundled into a * {@link UmbrellaException} and then re-thrown after all handlers have * completed. An exception thrown by a handler will not prevent other handlers * from executing. * * @throws UmbrellaException wrapping exceptions thrown by handlers * * @param event the event to fire */ public abstract void fireEvent(Event event); /** * Fires the given event to the handlers listening to the event's type. *

* Any exceptions thrown by handlers will be bundled into a * {@link UmbrellaException} and then re-thrown after all handlers have * completed. An exception thrown by a handler will not prevent other handlers * from executing. * * @throws UmbrellaException wrapping exceptions thrown by handlers * * @param event the event to fire */ public abstract void fireEventFromSource(Event event, Object source); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy