/* * Copyright 2011 ArcBees 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.gwtplatform.mvp.client.proxy; import com.google.gwt.event.shared.GwtEvent; import com.google.web.bindery.event.shared.EventBus; /** * Event fired after any asynchronous call to the server performed by GWTP MVP returns with * Such asynchronous calls only occur when using code splitting. * * @see AsyncCallFailHandler * @see AsyncCallStartEvent * @see AsyncCallSucceedEvent */ public class AsyncCallFailEvent extends GwtEvent<AsyncCallFailHandler> { private static final Type<AsyncCallFailHandler> TYPE = new Type<>(); private final Throwable caught; /** * Creates an event indicating that an asynchronous call has failed, and attach a {@link Throwable} * to it. * * @param caught failure encountered while executing a remote procedure call. */ AsyncCallFailEvent(Throwable caught) { this.caught = caught; } /** * Fires a {@link AsyncCallFailEvent} * into a source that has access to an {@link com.google.web.bindery.event.shared.EventBus}. * * @param source The source that fires this event ({@link EventBus}). * @param caught failure encountered while executing a remote procedure call. */ public static void fire(EventBus source, Throwable caught) { source.fireEvent(new AsyncCallFailEvent(caught)); } public static Type<AsyncCallFailHandler> getType() { return TYPE; } @Override public Type<AsyncCallFailHandler> getAssociatedType() { return getType(); } /** * Access the {@link Throwable} that was obtained when this asynchronous call failed. * * @return The {@link com.gwtplatform.mvp.shared.proxy.PlaceRequest} or {@code null} if no place request is * known. */ public Throwable getCaught() { return caught; } @Override protected void dispatch(AsyncCallFailHandler handler) { handler.onAsyncCallFail(this); } }