/* * Copyright 2011 cruxframework.org. * * 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 org.cruxframework.crux.core.client.datasource; import org.cruxframework.crux.core.client.rpc.AsyncCallbackAdapter; /** * @author Thiago da Rosa de Bustamante * */ public class DataSourceAsyncCallbackAdapter<T> extends AsyncCallbackAdapter<T[]> { private final Object ds; public DataSourceAsyncCallbackAdapter(Object dataSource) { super(); this.ds = dataSource; } /** * @see org.cruxframework.crux.core.client.rpc.AsyncCallbackAdapter#onComplete(java.lang.Object) */ @SuppressWarnings("unchecked") @Override public void onComplete(T[] result) { if (this.ds instanceof RemoteDataSource) { ((RemoteDataSource<T>)this.ds).updateData(result); } else { ((LocalDataSource<T>)this.ds).updateData(result); } } /** * @see org.cruxframework.crux.core.client.rpc.AsyncCallbackAdapter#onError(java.lang.Throwable) */ @Override @SuppressWarnings("unchecked") public void onError(Throwable e) { if (this.ds instanceof RemoteDataSource) { ((RemoteDataSource<T>)this.ds).cancelFetching(); } super.onError(e); } }