/*******************************************************************************
* Copyright (c) 2012-2017 Codenvy, S.A.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Codenvy, S.A. - initial API and implementation
*******************************************************************************/
package org.eclipse.che.api.promises.client.js;
import elemental.js.util.JsArrayOf;
import elemental.util.ArrayOf;
import com.google.gwt.core.client.JavaScriptObject;
import com.google.gwt.core.client.JsArrayMixed;
import org.eclipse.che.api.promises.client.Promise;
import org.eclipse.che.api.promises.client.PromiseError;
import org.eclipse.che.api.promises.client.PromiseProvider;
/**
* A smattering of useful methods to work with Promises.
*
* @author Mickaƫl Leduque
* @author Artem Zatsarynnyi
*/
public final class Promises {
/** Private constructor, the class is not instantiable. */
private Promises() {
}
/**
* Creates a new promise using the provided executor.
*
* @param conclusion
* the executor
* @param <V>
* the type of the promised value
* @return a promise
*/
public static final native <V> JsPromise<V> create(Executor<V> conclusion) /*-{
return new Promise(conclusion);
}-*/;
/**
* Creates a new promise using the provided executor body.
*
* @param conclusion
* the executor body
* @param <V>
* the type of the promised value
* @return a promise
*/
public static final <V> JsPromise<V> create(Executor.ExecutorBody<V> conclusion) {
return create(Executor.create(conclusion));
}
/**
* Creates a promise that resolves as soon as all the promises used as parameters are resolved or
* rejected as soon as the first rejection happens on one of the included promises.
* This is useful for aggregating results of multiple promises together.
*
* @param promises
* the included promises
* @return a promise with an array of unit values as fulfillment value
* @deprecated use {@link PromiseProvider#all(ArrayOf)}
*/
@Deprecated
public static final native JsPromise<JsArrayMixed> all(ArrayOf<Promise<?>> promises) /*-{
return Promise.all(promises);
}-*/;
/**
* @see #all(ArrayOf)
* @deprecated use {@link PromiseProvider#all2(Promise[])}
*/
@Deprecated
public static final JsPromise<JsArrayMixed> all(final Promise<?>... promises) {
final JsArrayOf<Promise<?>> promisesArray = JavaScriptObject.createArray().cast();
for (final Promise<?> promise : promises) {
promisesArray.push(promise);
}
return all(promisesArray);
}
/**
* Returns a promise that is rejected with the given reason.
*
* @param reason
* the reason of promise rejection
* @param <U>
* the type of the returned promise
* @return
* @deprecated use {@link PromiseProvider#reject(PromiseError)}
*/
@Deprecated
public static final native <U> JsPromise<U> reject(PromiseError reason) /*-{
return Promise.reject(reason);
}-*/;
/**
* Returns a promise that is resolved with the given {@code value}.
*
* @param value
* the 'promised' value
* @param <U>
* the type of the returned promise
* @return a promise that is resolved with the specified value
* @deprecated use {@link PromiseProvider#resolve(U)}
*/
@Deprecated
public static final native <U> JsPromise<U> resolve(U value) /*-{
return Promise.resolve(value);
}-*/;
}