/* * 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}. * <p> * Protected to allow EventBus implementations in different packages to * dispatch events even though the {@code event.dispatch} method is protected. */ protected static <H> void dispatchEvent(Event<H> event, H handler) { event.dispatch(handler); } /** * Sets {@code source} as the source of {@code event}. * <p> * 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. * <p> * It is rare to call this method directly. More typically an {@link Event} * subclass will provide a static <code>register</code> method, or a widget * will accept handlers directly. * * @param <H> 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 <H> HandlerRegistration addHandler(Type<H> type, H handler); /** * Adds a handler to receive events of this type from the given source. * <p> * It is rare to call this method directly. More typically a {@link Event} * subclass will provide a static <code>register</code> method, or a widget * will accept handlers directly. * * @param <H> 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 <H> HandlerRegistration addHandlerToSource(Type<H> type, Object source, H handler); /** * Fires the event from no source. Only unfiltered handlers will receive it. * <p> * 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. * <p> * 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); }