001/*
002 * Copyright (C) 2017 The Guava Authors
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016
017package com.google.common.util.concurrent;
018
019import static com.google.common.base.Functions.constant;
020import static com.google.common.base.MoreObjects.toStringHelper;
021import static com.google.common.base.Preconditions.checkArgument;
022import static com.google.common.base.Preconditions.checkNotNull;
023import static com.google.common.base.Preconditions.checkState;
024import static com.google.common.collect.Lists.asList;
025import static com.google.common.util.concurrent.ClosingFuture.State.CLOSED;
026import static com.google.common.util.concurrent.ClosingFuture.State.CLOSING;
027import static com.google.common.util.concurrent.ClosingFuture.State.OPEN;
028import static com.google.common.util.concurrent.ClosingFuture.State.SUBSUMED;
029import static com.google.common.util.concurrent.ClosingFuture.State.WILL_CLOSE;
030import static com.google.common.util.concurrent.ClosingFuture.State.WILL_CREATE_VALUE_AND_CLOSER;
031import static com.google.common.util.concurrent.Futures.getDone;
032import static com.google.common.util.concurrent.Futures.immediateFuture;
033import static com.google.common.util.concurrent.Futures.nonCancellationPropagating;
034import static com.google.common.util.concurrent.MoreExecutors.directExecutor;
035import static com.google.common.util.concurrent.Platform.restoreInterruptIfIsInterruptedException;
036import static java.util.logging.Level.FINER;
037import static java.util.logging.Level.SEVERE;
038import static java.util.logging.Level.WARNING;
039
040import com.google.common.annotations.J2ktIncompatible;
041import com.google.common.annotations.VisibleForTesting;
042import com.google.common.collect.FluentIterable;
043import com.google.common.collect.ImmutableList;
044import com.google.common.util.concurrent.ClosingFuture.Combiner.AsyncCombiningCallable;
045import com.google.common.util.concurrent.ClosingFuture.Combiner.CombiningCallable;
046import com.google.common.util.concurrent.Futures.FutureCombiner;
047import com.google.errorprone.annotations.CanIgnoreReturnValue;
048import com.google.errorprone.annotations.DoNotMock;
049import com.google.j2objc.annotations.RetainedWith;
050import java.io.Closeable;
051import java.util.IdentityHashMap;
052import java.util.Map;
053import java.util.concurrent.Callable;
054import java.util.concurrent.CancellationException;
055import java.util.concurrent.CountDownLatch;
056import java.util.concurrent.ExecutionException;
057import java.util.concurrent.Executor;
058import java.util.concurrent.Future;
059import java.util.concurrent.RejectedExecutionException;
060import java.util.concurrent.atomic.AtomicReference;
061import org.jspecify.annotations.Nullable;
062
063/**
064 * A step in a pipeline of an asynchronous computation. When the last step in the computation is
065 * complete, some objects captured during the computation are closed.
066 *
067 * <p>A pipeline of {@code ClosingFuture}s is a tree of steps. Each step represents either an
068 * asynchronously-computed intermediate value, or else an exception that indicates the failure or
069 * cancellation of the operation so far. The only way to extract the value or exception from a step
070 * is by declaring that step to be the last step of the pipeline. Nevertheless, we refer to the
071 * "value" of a successful step or the "result" (value or exception) of any step.
072 *
073 * <ol>
074 *   <li>A pipeline starts at its leaf step (or steps), which is created from either a callable
075 *       block or a {@link ListenableFuture}.
076 *   <li>Each other step is derived from one or more input steps. At each step, zero or more objects
077 *       can be captured for later closing.
078 *   <li>There is one last step (the root of the tree), from which you can extract the final result
079 *       of the computation. After that result is available (or the computation fails), all objects
080 *       captured by any of the steps in the pipeline are closed.
081 * </ol>
082 *
083 * <h3>Starting a pipeline</h3>
084 *
085 * Start a {@code ClosingFuture} pipeline {@linkplain #submit(ClosingCallable, Executor) from a
086 * callable block} that may capture objects for later closing. To start a pipeline from a {@link
087 * ListenableFuture} that doesn't create resources that should be closed later, you can use {@link
088 * #from(ListenableFuture)} instead.
089 *
090 * <h3>Derived steps</h3>
091 *
092 * A {@code ClosingFuture} step can be derived from one or more input {@code ClosingFuture} steps in
093 * ways similar to {@link FluentFuture}s:
094 *
095 * <ul>
096 *   <li>by transforming the value from a successful input step,
097 *   <li>by catching the exception from a failed input step, or
098 *   <li>by combining the results of several input steps.
099 * </ul>
100 *
101 * Each derivation can capture the next value or any intermediate objects for later closing.
102 *
103 * <p>A step can be the input to at most one derived step. Once you transform its value, catch its
104 * exception, or combine it with others, you cannot do anything else with it, including declare it
105 * to be the last step of the pipeline.
106 *
107 * <h4>Transforming</h4>
108 *
109 * To derive the next step by asynchronously applying a function to an input step's value, call
110 * {@link #transform(ClosingFunction, Executor)} or {@link #transformAsync(AsyncClosingFunction,
111 * Executor)} on the input step.
112 *
113 * <h4>Catching</h4>
114 *
115 * To derive the next step from a failed input step, call {@link #catching(Class, ClosingFunction,
116 * Executor)} or {@link #catchingAsync(Class, AsyncClosingFunction, Executor)} on the input step.
117 *
118 * <h4>Combining</h4>
119 *
120 * To derive a {@code ClosingFuture} from two or more input steps, pass the input steps to {@link
121 * #whenAllComplete(Iterable)} or {@link #whenAllSucceed(Iterable)} or its overloads.
122 *
123 * <h3>Cancelling</h3>
124 *
125 * Any step in a pipeline can be {@linkplain #cancel(boolean) cancelled}, even after another step
126 * has been derived, with the same semantics as cancelling a {@link Future}. In addition, a
127 * successfully cancelled step will immediately start closing all objects captured for later closing
128 * by it and by its input steps.
129 *
130 * <h3>Ending a pipeline</h3>
131 *
132 * Each {@code ClosingFuture} pipeline must be ended. To end a pipeline, decide whether you want to
133 * close the captured objects automatically or manually.
134 *
135 * <h4>Automatically closing</h4>
136 *
137 * You can extract a {@link Future} that represents the result of the last step in the pipeline by
138 * calling {@link #finishToFuture()}. All objects the pipeline has captured for closing will begin
139 * to be closed asynchronously <b>after</b> the returned {@code Future} is done: the future
140 * completes before closing starts, rather than once it has finished.
141 *
142 * <pre>{@code
143 * FluentFuture<UserName> userName =
144 *     ClosingFuture.submit(
145 *             closer -> closer.eventuallyClose(database.newTransaction(), closingExecutor),
146 *             executor)
147 *         .transformAsync((closer, transaction) -> transaction.queryClosingFuture("..."), executor)
148 *         .transform((closer, result) -> result.get("userName"), directExecutor())
149 *         .catching(DBException.class, e -> "no user", directExecutor())
150 *         .finishToFuture();
151 * }</pre>
152 *
153 * In this example, when the {@code userName} {@link Future} is done, the transaction and the query
154 * result cursor will both be closed, even if the operation is cancelled or fails.
155 *
156 * <h4>Manually closing</h4>
157 *
158 * If you want to close the captured objects manually, after you've used the final result, call
159 * {@link #finishToValueAndCloser(ValueAndCloserConsumer, Executor)} to get an object that holds the
160 * final result. You then call {@link ValueAndCloser#closeAsync()} to close the captured objects.
161 *
162 * <pre>{@code
163 *     ClosingFuture.submit(
164 *             closer -> closer.eventuallyClose(database.newTransaction(), closingExecutor),
165 *             executor)
166 *     .transformAsync((closer, transaction) -> transaction.queryClosingFuture("..."), executor)
167 *     .transform((closer, result) -> result.get("userName"), directExecutor())
168 *     .catching(DBException.class, e -> "no user", directExecutor())
169 *     .finishToValueAndCloser(
170 *         valueAndCloser -> this.userNameValueAndCloser = valueAndCloser, executor);
171 *
172 * // later
173 * try { // get() will throw if the operation failed or was cancelled.
174 *   UserName userName = userNameValueAndCloser.get();
175 *   // do something with userName
176 * } finally {
177 *   userNameValueAndCloser.closeAsync();
178 * }
179 * }</pre>
180 *
181 * In this example, when {@code userNameValueAndCloser.closeAsync()} is called, the transaction and
182 * the query result cursor will both be closed, even if the operation is cancelled or fails.
183 *
184 * <p>Note that if you don't call {@code closeAsync()}, the captured objects will not be closed. The
185 * automatic-closing approach described above is safer.
186 *
187 * @param <V> the type of the value of this step
188 * @since 30.0
189 */
190// TODO(dpb): Consider reusing one CloseableList for the entire pipeline, modulo combinations.
191@DoNotMock("Use ClosingFuture.from(Futures.immediate*Future)")
192@J2ktIncompatible
193// TODO(dpb): GWT compatibility.
194public final class ClosingFuture<V extends @Nullable Object> {
195
196  private static final LazyLogger logger = new LazyLogger(ClosingFuture.class);
197
198  /**
199   * An object that can capture objects to be closed later, when a {@link ClosingFuture} pipeline is
200   * done.
201   */
202  public static final class DeferredCloser {
203    @RetainedWith private final CloseableList list;
204
205    DeferredCloser(CloseableList list) {
206      this.list = list;
207    }
208
209    /**
210     * Captures an object to be closed when a {@link ClosingFuture} pipeline is done.
211     *
212     * <p>For users of the {@code -jre} flavor of Guava, the object can be any {@code
213     * AutoCloseable}. For users of the {@code -android} flavor, the object must be a {@code
214     * Closeable}. (For more about the flavors, see <a
215     * href="https://github.com/google/guava#adding-guava-to-your-build">Adding Guava to your
216     * build</a>.)
217     *
218     * <p>Be careful when targeting an older SDK than you are building against (most commonly when
219     * building for Android): Ensure that any object you pass implements the interface not just in
220     * your current SDK version but also at the oldest version you support. For example, <a
221     * href="https://developer.android.com/sdk/api_diff/16/">API Level 16</a> is the first version
222     * in which {@code Cursor} is {@code Closeable}. To support older versions, pass a wrapper
223     * {@code Closeable} with a method reference like {@code cursor::close}.
224     *
225     * <p>Note that this method is still binary-compatible between flavors because the erasure of
226     * its parameter type is {@code Object}, not {@code AutoCloseable} or {@code Closeable}.
227     *
228     * @param closeable the object to be closed (see notes above)
229     * @param closingExecutor the object will be closed on this executor
230     * @return the first argument
231     */
232    @CanIgnoreReturnValue
233    @ParametricNullness
234    public <C extends @Nullable Object & @Nullable AutoCloseable> C eventuallyClose(
235        @ParametricNullness C closeable, Executor closingExecutor) {
236      checkNotNull(closingExecutor);
237      if (closeable != null) {
238        list.add(closeable, closingExecutor);
239      }
240      return closeable;
241    }
242  }
243
244  /**
245   * An operation that computes a result.
246   *
247   * @param <V> the type of the result
248   */
249  public interface ClosingCallable<V extends @Nullable Object> {
250    /**
251     * Computes a result, or throws an exception if unable to do so.
252     *
253     * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
254     * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done (but
255     * not before this method completes), even if this method throws or the pipeline is cancelled.
256     */
257    @ParametricNullness
258    V call(DeferredCloser closer) throws Exception;
259  }
260
261  /**
262   * An operation that computes a {@link ClosingFuture} of a result.
263   *
264   * @param <V> the type of the result
265   * @since 30.1
266   */
267  public interface AsyncClosingCallable<V extends @Nullable Object> {
268    /**
269     * Computes a result, or throws an exception if unable to do so.
270     *
271     * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
272     * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done (but
273     * not before this method completes), even if this method throws or the pipeline is cancelled.
274     */
275    ClosingFuture<V> call(DeferredCloser closer) throws Exception;
276  }
277
278  /**
279   * A function from an input to a result.
280   *
281   * @param <T> the type of the input to the function
282   * @param <U> the type of the result of the function
283   */
284  public interface ClosingFunction<T extends @Nullable Object, U extends @Nullable Object> {
285
286    /**
287     * Applies this function to an input, or throws an exception if unable to do so.
288     *
289     * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
290     * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done (but
291     * not before this method completes), even if this method throws or the pipeline is cancelled.
292     */
293    @ParametricNullness
294    U apply(DeferredCloser closer, @ParametricNullness T input) throws Exception;
295  }
296
297  /**
298   * A function from an input to a {@link ClosingFuture} of a result.
299   *
300   * @param <T> the type of the input to the function
301   * @param <U> the type of the result of the function
302   */
303  public interface AsyncClosingFunction<T extends @Nullable Object, U extends @Nullable Object> {
304    /**
305     * Applies this function to an input, or throws an exception if unable to do so.
306     *
307     * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
308     * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done (but
309     * not before this method completes), even if this method throws or the pipeline is cancelled.
310     */
311    ClosingFuture<U> apply(DeferredCloser closer, @ParametricNullness T input) throws Exception;
312  }
313
314  /**
315   * An object that holds the final result of an asynchronous {@link ClosingFuture} operation and
316   * allows the user to close all the closeable objects that were captured during it for later
317   * closing.
318   *
319   * <p>The asynchronous operation will have completed before this object is created.
320   *
321   * @param <V> the type of the value of a successful operation
322   * @see ClosingFuture#finishToValueAndCloser(ValueAndCloserConsumer, Executor)
323   */
324  public static final class ValueAndCloser<V extends @Nullable Object> {
325
326    private final ClosingFuture<? extends V> closingFuture;
327
328    ValueAndCloser(ClosingFuture<? extends V> closingFuture) {
329      this.closingFuture = checkNotNull(closingFuture);
330    }
331
332    /**
333     * Returns the final value of the associated {@link ClosingFuture}, or throws an exception as
334     * {@link Future#get()} would.
335     *
336     * <p>Because the asynchronous operation has already completed, this method is synchronous and
337     * returns immediately.
338     *
339     * @throws CancellationException if the computation was cancelled
340     * @throws ExecutionException if the computation threw an exception
341     */
342    @ParametricNullness
343    public V get() throws ExecutionException {
344      return getDone(closingFuture.future);
345    }
346
347    /**
348     * Starts closing all closeable objects captured during the {@link ClosingFuture}'s asynchronous
349     * operation on the {@link Executor}s specified by calls to {@link
350     * DeferredCloser#eventuallyClose(Object, Executor)}.
351     *
352     * <p>If any such calls specified {@link MoreExecutors#directExecutor()}, those objects will be
353     * closed synchronously.
354     *
355     * <p>Idempotent: objects will be closed at most once.
356     */
357    public void closeAsync() {
358      closingFuture.close();
359    }
360  }
361
362  /**
363   * Represents an operation that accepts a {@link ValueAndCloser} for the last step in a {@link
364   * ClosingFuture} pipeline.
365   *
366   * @param <V> the type of the final value of a successful pipeline
367   * @see ClosingFuture#finishToValueAndCloser(ValueAndCloserConsumer, Executor)
368   */
369  public interface ValueAndCloserConsumer<V extends @Nullable Object> {
370
371    /** Accepts a {@link ValueAndCloser} for the last step in a {@link ClosingFuture} pipeline. */
372    void accept(ValueAndCloser<V> valueAndCloser);
373  }
374
375  /**
376   * Starts a {@link ClosingFuture} pipeline by submitting a callable block to an executor.
377   *
378   * @throws java.util.concurrent.RejectedExecutionException if the task cannot be scheduled for
379   *     execution
380   */
381  public static <V extends @Nullable Object> ClosingFuture<V> submit(
382      ClosingCallable<V> callable, Executor executor) {
383    checkNotNull(callable);
384    CloseableList closeables = new CloseableList();
385    TrustedListenableFutureTask<V> task =
386        TrustedListenableFutureTask.create(
387            new Callable<V>() {
388              @Override
389              @ParametricNullness
390              public V call() throws Exception {
391                return callable.call(closeables.closer);
392              }
393
394              @Override
395              public String toString() {
396                return callable.toString();
397              }
398            });
399    executor.execute(task);
400    return new ClosingFuture<>(task, closeables);
401  }
402
403  /**
404   * Starts a {@link ClosingFuture} pipeline by submitting a callable block to an executor.
405   *
406   * @throws java.util.concurrent.RejectedExecutionException if the task cannot be scheduled for
407   *     execution
408   * @since 30.1
409   */
410  public static <V extends @Nullable Object> ClosingFuture<V> submitAsync(
411      AsyncClosingCallable<V> callable, Executor executor) {
412    checkNotNull(callable);
413    CloseableList closeables = new CloseableList();
414    TrustedListenableFutureTask<V> task =
415        TrustedListenableFutureTask.create(
416            new AsyncCallable<V>() {
417              @Override
418              public ListenableFuture<V> call() throws Exception {
419                CloseableList newCloseables = new CloseableList();
420                try {
421                  ClosingFuture<V> closingFuture = callable.call(newCloseables.closer);
422                  closingFuture.becomeSubsumedInto(closeables);
423                  return closingFuture.future;
424                } finally {
425                  closeables.add(newCloseables, directExecutor());
426                }
427              }
428
429              @Override
430              public String toString() {
431                return callable.toString();
432              }
433            });
434    executor.execute(task);
435    return new ClosingFuture<>(task, closeables);
436  }
437
438  /**
439   * Starts a {@link ClosingFuture} pipeline with a {@link ListenableFuture}.
440   *
441   * <p>{@code future}'s value will not be closed when the pipeline is done even if {@code V}
442   * implements {@link Closeable}. In order to start a pipeline with a value that will be closed
443   * when the pipeline is done, use {@link #submit(ClosingCallable, Executor)} instead.
444   */
445  public static <V extends @Nullable Object> ClosingFuture<V> from(ListenableFuture<V> future) {
446    return new ClosingFuture<>(future);
447  }
448
449  /**
450   * Starts a {@link ClosingFuture} pipeline with a {@link ListenableFuture}.
451   *
452   * <p>If {@code future} succeeds, its value will be closed (using {@code closingExecutor)}) when
453   * the pipeline is done, even if the pipeline is canceled or fails.
454   *
455   * <p>Cancelling the pipeline will not cancel {@code future}, so that the pipeline can access its
456   * value in order to close it.
457   *
458   * @param future the future to create the {@code ClosingFuture} from. For discussion of the
459   *     future's result type {@code C}, see {@link DeferredCloser#eventuallyClose(Object,
460   *     Executor)}.
461   * @param closingExecutor the future's result will be closed on this executor
462   * @deprecated Creating {@link Future}s of closeable types is dangerous in general because the
463   *     underlying value may never be closed if the {@link Future} is canceled after its operation
464   *     begins. Consider replacing code that creates {@link ListenableFuture}s of closeable types,
465   *     including those that pass them to this method, with {@link #submit(ClosingCallable,
466   *     Executor)} in order to ensure that resources do not leak. Or, to start a pipeline with a
467   *     {@link ListenableFuture} that doesn't create values that should be closed, use {@link
468   *     ClosingFuture#from}.
469   */
470  @Deprecated
471  public static <C extends @Nullable Object & @Nullable AutoCloseable>
472      ClosingFuture<C> eventuallyClosing(
473          ListenableFuture<C> future, final Executor closingExecutor) {
474    checkNotNull(closingExecutor);
475    final ClosingFuture<C> closingFuture = new ClosingFuture<>(nonCancellationPropagating(future));
476    Futures.addCallback(
477        future,
478        new FutureCallback<@Nullable AutoCloseable>() {
479          @Override
480          public void onSuccess(@Nullable AutoCloseable result) {
481            closingFuture.closeables.closer.eventuallyClose(result, closingExecutor);
482          }
483
484          @Override
485          public void onFailure(Throwable t) {}
486        },
487        directExecutor());
488    return closingFuture;
489  }
490
491  /**
492   * Starts specifying how to combine {@link ClosingFuture}s into a single pipeline.
493   *
494   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
495   *     the {@code futures}, or if any has already been {@linkplain #finishToFuture() finished}
496   */
497  public static Combiner whenAllComplete(Iterable<? extends ClosingFuture<?>> futures) {
498    return new Combiner(false, futures);
499  }
500
501  /**
502   * Starts specifying how to combine {@link ClosingFuture}s into a single pipeline.
503   *
504   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
505   *     the arguments, or if any has already been {@linkplain #finishToFuture() finished}
506   */
507  public static Combiner whenAllComplete(
508      ClosingFuture<?> future1, ClosingFuture<?>... moreFutures) {
509    return whenAllComplete(asList(future1, moreFutures));
510  }
511
512  /**
513   * Starts specifying how to combine {@link ClosingFuture}s into a single pipeline, assuming they
514   * all succeed. If any fail, the resulting pipeline will fail.
515   *
516   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
517   *     the {@code futures}, or if any has already been {@linkplain #finishToFuture() finished}
518   */
519  public static Combiner whenAllSucceed(Iterable<? extends ClosingFuture<?>> futures) {
520    return new Combiner(true, futures);
521  }
522
523  /**
524   * Starts specifying how to combine two {@link ClosingFuture}s into a single pipeline, assuming
525   * they all succeed. If any fail, the resulting pipeline will fail.
526   *
527   * <p>Calling this method allows you to use lambdas or method references typed with the types of
528   * the input {@link ClosingFuture}s.
529   *
530   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
531   *     the arguments, or if any has already been {@linkplain #finishToFuture() finished}
532   */
533  public static <V1 extends @Nullable Object, V2 extends @Nullable Object>
534      Combiner2<V1, V2> whenAllSucceed(ClosingFuture<V1> future1, ClosingFuture<V2> future2) {
535    return new Combiner2<>(future1, future2);
536  }
537
538  /**
539   * Starts specifying how to combine three {@link ClosingFuture}s into a single pipeline, assuming
540   * they all succeed. If any fail, the resulting pipeline will fail.
541   *
542   * <p>Calling this method allows you to use lambdas or method references typed with the types of
543   * the input {@link ClosingFuture}s.
544   *
545   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
546   *     the arguments, or if any has already been {@linkplain #finishToFuture() finished}
547   */
548  public static <
549          V1 extends @Nullable Object, V2 extends @Nullable Object, V3 extends @Nullable Object>
550      Combiner3<V1, V2, V3> whenAllSucceed(
551          ClosingFuture<V1> future1, ClosingFuture<V2> future2, ClosingFuture<V3> future3) {
552    return new Combiner3<>(future1, future2, future3);
553  }
554
555  /**
556   * Starts specifying how to combine four {@link ClosingFuture}s into a single pipeline, assuming
557   * they all succeed. If any fail, the resulting pipeline will fail.
558   *
559   * <p>Calling this method allows you to use lambdas or method references typed with the types of
560   * the input {@link ClosingFuture}s.
561   *
562   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
563   *     the arguments, or if any has already been {@linkplain #finishToFuture() finished}
564   */
565  public static <
566          V1 extends @Nullable Object,
567          V2 extends @Nullable Object,
568          V3 extends @Nullable Object,
569          V4 extends @Nullable Object>
570      Combiner4<V1, V2, V3, V4> whenAllSucceed(
571          ClosingFuture<V1> future1,
572          ClosingFuture<V2> future2,
573          ClosingFuture<V3> future3,
574          ClosingFuture<V4> future4) {
575    return new Combiner4<>(future1, future2, future3, future4);
576  }
577
578  /**
579   * Starts specifying how to combine five {@link ClosingFuture}s into a single pipeline, assuming
580   * they all succeed. If any fail, the resulting pipeline will fail.
581   *
582   * <p>Calling this method allows you to use lambdas or method references typed with the types of
583   * the input {@link ClosingFuture}s.
584   *
585   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
586   *     the arguments, or if any has already been {@linkplain #finishToFuture() finished}
587   */
588  public static <
589          V1 extends @Nullable Object,
590          V2 extends @Nullable Object,
591          V3 extends @Nullable Object,
592          V4 extends @Nullable Object,
593          V5 extends @Nullable Object>
594      Combiner5<V1, V2, V3, V4, V5> whenAllSucceed(
595          ClosingFuture<V1> future1,
596          ClosingFuture<V2> future2,
597          ClosingFuture<V3> future3,
598          ClosingFuture<V4> future4,
599          ClosingFuture<V5> future5) {
600    return new Combiner5<>(future1, future2, future3, future4, future5);
601  }
602
603  /**
604   * Starts specifying how to combine {@link ClosingFuture}s into a single pipeline, assuming they
605   * all succeed. If any fail, the resulting pipeline will fail.
606   *
607   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from any of
608   *     the arguments, or if any has already been {@linkplain #finishToFuture() finished}
609   */
610  public static Combiner whenAllSucceed(
611      ClosingFuture<?> future1,
612      ClosingFuture<?> future2,
613      ClosingFuture<?> future3,
614      ClosingFuture<?> future4,
615      ClosingFuture<?> future5,
616      ClosingFuture<?> future6,
617      ClosingFuture<?>... moreFutures) {
618    return whenAllSucceed(
619        FluentIterable.of(future1, future2, future3, future4, future5, future6)
620            .append(moreFutures));
621  }
622
623  private final AtomicReference<State> state = new AtomicReference<>(OPEN);
624  private final CloseableList closeables;
625  private final FluentFuture<V> future;
626
627  private ClosingFuture(ListenableFuture<V> future) {
628    this(future, new CloseableList());
629  }
630
631  private ClosingFuture(ListenableFuture<V> future, CloseableList closeables) {
632    this.future = FluentFuture.from(future);
633    this.closeables = closeables;
634  }
635
636  /**
637   * Returns a future that finishes when this step does. Calling {@code get()} on the returned
638   * future returns {@code null} if the step is successful or throws the same exception that would
639   * be thrown by calling {@code finishToFuture().get()} if this were the last step. Calling {@code
640   * cancel()} on the returned future has no effect on the {@code ClosingFuture} pipeline.
641   *
642   * <p>{@code statusFuture} differs from most methods on {@code ClosingFuture}: You can make calls
643   * to {@code statusFuture} <i>in addition to</i> the call you make to {@link #finishToFuture()} or
644   * a derivation method <i>on the same instance</i>. This is important because calling {@code
645   * statusFuture} alone does not provide a way to close the pipeline.
646   */
647  public ListenableFuture<?> statusFuture() {
648    return nonCancellationPropagating(future.transform(constant(null), directExecutor()));
649  }
650
651  /**
652   * Returns a new {@code ClosingFuture} pipeline step derived from this one by applying a function
653   * to its value. The function can use a {@link DeferredCloser} to capture objects to be closed
654   * when the pipeline is done.
655   *
656   * <p>If this {@code ClosingFuture} fails, the function will not be called, and the derived {@code
657   * ClosingFuture} will be equivalent to this one.
658   *
659   * <p>If the function throws an exception, that exception is used as the result of the derived
660   * {@code ClosingFuture}.
661   *
662   * <p>Example usage:
663   *
664   * <pre>{@code
665   * ClosingFuture<List<Row>> rowsFuture =
666   *     queryFuture.transform((closer, result) -> result.getRows(), executor);
667   * }</pre>
668   *
669   * <p>When selecting an executor, note that {@code directExecutor} is dangerous in some cases. See
670   * the discussion in the {@link ListenableFuture#addListener} documentation. All its warnings
671   * about heavyweight listeners are also applicable to heavyweight functions passed to this method.
672   *
673   * <p>After calling this method, you may not call {@link #finishToFuture()}, {@link
674   * #finishToValueAndCloser(ValueAndCloserConsumer, Executor)}, or any other derivation method on
675   * the original {@code ClosingFuture} instance.
676   *
677   * @param function transforms the value of this step to the value of the derived step
678   * @param executor executor to run the function in
679   * @return the derived step
680   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from this
681   *     one, or if this {@code ClosingFuture} has already been {@linkplain #finishToFuture()
682   *     finished}
683   */
684  public <U extends @Nullable Object> ClosingFuture<U> transform(
685      final ClosingFunction<? super V, U> function, Executor executor) {
686    checkNotNull(function);
687    AsyncFunction<V, U> applyFunction =
688        new AsyncFunction<V, U>() {
689          @Override
690          public ListenableFuture<U> apply(V input) throws Exception {
691            return closeables.applyClosingFunction(function, input);
692          }
693
694          @Override
695          public String toString() {
696            return function.toString();
697          }
698        };
699    // TODO(dpb): Switch to future.transformSync when that exists (passing a throwing function).
700    return derive(future.transformAsync(applyFunction, executor));
701  }
702
703  /**
704   * Returns a new {@code ClosingFuture} pipeline step derived from this one by applying a function
705   * that returns a {@code ClosingFuture} to its value. The function can use a {@link
706   * DeferredCloser} to capture objects to be closed when the pipeline is done (other than those
707   * captured by the returned {@link ClosingFuture}).
708   *
709   * <p>If this {@code ClosingFuture} succeeds, the derived one will be equivalent to the one
710   * returned by the function.
711   *
712   * <p>If this {@code ClosingFuture} fails, the function will not be called, and the derived {@code
713   * ClosingFuture} will be equivalent to this one.
714   *
715   * <p>If the function throws an exception, that exception is used as the result of the derived
716   * {@code ClosingFuture}. But if the exception is thrown after the function creates a {@code
717   * ClosingFuture}, then none of the closeable objects in that {@code ClosingFuture} will be
718   * closed.
719   *
720   * <p>Usage guidelines for this method:
721   *
722   * <ul>
723   *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
724   *       {@code ClosingFuture}. If possible, prefer calling {@link #transform(ClosingFunction,
725   *       Executor)} instead, with a function that returns the next value directly.
726   *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
727   *       for every closeable object this step creates in order to capture it for later closing.
728   *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
729   *       ClosingFuture} call {@link #from(ListenableFuture)}.
730   *   <li>In case this step doesn't create new closeables, you can adapt an API that returns a
731   *       {@link ListenableFuture} to return a {@code ClosingFuture} by wrapping it with a call to
732   *       {@link #withoutCloser(AsyncFunction)}
733   * </ul>
734   *
735   * <p>Example usage:
736   *
737   * <pre>{@code
738   * // Result.getRowsClosingFuture() returns a ClosingFuture.
739   * ClosingFuture<List<Row>> rowsFuture =
740   *     queryFuture.transformAsync((closer, result) -> result.getRowsClosingFuture(), executor);
741   *
742   * // Result.writeRowsToOutputStreamFuture() returns a ListenableFuture that resolves to the
743   * // number of written rows. openOutputFile() returns a FileOutputStream (which implements
744   * // Closeable).
745   * ClosingFuture<Integer> rowsFuture2 =
746   *     queryFuture.transformAsync(
747   *         (closer, result) -> {
748   *           FileOutputStream fos = closer.eventuallyClose(openOutputFile(), closingExecutor);
749   *           return ClosingFuture.from(result.writeRowsToOutputStreamFuture(fos));
750   *      },
751   *      executor);
752   *
753   * // Result.getRowsFuture() returns a ListenableFuture (no new closeables are created).
754   * ClosingFuture<List<Row>> rowsFuture3 =
755   *     queryFuture.transformAsync(withoutCloser(Result::getRowsFuture), executor);
756   *
757   * }</pre>
758   *
759   * <p>When selecting an executor, note that {@code directExecutor} is dangerous in some cases. See
760   * the discussion in the {@link ListenableFuture#addListener} documentation. All its warnings
761   * about heavyweight listeners are also applicable to heavyweight functions passed to this method.
762   * (Specifically, {@code directExecutor} functions should avoid heavyweight operations inside
763   * {@code AsyncClosingFunction.apply}. Any heavyweight operations should occur in other threads
764   * responsible for completing the returned {@code ClosingFuture}.)
765   *
766   * <p>After calling this method, you may not call {@link #finishToFuture()}, {@link
767   * #finishToValueAndCloser(ValueAndCloserConsumer, Executor)}, or any other derivation method on
768   * the original {@code ClosingFuture} instance.
769   *
770   * @param function transforms the value of this step to a {@code ClosingFuture} with the value of
771   *     the derived step
772   * @param executor executor to run the function in
773   * @return the derived step
774   * @throws IllegalStateException if a {@code ClosingFuture} has already been derived from this
775   *     one, or if this {@code ClosingFuture} has already been {@linkplain #finishToFuture()
776   *     finished}
777   */
778  public <U extends @Nullable Object> ClosingFuture<U> transformAsync(
779      final AsyncClosingFunction<? super V, U> function, Executor executor) {
780    checkNotNull(function);
781    AsyncFunction<V, U> applyFunction =
782        new AsyncFunction<V, U>() {
783          @Override
784          public ListenableFuture<U> apply(V input) throws Exception {
785            return closeables.applyAsyncClosingFunction(function, input);
786          }
787
788          @Override
789          public String toString() {
790            return function.toString();
791          }
792        };
793    return derive(future.transformAsync(applyFunction, executor));
794  }
795
796  /**
797   * Returns an {@link AsyncClosingFunction} that applies an {@link AsyncFunction} to an input,
798   * ignoring the DeferredCloser and returning a {@code ClosingFuture} derived from the returned
799   * {@link ListenableFuture}.
800   *
801   * <p>Use this method to pass a transformation to {@link #transformAsync(AsyncClosingFunction,
802   * Executor)} or to {@link #catchingAsync(Class, AsyncClosingFunction, Executor)} as long as it
803   * meets these conditions:
804   *
805   * <ul>
806   *   <li>It does not need to capture any {@link Closeable} objects by calling {@link
807   *       DeferredCloser#eventuallyClose(Object, Executor)}.
808   *   <li>It returns a {@link ListenableFuture}.
809   * </ul>
810   *
811   * <p>Example usage:
812   *
813   * <pre>{@code
814   * // Result.getRowsFuture() returns a ListenableFuture.
815   * ClosingFuture<List<Row>> rowsFuture =
816   *     queryFuture.transformAsync(withoutCloser(Result::getRowsFuture), executor);
817   * }</pre>
818   *
819   * @param function transforms the value of a {@code ClosingFuture} step to a {@link
820   *     ListenableFuture} with the value of a derived step
821   */
822  public static <V extends @Nullable Object, U extends @Nullable Object>
823      AsyncClosingFunction<V, U> withoutCloser(final AsyncFunction<V, U> function) {
824    checkNotNull(function);
825    return new AsyncClosingFunction<V, U>() {
826      @Override
827      public ClosingFuture<U> apply(DeferredCloser closer, V input) throws Exception {
828        return ClosingFuture.from(function.apply(input));
829      }
830    };
831  }
832
833  /**
834   * Returns a new {@code ClosingFuture} pipeline step derived from this one by applying a function
835   * to its exception if it is an instance of a given exception type. The function can use a {@link
836   * DeferredCloser} to capture objects to be closed when the pipeline is done.
837   *
838   * <p>If this {@code ClosingFuture} succeeds or fails with a different exception type, the
839   * function will not be called, and the derived {@code ClosingFuture} will be equivalent to this
840   * one.
841   *
842   * <p>If the function throws an exception, that exception is used as the result of the derived
843   * {@code ClosingFuture}.
844   *
845   * <p>Example usage:
846   *
847   * <pre>{@code
848   * ClosingFuture<QueryResult> queryFuture =
849   *     queryFuture.catching(
850   *         QueryException.class, (closer, x) -> Query.emptyQueryResult(), executor);
851   * }</pre>
852   *
853   * <p>When selecting an executor, note that {@code directExecutor} is dangerous in some cases. See
854   * the discussion in the {@link ListenableFuture#addListener} documentation. All its warnings
855   * about heavyweight listeners are also applicable to heavyweight functions passed to this method.
856   *
857   * <p>After calling this method, you may not call {@link #finishToFuture()}, {@link
858   * #finishToValueAndCloser(ValueAndCloserConsumer, Executor)}, or any other derivation method on
859   * the original {@code ClosingFuture} instance.
860   *
861   * @param exceptionType the exception type that triggers use of {@code fallback}. The exception
862   *     type is matched against this step's exception. "This step's exception" means the cause of
863   *     the {@link ExecutionException} thrown by {@link Future#get()} on the {@link Future}
864   *     underlying this step or, if {@code get()} throws a different kind of exception, that
865   *     exception itself. To avoid hiding bugs and other unrecoverable errors, callers should
866   *     prefer more specific types, avoiding {@code Throwable.class} in particular.
867   * @param fallback the function to be called if this step fails with the expected exception type.
868   *     The function's argument is this step's exception. "This step's exception" means the cause
869   *     of the {@link ExecutionException} thrown by {@link Future#get()} on the {@link Future}
870   *     underlying this step or, if {@code get()} throws a different kind of exception, that
871   *     exception itself.
872   * @param executor the executor that runs {@code fallback} if the input fails
873   */
874  public <X extends Throwable> ClosingFuture<V> catching(
875      Class<X> exceptionType, ClosingFunction<? super X, ? extends V> fallback, Executor executor) {
876    return catchingMoreGeneric(exceptionType, fallback, executor);
877  }
878
879  // Avoids generic type capture inconsistency problems where |? extends V| is incompatible with V.
880  private <X extends Throwable, W extends V> ClosingFuture<V> catchingMoreGeneric(
881      Class<X> exceptionType, final ClosingFunction<? super X, W> fallback, Executor executor) {
882    checkNotNull(fallback);
883    AsyncFunction<X, W> applyFallback =
884        new AsyncFunction<X, W>() {
885          @Override
886          public ListenableFuture<W> apply(X exception) throws Exception {
887            return closeables.applyClosingFunction(fallback, exception);
888          }
889
890          @Override
891          public String toString() {
892            return fallback.toString();
893          }
894        };
895    // TODO(dpb): Switch to future.catchingSync when that exists (passing a throwing function).
896    return derive(future.catchingAsync(exceptionType, applyFallback, executor));
897  }
898
899  /**
900   * Returns a new {@code ClosingFuture} pipeline step derived from this one by applying a function
901   * that returns a {@code ClosingFuture} to its exception if it is an instance of a given exception
902   * type. The function can use a {@link DeferredCloser} to capture objects to be closed when the
903   * pipeline is done (other than those captured by the returned {@link ClosingFuture}).
904   *
905   * <p>If this {@code ClosingFuture} fails with an exception of the given type, the derived {@code
906   * ClosingFuture} will be equivalent to the one returned by the function.
907   *
908   * <p>If this {@code ClosingFuture} succeeds or fails with a different exception type, the
909   * function will not be called, and the derived {@code ClosingFuture} will be equivalent to this
910   * one.
911   *
912   * <p>If the function throws an exception, that exception is used as the result of the derived
913   * {@code ClosingFuture}. But if the exception is thrown after the function creates a {@code
914   * ClosingFuture}, then none of the closeable objects in that {@code ClosingFuture} will be
915   * closed.
916   *
917   * <p>Usage guidelines for this method:
918   *
919   * <ul>
920   *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
921   *       {@code ClosingFuture}. If possible, prefer calling {@link #catching(Class,
922   *       ClosingFunction, Executor)} instead, with a function that returns the next value
923   *       directly.
924   *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
925   *       for every closeable object this step creates in order to capture it for later closing.
926   *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
927   *       ClosingFuture} call {@link #from(ListenableFuture)}.
928   *   <li>In case this step doesn't create new closeables, you can adapt an API that returns a
929   *       {@link ListenableFuture} to return a {@code ClosingFuture} by wrapping it with a call to
930   *       {@link #withoutCloser(AsyncFunction)}
931   * </ul>
932   *
933   * <p>Example usage:
934   *
935   * <pre>{@code
936   * // Fall back to a secondary input stream in case of IOException.
937   * ClosingFuture<InputStream> inputFuture =
938   *     firstInputFuture.catchingAsync(
939   *         IOException.class, (closer, x) -> secondaryInputStreamClosingFuture(), executor);
940   * }
941   * }</pre>
942   *
943   * <p>When selecting an executor, note that {@code directExecutor} is dangerous in some cases. See
944   * the discussion in the {@link ListenableFuture#addListener} documentation. All its warnings
945   * about heavyweight listeners are also applicable to heavyweight functions passed to this method.
946   * (Specifically, {@code directExecutor} functions should avoid heavyweight operations inside
947   * {@code AsyncClosingFunction.apply}. Any heavyweight operations should occur in other threads
948   * responsible for completing the returned {@code ClosingFuture}.)
949   *
950   * <p>After calling this method, you may not call {@link #finishToFuture()}, {@link
951   * #finishToValueAndCloser(ValueAndCloserConsumer, Executor)}, or any other derivation method on
952   * the original {@code ClosingFuture} instance.
953   *
954   * @param exceptionType the exception type that triggers use of {@code fallback}. The exception
955   *     type is matched against this step's exception. "This step's exception" means the cause of
956   *     the {@link ExecutionException} thrown by {@link Future#get()} on the {@link Future}
957   *     underlying this step or, if {@code get()} throws a different kind of exception, that
958   *     exception itself. To avoid hiding bugs and other unrecoverable errors, callers should
959   *     prefer more specific types, avoiding {@code Throwable.class} in particular.
960   * @param fallback the function to be called if this step fails with the expected exception type.
961   *     The function's argument is this step's exception. "This step's exception" means the cause
962   *     of the {@link ExecutionException} thrown by {@link Future#get()} on the {@link Future}
963   *     underlying this step or, if {@code get()} throws a different kind of exception, that
964   *     exception itself.
965   * @param executor the executor that runs {@code fallback} if the input fails
966   */
967  // TODO(dpb): Should this do something special if the function throws CancellationException or
968  // ExecutionException?
969  public <X extends Throwable> ClosingFuture<V> catchingAsync(
970      Class<X> exceptionType,
971      AsyncClosingFunction<? super X, ? extends V> fallback,
972      Executor executor) {
973    return catchingAsyncMoreGeneric(exceptionType, fallback, executor);
974  }
975
976  // Avoids generic type capture inconsistency problems where |? extends V| is incompatible with V.
977  private <X extends Throwable, W extends V> ClosingFuture<V> catchingAsyncMoreGeneric(
978      Class<X> exceptionType,
979      final AsyncClosingFunction<? super X, W> fallback,
980      Executor executor) {
981    checkNotNull(fallback);
982    AsyncFunction<X, W> asyncFunction =
983        new AsyncFunction<X, W>() {
984          @Override
985          public ListenableFuture<W> apply(X exception) throws Exception {
986            return closeables.applyAsyncClosingFunction(fallback, exception);
987          }
988
989          @Override
990          public String toString() {
991            return fallback.toString();
992          }
993        };
994    return derive(future.catchingAsync(exceptionType, asyncFunction, executor));
995  }
996
997  /**
998   * Marks this step as the last step in the {@code ClosingFuture} pipeline.
999   *
1000   * <p>The returned {@link Future} is completed when the pipeline's computation completes, or when
1001   * the pipeline is cancelled.
1002   *
1003   * <p>All objects the pipeline has captured for closing will begin to be closed asynchronously
1004   * <b>after</b> the returned {@code Future} is done: the future completes before closing starts,
1005   * rather than once it has finished.
1006   *
1007   * <p>After calling this method, you may not call {@link
1008   * #finishToValueAndCloser(ValueAndCloserConsumer, Executor)}, this method, or any other
1009   * derivation method on the original {@code ClosingFuture} instance.
1010   *
1011   * @return a {@link Future} that represents the final value or exception of the pipeline
1012   */
1013  public FluentFuture<V> finishToFuture() {
1014    if (compareAndUpdateState(OPEN, WILL_CLOSE)) {
1015      logger.get().log(FINER, "will close {0}", this);
1016      future.addListener(
1017          new Runnable() {
1018            @Override
1019            public void run() {
1020              checkAndUpdateState(WILL_CLOSE, CLOSING);
1021              close();
1022              checkAndUpdateState(CLOSING, CLOSED);
1023            }
1024          },
1025          directExecutor());
1026    } else {
1027      switch (state.get()) {
1028        case SUBSUMED:
1029          throw new IllegalStateException(
1030              "Cannot call finishToFuture() after deriving another step");
1031
1032        case WILL_CREATE_VALUE_AND_CLOSER:
1033          throw new IllegalStateException(
1034              "Cannot call finishToFuture() after calling finishToValueAndCloser()");
1035
1036        case WILL_CLOSE:
1037        case CLOSING:
1038        case CLOSED:
1039          throw new IllegalStateException("Cannot call finishToFuture() twice");
1040
1041        case OPEN:
1042          throw new AssertionError();
1043      }
1044    }
1045    return future;
1046  }
1047
1048  /**
1049   * Marks this step as the last step in the {@code ClosingFuture} pipeline. When this step is done,
1050   * {@code receiver} will be called with an object that contains the result of the operation. The
1051   * receiver can store the {@link ValueAndCloser} outside the receiver for later synchronous use.
1052   *
1053   * <p>After calling this method, you may not call {@link #finishToFuture()}, this method again, or
1054   * any other derivation method on the original {@code ClosingFuture} instance.
1055   *
1056   * @param consumer a callback whose method will be called (using {@code executor}) when this
1057   *     operation is done
1058   */
1059  public void finishToValueAndCloser(
1060      final ValueAndCloserConsumer<? super V> consumer, Executor executor) {
1061    checkNotNull(consumer);
1062    if (!compareAndUpdateState(OPEN, WILL_CREATE_VALUE_AND_CLOSER)) {
1063      switch (state.get()) {
1064        case SUBSUMED:
1065          throw new IllegalStateException(
1066              "Cannot call finishToValueAndCloser() after deriving another step");
1067
1068        case WILL_CLOSE:
1069        case CLOSING:
1070        case CLOSED:
1071          throw new IllegalStateException(
1072              "Cannot call finishToValueAndCloser() after calling finishToFuture()");
1073
1074        case WILL_CREATE_VALUE_AND_CLOSER:
1075          throw new IllegalStateException("Cannot call finishToValueAndCloser() twice");
1076
1077        case OPEN:
1078          break;
1079      }
1080      throw new AssertionError(state);
1081    }
1082    future.addListener(
1083        new Runnable() {
1084          @Override
1085          public void run() {
1086            provideValueAndCloser(consumer, ClosingFuture.this);
1087          }
1088        },
1089        executor);
1090  }
1091
1092  private static <C extends @Nullable Object, V extends C> void provideValueAndCloser(
1093      ValueAndCloserConsumer<C> consumer, ClosingFuture<V> closingFuture) {
1094    consumer.accept(new ValueAndCloser<C>(closingFuture));
1095  }
1096
1097  /**
1098   * Attempts to cancel execution of this step. This attempt will fail if the step has already
1099   * completed, has already been cancelled, or could not be cancelled for some other reason. If
1100   * successful, and this step has not started when {@code cancel} is called, this step should never
1101   * run.
1102   *
1103   * <p>If successful, causes the objects captured by this step (if already started) and its input
1104   * step(s) for later closing to be closed on their respective {@link Executor}s. If any such calls
1105   * specified {@link MoreExecutors#directExecutor()}, those objects will be closed synchronously.
1106   *
1107   * @param mayInterruptIfRunning {@code true} if the thread executing this task should be
1108   *     interrupted; otherwise, in-progress tasks are allowed to complete, but the step will be
1109   *     cancelled regardless
1110   * @return {@code false} if the step could not be cancelled, typically because it has already
1111   *     completed normally; {@code true} otherwise
1112   */
1113  @CanIgnoreReturnValue
1114  @SuppressWarnings("Interruption") // We are propagating an interrupt from a caller.
1115  public boolean cancel(boolean mayInterruptIfRunning) {
1116    logger.get().log(FINER, "cancelling {0}", this);
1117    boolean cancelled = future.cancel(mayInterruptIfRunning);
1118    if (cancelled) {
1119      close();
1120    }
1121    return cancelled;
1122  }
1123
1124  private void close() {
1125    logger.get().log(FINER, "closing {0}", this);
1126    closeables.close();
1127  }
1128
1129  private <U extends @Nullable Object> ClosingFuture<U> derive(FluentFuture<U> future) {
1130    ClosingFuture<U> derived = new ClosingFuture<>(future);
1131    becomeSubsumedInto(derived.closeables);
1132    return derived;
1133  }
1134
1135  private void becomeSubsumedInto(CloseableList otherCloseables) {
1136    checkAndUpdateState(OPEN, SUBSUMED);
1137    otherCloseables.add(closeables, directExecutor());
1138  }
1139
1140  /**
1141   * An object that can return the value of the {@link ClosingFuture}s that are passed to {@link
1142   * #whenAllComplete(Iterable)} or {@link #whenAllSucceed(Iterable)}.
1143   *
1144   * <p>Only for use by a {@link CombiningCallable} or {@link AsyncCombiningCallable} object.
1145   */
1146  public static final class Peeker {
1147    private final ImmutableList<ClosingFuture<?>> futures;
1148    private volatile boolean beingCalled;
1149
1150    private Peeker(ImmutableList<ClosingFuture<?>> futures) {
1151      this.futures = checkNotNull(futures);
1152    }
1153
1154    /**
1155     * Returns the value of {@code closingFuture}.
1156     *
1157     * @throws ExecutionException if {@code closingFuture} is a failed step
1158     * @throws CancellationException if the {@code closingFuture}'s future was cancelled
1159     * @throws IllegalArgumentException if {@code closingFuture} is not one of the futures passed to
1160     *     {@link #whenAllComplete(Iterable)} or {@link #whenAllComplete(Iterable)}
1161     * @throws IllegalStateException if called outside of a call to {@link
1162     *     CombiningCallable#call(DeferredCloser, Peeker)} or {@link
1163     *     AsyncCombiningCallable#call(DeferredCloser, Peeker)}
1164     */
1165    @ParametricNullness
1166    public final <D extends @Nullable Object> D getDone(ClosingFuture<D> closingFuture)
1167        throws ExecutionException {
1168      checkState(beingCalled);
1169      checkArgument(futures.contains(closingFuture));
1170      return Futures.getDone(closingFuture.future);
1171    }
1172
1173    @ParametricNullness
1174    private <V extends @Nullable Object> V call(
1175        CombiningCallable<V> combiner, CloseableList closeables) throws Exception {
1176      beingCalled = true;
1177      CloseableList newCloseables = new CloseableList();
1178      try {
1179        return combiner.call(newCloseables.closer, this);
1180      } finally {
1181        closeables.add(newCloseables, directExecutor());
1182        beingCalled = false;
1183      }
1184    }
1185
1186    private <V extends @Nullable Object> FluentFuture<V> callAsync(
1187        AsyncCombiningCallable<V> combiner, CloseableList closeables) throws Exception {
1188      beingCalled = true;
1189      CloseableList newCloseables = new CloseableList();
1190      try {
1191        ClosingFuture<V> closingFuture = combiner.call(newCloseables.closer, this);
1192        closingFuture.becomeSubsumedInto(closeables);
1193        return closingFuture.future;
1194      } finally {
1195        closeables.add(newCloseables, directExecutor());
1196        beingCalled = false;
1197      }
1198    }
1199  }
1200
1201  /**
1202   * A builder of a {@link ClosingFuture} step that is derived from more than one input step.
1203   *
1204   * <p>See {@link #whenAllComplete(Iterable)} and {@link #whenAllSucceed(Iterable)} for how to
1205   * instantiate this class.
1206   *
1207   * <p>Example:
1208   *
1209   * <pre>{@code
1210   * final ClosingFuture<BufferedReader> file1ReaderFuture = ...;
1211   * final ClosingFuture<BufferedReader> file2ReaderFuture = ...;
1212   * ListenableFuture<Integer> numberOfDifferentLines =
1213   *       ClosingFuture.whenAllSucceed(file1ReaderFuture, file2ReaderFuture)
1214   *           .call(
1215   *               (closer, peeker) -> {
1216   *                 BufferedReader file1Reader = peeker.getDone(file1ReaderFuture);
1217   *                 BufferedReader file2Reader = peeker.getDone(file2ReaderFuture);
1218   *                 return countDifferentLines(file1Reader, file2Reader);
1219   *               },
1220   *               executor)
1221   *           .closing(executor);
1222   * }</pre>
1223   */
1224  @DoNotMock("Use ClosingFuture.whenAllSucceed() or .whenAllComplete() instead.")
1225  public static class Combiner {
1226
1227    private final CloseableList closeables = new CloseableList();
1228
1229    /**
1230     * An operation that returns a result and may throw an exception.
1231     *
1232     * @param <V> the type of the result
1233     */
1234    public interface CombiningCallable<V extends @Nullable Object> {
1235      /**
1236       * Computes a result, or throws an exception if unable to do so.
1237       *
1238       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1239       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1240       * (but not before this method completes), even if this method throws or the pipeline is
1241       * cancelled.
1242       *
1243       * @param peeker used to get the value of any of the input futures
1244       */
1245      @ParametricNullness
1246      V call(DeferredCloser closer, Peeker peeker) throws Exception;
1247    }
1248
1249    /**
1250     * An operation that returns a {@link ClosingFuture} result and may throw an exception.
1251     *
1252     * @param <V> the type of the result
1253     */
1254    public interface AsyncCombiningCallable<V extends @Nullable Object> {
1255      /**
1256       * Computes a {@link ClosingFuture} result, or throws an exception if unable to do so.
1257       *
1258       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1259       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1260       * (but not before this method completes), even if this method throws or the pipeline is
1261       * cancelled.
1262       *
1263       * @param peeker used to get the value of any of the input futures
1264       */
1265      ClosingFuture<V> call(DeferredCloser closer, Peeker peeker) throws Exception;
1266    }
1267
1268    private final boolean allMustSucceed;
1269    protected final ImmutableList<ClosingFuture<?>> inputs;
1270
1271    private Combiner(boolean allMustSucceed, Iterable<? extends ClosingFuture<?>> inputs) {
1272      this.allMustSucceed = allMustSucceed;
1273      this.inputs = ImmutableList.copyOf(inputs);
1274      for (ClosingFuture<?> input : inputs) {
1275        input.becomeSubsumedInto(closeables);
1276      }
1277    }
1278
1279    /**
1280     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1281     * combining function to their values. The function can use a {@link DeferredCloser} to capture
1282     * objects to be closed when the pipeline is done.
1283     *
1284     * <p>If this combiner was returned by a {@link #whenAllSucceed} method and any of the inputs
1285     * fail, so will the returned step.
1286     *
1287     * <p>If the combiningCallable throws a {@code CancellationException}, the pipeline will be
1288     * cancelled.
1289     *
1290     * <p>If the combiningCallable throws an {@code ExecutionException}, the cause of the thrown
1291     * {@code ExecutionException} will be extracted and used as the failure of the derived step.
1292     */
1293    public <V extends @Nullable Object> ClosingFuture<V> call(
1294        final CombiningCallable<V> combiningCallable, Executor executor) {
1295      Callable<V> callable =
1296          new Callable<V>() {
1297            @Override
1298            @ParametricNullness
1299            public V call() throws Exception {
1300              return new Peeker(inputs).call(combiningCallable, closeables);
1301            }
1302
1303            @Override
1304            public String toString() {
1305              return combiningCallable.toString();
1306            }
1307          };
1308      ClosingFuture<V> derived = new ClosingFuture<>(futureCombiner().call(callable, executor));
1309      derived.closeables.add(closeables, directExecutor());
1310      return derived;
1311    }
1312
1313    /**
1314     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1315     * {@code ClosingFuture}-returning function to their values. The function can use a {@link
1316     * DeferredCloser} to capture objects to be closed when the pipeline is done (other than those
1317     * captured by the returned {@link ClosingFuture}).
1318     *
1319     * <p>If this combiner was returned by a {@link #whenAllSucceed} method and any of the inputs
1320     * fail, so will the returned step.
1321     *
1322     * <p>If the combiningCallable throws a {@code CancellationException}, the pipeline will be
1323     * cancelled.
1324     *
1325     * <p>If the combiningCallable throws an {@code ExecutionException}, the cause of the thrown
1326     * {@code ExecutionException} will be extracted and used as the failure of the derived step.
1327     *
1328     * <p>If the combiningCallable throws any other exception, it will be used as the failure of the
1329     * derived step.
1330     *
1331     * <p>If an exception is thrown after the combiningCallable creates a {@code ClosingFuture},
1332     * then none of the closeable objects in that {@code ClosingFuture} will be closed.
1333     *
1334     * <p>Usage guidelines for this method:
1335     *
1336     * <ul>
1337     *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
1338     *       {@code ClosingFuture}. If possible, prefer calling {@link #call(CombiningCallable,
1339     *       Executor)} instead, with a function that returns the next value directly.
1340     *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
1341     *       for every closeable object this step creates in order to capture it for later closing.
1342     *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
1343     *       ClosingFuture} call {@link #from(ListenableFuture)}.
1344     * </ul>
1345     *
1346     * <p>The same warnings about doing heavyweight operations within {@link
1347     * ClosingFuture#transformAsync(AsyncClosingFunction, Executor)} apply here.
1348     */
1349    public <V extends @Nullable Object> ClosingFuture<V> callAsync(
1350        final AsyncCombiningCallable<V> combiningCallable, Executor executor) {
1351      AsyncCallable<V> asyncCallable =
1352          new AsyncCallable<V>() {
1353            @Override
1354            public ListenableFuture<V> call() throws Exception {
1355              return new Peeker(inputs).callAsync(combiningCallable, closeables);
1356            }
1357
1358            @Override
1359            public String toString() {
1360              return combiningCallable.toString();
1361            }
1362          };
1363      ClosingFuture<V> derived =
1364          new ClosingFuture<>(futureCombiner().callAsync(asyncCallable, executor));
1365      derived.closeables.add(closeables, directExecutor());
1366      return derived;
1367    }
1368
1369    private FutureCombiner<@Nullable Object> futureCombiner() {
1370      return allMustSucceed
1371          ? Futures.whenAllSucceed(inputFutures())
1372          : Futures.whenAllComplete(inputFutures());
1373    }
1374
1375
1376    private ImmutableList<FluentFuture<?>> inputFutures() {
1377      return FluentIterable.from(inputs)
1378          .<FluentFuture<?>>transform(future -> future.future)
1379          .toList();
1380    }
1381  }
1382
1383  /**
1384   * A generic {@link Combiner} that lets you use a lambda or method reference to combine two {@link
1385   * ClosingFuture}s. Use {@link #whenAllSucceed(ClosingFuture, ClosingFuture)} to start this
1386   * combination.
1387   *
1388   * @param <V1> the type returned by the first future
1389   * @param <V2> the type returned by the second future
1390   */
1391  public static final class Combiner2<V1 extends @Nullable Object, V2 extends @Nullable Object>
1392      extends Combiner {
1393
1394    /**
1395     * A function that returns a value when applied to the values of the two futures passed to
1396     * {@link #whenAllSucceed(ClosingFuture, ClosingFuture)}.
1397     *
1398     * @param <V1> the type returned by the first future
1399     * @param <V2> the type returned by the second future
1400     * @param <U> the type returned by the function
1401     */
1402    public interface ClosingFunction2<
1403        V1 extends @Nullable Object, V2 extends @Nullable Object, U extends @Nullable Object> {
1404
1405      /**
1406       * Applies this function to two inputs, or throws an exception if unable to do so.
1407       *
1408       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1409       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1410       * (but not before this method completes), even if this method throws or the pipeline is
1411       * cancelled.
1412       */
1413      @ParametricNullness
1414      U apply(DeferredCloser closer, @ParametricNullness V1 value1, @ParametricNullness V2 value2)
1415          throws Exception;
1416    }
1417
1418    /**
1419     * A function that returns a {@link ClosingFuture} when applied to the values of the two futures
1420     * passed to {@link #whenAllSucceed(ClosingFuture, ClosingFuture)}.
1421     *
1422     * @param <V1> the type returned by the first future
1423     * @param <V2> the type returned by the second future
1424     * @param <U> the type returned by the function
1425     */
1426    public interface AsyncClosingFunction2<
1427        V1 extends @Nullable Object, V2 extends @Nullable Object, U extends @Nullable Object> {
1428
1429      /**
1430       * Applies this function to two inputs, or throws an exception if unable to do so.
1431       *
1432       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1433       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1434       * (but not before this method completes), even if this method throws or the pipeline is
1435       * cancelled.
1436       */
1437      ClosingFuture<U> apply(
1438          DeferredCloser closer, @ParametricNullness V1 value1, @ParametricNullness V2 value2)
1439          throws Exception;
1440    }
1441
1442    private final ClosingFuture<V1> future1;
1443    private final ClosingFuture<V2> future2;
1444
1445    private Combiner2(ClosingFuture<V1> future1, ClosingFuture<V2> future2) {
1446      super(true, ImmutableList.of(future1, future2));
1447      this.future1 = future1;
1448      this.future2 = future2;
1449    }
1450
1451    /**
1452     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1453     * combining function to their values. The function can use a {@link DeferredCloser} to capture
1454     * objects to be closed when the pipeline is done.
1455     *
1456     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture)} and
1457     * any of the inputs fail, so will the returned step.
1458     *
1459     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
1460     *
1461     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
1462     * ExecutionException} will be extracted and used as the failure of the derived step.
1463     */
1464    public <U extends @Nullable Object> ClosingFuture<U> call(
1465        final ClosingFunction2<V1, V2, U> function, Executor executor) {
1466      return call(
1467          new CombiningCallable<U>() {
1468            @Override
1469            @ParametricNullness
1470            public U call(DeferredCloser closer, Peeker peeker) throws Exception {
1471              return function.apply(closer, peeker.getDone(future1), peeker.getDone(future2));
1472            }
1473
1474            @Override
1475            public String toString() {
1476              return function.toString();
1477            }
1478          },
1479          executor);
1480    }
1481
1482    /**
1483     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1484     * {@code ClosingFuture}-returning function to their values. The function can use a {@link
1485     * DeferredCloser} to capture objects to be closed when the pipeline is done (other than those
1486     * captured by the returned {@link ClosingFuture}).
1487     *
1488     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture)} and
1489     * any of the inputs fail, so will the returned step.
1490     *
1491     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
1492     *
1493     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
1494     * ExecutionException} will be extracted and used as the failure of the derived step.
1495     *
1496     * <p>If the function throws any other exception, it will be used as the failure of the derived
1497     * step.
1498     *
1499     * <p>If an exception is thrown after the function creates a {@code ClosingFuture}, then none of
1500     * the closeable objects in that {@code ClosingFuture} will be closed.
1501     *
1502     * <p>Usage guidelines for this method:
1503     *
1504     * <ul>
1505     *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
1506     *       {@code ClosingFuture}. If possible, prefer calling {@link #call(CombiningCallable,
1507     *       Executor)} instead, with a function that returns the next value directly.
1508     *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
1509     *       for every closeable object this step creates in order to capture it for later closing.
1510     *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
1511     *       ClosingFuture} call {@link #from(ListenableFuture)}.
1512     * </ul>
1513     *
1514     * <p>The same warnings about doing heavyweight operations within {@link
1515     * ClosingFuture#transformAsync(AsyncClosingFunction, Executor)} apply here.
1516     */
1517    public <U extends @Nullable Object> ClosingFuture<U> callAsync(
1518        final AsyncClosingFunction2<V1, V2, U> function, Executor executor) {
1519      return callAsync(
1520          new AsyncCombiningCallable<U>() {
1521            @Override
1522            public ClosingFuture<U> call(DeferredCloser closer, Peeker peeker) throws Exception {
1523              return function.apply(closer, peeker.getDone(future1), peeker.getDone(future2));
1524            }
1525
1526            @Override
1527            public String toString() {
1528              return function.toString();
1529            }
1530          },
1531          executor);
1532    }
1533  }
1534
1535  /**
1536   * A generic {@link Combiner} that lets you use a lambda or method reference to combine three
1537   * {@link ClosingFuture}s. Use {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
1538   * ClosingFuture)} to start this combination.
1539   *
1540   * @param <V1> the type returned by the first future
1541   * @param <V2> the type returned by the second future
1542   * @param <V3> the type returned by the third future
1543   */
1544  public static final class Combiner3<
1545          V1 extends @Nullable Object, V2 extends @Nullable Object, V3 extends @Nullable Object>
1546      extends Combiner {
1547    /**
1548     * A function that returns a value when applied to the values of the three futures passed to
1549     * {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture)}.
1550     *
1551     * @param <V1> the type returned by the first future
1552     * @param <V2> the type returned by the second future
1553     * @param <V3> the type returned by the third future
1554     * @param <U> the type returned by the function
1555     */
1556    public interface ClosingFunction3<
1557        V1 extends @Nullable Object,
1558        V2 extends @Nullable Object,
1559        V3 extends @Nullable Object,
1560        U extends @Nullable Object> {
1561      /**
1562       * Applies this function to three inputs, or throws an exception if unable to do so.
1563       *
1564       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1565       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1566       * (but not before this method completes), even if this method throws or the pipeline is
1567       * cancelled.
1568       */
1569      @ParametricNullness
1570      U apply(
1571          DeferredCloser closer,
1572          @ParametricNullness V1 value1,
1573          @ParametricNullness V2 value2,
1574          @ParametricNullness V3 value3)
1575          throws Exception;
1576    }
1577
1578    /**
1579     * A function that returns a {@link ClosingFuture} when applied to the values of the three
1580     * futures passed to {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture)}.
1581     *
1582     * @param <V1> the type returned by the first future
1583     * @param <V2> the type returned by the second future
1584     * @param <V3> the type returned by the third future
1585     * @param <U> the type returned by the function
1586     */
1587    public interface AsyncClosingFunction3<
1588        V1 extends @Nullable Object,
1589        V2 extends @Nullable Object,
1590        V3 extends @Nullable Object,
1591        U extends @Nullable Object> {
1592      /**
1593       * Applies this function to three inputs, or throws an exception if unable to do so.
1594       *
1595       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1596       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1597       * (but not before this method completes), even if this method throws or the pipeline is
1598       * cancelled.
1599       */
1600      ClosingFuture<U> apply(
1601          DeferredCloser closer,
1602          @ParametricNullness V1 value1,
1603          @ParametricNullness V2 value2,
1604          @ParametricNullness V3 value3)
1605          throws Exception;
1606    }
1607
1608    private final ClosingFuture<V1> future1;
1609    private final ClosingFuture<V2> future2;
1610    private final ClosingFuture<V3> future3;
1611
1612    private Combiner3(
1613        ClosingFuture<V1> future1, ClosingFuture<V2> future2, ClosingFuture<V3> future3) {
1614      super(true, ImmutableList.of(future1, future2, future3));
1615      this.future1 = future1;
1616      this.future2 = future2;
1617      this.future3 = future3;
1618    }
1619
1620    /**
1621     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1622     * combining function to their values. The function can use a {@link DeferredCloser} to capture
1623     * objects to be closed when the pipeline is done.
1624     *
1625     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
1626     * ClosingFuture)} and any of the inputs fail, so will the returned step.
1627     *
1628     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
1629     *
1630     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
1631     * ExecutionException} will be extracted and used as the failure of the derived step.
1632     */
1633    public <U extends @Nullable Object> ClosingFuture<U> call(
1634        final ClosingFunction3<V1, V2, V3, U> function, Executor executor) {
1635      return call(
1636          new CombiningCallable<U>() {
1637            @Override
1638            @ParametricNullness
1639            public U call(DeferredCloser closer, Peeker peeker) throws Exception {
1640              return function.apply(
1641                  closer,
1642                  peeker.getDone(future1),
1643                  peeker.getDone(future2),
1644                  peeker.getDone(future3));
1645            }
1646
1647            @Override
1648            public String toString() {
1649              return function.toString();
1650            }
1651          },
1652          executor);
1653    }
1654
1655    /**
1656     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1657     * {@code ClosingFuture}-returning function to their values. The function can use a {@link
1658     * DeferredCloser} to capture objects to be closed when the pipeline is done (other than those
1659     * captured by the returned {@link ClosingFuture}).
1660     *
1661     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
1662     * ClosingFuture)} and any of the inputs fail, so will the returned step.
1663     *
1664     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
1665     *
1666     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
1667     * ExecutionException} will be extracted and used as the failure of the derived step.
1668     *
1669     * <p>If the function throws any other exception, it will be used as the failure of the derived
1670     * step.
1671     *
1672     * <p>If an exception is thrown after the function creates a {@code ClosingFuture}, then none of
1673     * the closeable objects in that {@code ClosingFuture} will be closed.
1674     *
1675     * <p>Usage guidelines for this method:
1676     *
1677     * <ul>
1678     *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
1679     *       {@code ClosingFuture}. If possible, prefer calling {@link #call(CombiningCallable,
1680     *       Executor)} instead, with a function that returns the next value directly.
1681     *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
1682     *       for every closeable object this step creates in order to capture it for later closing.
1683     *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
1684     *       ClosingFuture} call {@link #from(ListenableFuture)}.
1685     * </ul>
1686     *
1687     * <p>The same warnings about doing heavyweight operations within {@link
1688     * ClosingFuture#transformAsync(AsyncClosingFunction, Executor)} apply here.
1689     */
1690    public <U extends @Nullable Object> ClosingFuture<U> callAsync(
1691        final AsyncClosingFunction3<V1, V2, V3, U> function, Executor executor) {
1692      return callAsync(
1693          new AsyncCombiningCallable<U>() {
1694            @Override
1695            public ClosingFuture<U> call(DeferredCloser closer, Peeker peeker) throws Exception {
1696              return function.apply(
1697                  closer,
1698                  peeker.getDone(future1),
1699                  peeker.getDone(future2),
1700                  peeker.getDone(future3));
1701            }
1702
1703            @Override
1704            public String toString() {
1705              return function.toString();
1706            }
1707          },
1708          executor);
1709    }
1710  }
1711
1712  /**
1713   * A generic {@link Combiner} that lets you use a lambda or method reference to combine four
1714   * {@link ClosingFuture}s. Use {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture,
1715   * ClosingFuture)} to start this combination.
1716   *
1717   * @param <V1> the type returned by the first future
1718   * @param <V2> the type returned by the second future
1719   * @param <V3> the type returned by the third future
1720   * @param <V4> the type returned by the fourth future
1721   */
1722  public static final class Combiner4<
1723          V1 extends @Nullable Object,
1724          V2 extends @Nullable Object,
1725          V3 extends @Nullable Object,
1726          V4 extends @Nullable Object>
1727      extends Combiner {
1728    /**
1729     * A function that returns a value when applied to the values of the four futures passed to
1730     * {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture, ClosingFuture)}.
1731     *
1732     * @param <V1> the type returned by the first future
1733     * @param <V2> the type returned by the second future
1734     * @param <V3> the type returned by the third future
1735     * @param <V4> the type returned by the fourth future
1736     * @param <U> the type returned by the function
1737     */
1738    public interface ClosingFunction4<
1739        V1 extends @Nullable Object,
1740        V2 extends @Nullable Object,
1741        V3 extends @Nullable Object,
1742        V4 extends @Nullable Object,
1743        U extends @Nullable Object> {
1744      /**
1745       * Applies this function to four inputs, or throws an exception if unable to do so.
1746       *
1747       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1748       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1749       * (but not before this method completes), even if this method throws or the pipeline is
1750       * cancelled.
1751       */
1752      @ParametricNullness
1753      U apply(
1754          DeferredCloser closer,
1755          @ParametricNullness V1 value1,
1756          @ParametricNullness V2 value2,
1757          @ParametricNullness V3 value3,
1758          @ParametricNullness V4 value4)
1759          throws Exception;
1760    }
1761
1762    /**
1763     * A function that returns a {@link ClosingFuture} when applied to the values of the four
1764     * futures passed to {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture,
1765     * ClosingFuture)}.
1766     *
1767     * @param <V1> the type returned by the first future
1768     * @param <V2> the type returned by the second future
1769     * @param <V3> the type returned by the third future
1770     * @param <V4> the type returned by the fourth future
1771     * @param <U> the type returned by the function
1772     */
1773    public interface AsyncClosingFunction4<
1774        V1 extends @Nullable Object,
1775        V2 extends @Nullable Object,
1776        V3 extends @Nullable Object,
1777        V4 extends @Nullable Object,
1778        U extends @Nullable Object> {
1779      /**
1780       * Applies this function to four inputs, or throws an exception if unable to do so.
1781       *
1782       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1783       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1784       * (but not before this method completes), even if this method throws or the pipeline is
1785       * cancelled.
1786       */
1787      ClosingFuture<U> apply(
1788          DeferredCloser closer,
1789          @ParametricNullness V1 value1,
1790          @ParametricNullness V2 value2,
1791          @ParametricNullness V3 value3,
1792          @ParametricNullness V4 value4)
1793          throws Exception;
1794    }
1795
1796    private final ClosingFuture<V1> future1;
1797    private final ClosingFuture<V2> future2;
1798    private final ClosingFuture<V3> future3;
1799    private final ClosingFuture<V4> future4;
1800
1801    private Combiner4(
1802        ClosingFuture<V1> future1,
1803        ClosingFuture<V2> future2,
1804        ClosingFuture<V3> future3,
1805        ClosingFuture<V4> future4) {
1806      super(true, ImmutableList.of(future1, future2, future3, future4));
1807      this.future1 = future1;
1808      this.future2 = future2;
1809      this.future3 = future3;
1810      this.future4 = future4;
1811    }
1812
1813    /**
1814     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1815     * combining function to their values. The function can use a {@link DeferredCloser} to capture
1816     * objects to be closed when the pipeline is done.
1817     *
1818     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
1819     * ClosingFuture, ClosingFuture)} and any of the inputs fail, so will the returned step.
1820     *
1821     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
1822     *
1823     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
1824     * ExecutionException} will be extracted and used as the failure of the derived step.
1825     */
1826    public <U extends @Nullable Object> ClosingFuture<U> call(
1827        final ClosingFunction4<V1, V2, V3, V4, U> function, Executor executor) {
1828      return call(
1829          new CombiningCallable<U>() {
1830            @Override
1831            @ParametricNullness
1832            public U call(DeferredCloser closer, Peeker peeker) throws Exception {
1833              return function.apply(
1834                  closer,
1835                  peeker.getDone(future1),
1836                  peeker.getDone(future2),
1837                  peeker.getDone(future3),
1838                  peeker.getDone(future4));
1839            }
1840
1841            @Override
1842            public String toString() {
1843              return function.toString();
1844            }
1845          },
1846          executor);
1847    }
1848
1849    /**
1850     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
1851     * {@code ClosingFuture}-returning function to their values. The function can use a {@link
1852     * DeferredCloser} to capture objects to be closed when the pipeline is done (other than those
1853     * captured by the returned {@link ClosingFuture}).
1854     *
1855     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
1856     * ClosingFuture, ClosingFuture)} and any of the inputs fail, so will the returned step.
1857     *
1858     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
1859     *
1860     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
1861     * ExecutionException} will be extracted and used as the failure of the derived step.
1862     *
1863     * <p>If the function throws any other exception, it will be used as the failure of the derived
1864     * step.
1865     *
1866     * <p>If an exception is thrown after the function creates a {@code ClosingFuture}, then none of
1867     * the closeable objects in that {@code ClosingFuture} will be closed.
1868     *
1869     * <p>Usage guidelines for this method:
1870     *
1871     * <ul>
1872     *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
1873     *       {@code ClosingFuture}. If possible, prefer calling {@link #call(CombiningCallable,
1874     *       Executor)} instead, with a function that returns the next value directly.
1875     *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
1876     *       for every closeable object this step creates in order to capture it for later closing.
1877     *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
1878     *       ClosingFuture} call {@link #from(ListenableFuture)}.
1879     * </ul>
1880     *
1881     * <p>The same warnings about doing heavyweight operations within {@link
1882     * ClosingFuture#transformAsync(AsyncClosingFunction, Executor)} apply here.
1883     */
1884    public <U extends @Nullable Object> ClosingFuture<U> callAsync(
1885        final AsyncClosingFunction4<V1, V2, V3, V4, U> function, Executor executor) {
1886      return callAsync(
1887          new AsyncCombiningCallable<U>() {
1888            @Override
1889            public ClosingFuture<U> call(DeferredCloser closer, Peeker peeker) throws Exception {
1890              return function.apply(
1891                  closer,
1892                  peeker.getDone(future1),
1893                  peeker.getDone(future2),
1894                  peeker.getDone(future3),
1895                  peeker.getDone(future4));
1896            }
1897
1898            @Override
1899            public String toString() {
1900              return function.toString();
1901            }
1902          },
1903          executor);
1904    }
1905  }
1906
1907  /**
1908   * A generic {@link Combiner} that lets you use a lambda or method reference to combine five
1909   * {@link ClosingFuture}s. Use {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture,
1910   * ClosingFuture, ClosingFuture)} to start this combination.
1911   *
1912   * @param <V1> the type returned by the first future
1913   * @param <V2> the type returned by the second future
1914   * @param <V3> the type returned by the third future
1915   * @param <V4> the type returned by the fourth future
1916   * @param <V5> the type returned by the fifth future
1917   */
1918  public static final class Combiner5<
1919          V1 extends @Nullable Object,
1920          V2 extends @Nullable Object,
1921          V3 extends @Nullable Object,
1922          V4 extends @Nullable Object,
1923          V5 extends @Nullable Object>
1924      extends Combiner {
1925    /**
1926     * A function that returns a value when applied to the values of the five futures passed to
1927     * {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture, ClosingFuture,
1928     * ClosingFuture)}.
1929     *
1930     * @param <V1> the type returned by the first future
1931     * @param <V2> the type returned by the second future
1932     * @param <V3> the type returned by the third future
1933     * @param <V4> the type returned by the fourth future
1934     * @param <V5> the type returned by the fifth future
1935     * @param <U> the type returned by the function
1936     */
1937    public interface ClosingFunction5<
1938        V1 extends @Nullable Object,
1939        V2 extends @Nullable Object,
1940        V3 extends @Nullable Object,
1941        V4 extends @Nullable Object,
1942        V5 extends @Nullable Object,
1943        U extends @Nullable Object> {
1944      /**
1945       * Applies this function to five inputs, or throws an exception if unable to do so.
1946       *
1947       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1948       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1949       * (but not before this method completes), even if this method throws or the pipeline is
1950       * cancelled.
1951       */
1952      @ParametricNullness
1953      U apply(
1954          DeferredCloser closer,
1955          @ParametricNullness V1 value1,
1956          @ParametricNullness V2 value2,
1957          @ParametricNullness V3 value3,
1958          @ParametricNullness V4 value4,
1959          @ParametricNullness V5 value5)
1960          throws Exception;
1961    }
1962
1963    /**
1964     * A function that returns a {@link ClosingFuture} when applied to the values of the five
1965     * futures passed to {@link #whenAllSucceed(ClosingFuture, ClosingFuture, ClosingFuture,
1966     * ClosingFuture, ClosingFuture)}.
1967     *
1968     * @param <V1> the type returned by the first future
1969     * @param <V2> the type returned by the second future
1970     * @param <V3> the type returned by the third future
1971     * @param <V4> the type returned by the fourth future
1972     * @param <V5> the type returned by the fifth future
1973     * @param <U> the type returned by the function
1974     */
1975    public interface AsyncClosingFunction5<
1976        V1 extends @Nullable Object,
1977        V2 extends @Nullable Object,
1978        V3 extends @Nullable Object,
1979        V4 extends @Nullable Object,
1980        V5 extends @Nullable Object,
1981        U extends @Nullable Object> {
1982      /**
1983       * Applies this function to five inputs, or throws an exception if unable to do so.
1984       *
1985       * <p>Any objects that are passed to {@link DeferredCloser#eventuallyClose(Object, Executor)
1986       * closer.eventuallyClose()} will be closed when the {@link ClosingFuture} pipeline is done
1987       * (but not before this method completes), even if this method throws or the pipeline is
1988       * cancelled.
1989       */
1990      ClosingFuture<U> apply(
1991          DeferredCloser closer,
1992          @ParametricNullness V1 value1,
1993          @ParametricNullness V2 value2,
1994          @ParametricNullness V3 value3,
1995          @ParametricNullness V4 value4,
1996          @ParametricNullness V5 value5)
1997          throws Exception;
1998    }
1999
2000    private final ClosingFuture<V1> future1;
2001    private final ClosingFuture<V2> future2;
2002    private final ClosingFuture<V3> future3;
2003    private final ClosingFuture<V4> future4;
2004    private final ClosingFuture<V5> future5;
2005
2006    private Combiner5(
2007        ClosingFuture<V1> future1,
2008        ClosingFuture<V2> future2,
2009        ClosingFuture<V3> future3,
2010        ClosingFuture<V4> future4,
2011        ClosingFuture<V5> future5) {
2012      super(true, ImmutableList.of(future1, future2, future3, future4, future5));
2013      this.future1 = future1;
2014      this.future2 = future2;
2015      this.future3 = future3;
2016      this.future4 = future4;
2017      this.future5 = future5;
2018    }
2019
2020    /**
2021     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
2022     * combining function to their values. The function can use a {@link DeferredCloser} to capture
2023     * objects to be closed when the pipeline is done.
2024     *
2025     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
2026     * ClosingFuture, ClosingFuture, ClosingFuture)} and any of the inputs fail, so will the
2027     * returned step.
2028     *
2029     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
2030     *
2031     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
2032     * ExecutionException} will be extracted and used as the failure of the derived step.
2033     */
2034    public <U extends @Nullable Object> ClosingFuture<U> call(
2035        final ClosingFunction5<V1, V2, V3, V4, V5, U> function, Executor executor) {
2036      return call(
2037          new CombiningCallable<U>() {
2038            @Override
2039            @ParametricNullness
2040            public U call(DeferredCloser closer, Peeker peeker) throws Exception {
2041              return function.apply(
2042                  closer,
2043                  peeker.getDone(future1),
2044                  peeker.getDone(future2),
2045                  peeker.getDone(future3),
2046                  peeker.getDone(future4),
2047                  peeker.getDone(future5));
2048            }
2049
2050            @Override
2051            public String toString() {
2052              return function.toString();
2053            }
2054          },
2055          executor);
2056    }
2057
2058    /**
2059     * Returns a new {@code ClosingFuture} pipeline step derived from the inputs by applying a
2060     * {@code ClosingFuture}-returning function to their values. The function can use a {@link
2061     * DeferredCloser} to capture objects to be closed when the pipeline is done (other than those
2062     * captured by the returned {@link ClosingFuture}).
2063     *
2064     * <p>If this combiner was returned by {@link #whenAllSucceed(ClosingFuture, ClosingFuture,
2065     * ClosingFuture, ClosingFuture, ClosingFuture)} and any of the inputs fail, so will the
2066     * returned step.
2067     *
2068     * <p>If the function throws a {@code CancellationException}, the pipeline will be cancelled.
2069     *
2070     * <p>If the function throws an {@code ExecutionException}, the cause of the thrown {@code
2071     * ExecutionException} will be extracted and used as the failure of the derived step.
2072     *
2073     * <p>If the function throws any other exception, it will be used as the failure of the derived
2074     * step.
2075     *
2076     * <p>If an exception is thrown after the function creates a {@code ClosingFuture}, then none of
2077     * the closeable objects in that {@code ClosingFuture} will be closed.
2078     *
2079     * <p>Usage guidelines for this method:
2080     *
2081     * <ul>
2082     *   <li>Use this method only when calling an API that returns a {@link ListenableFuture} or a
2083     *       {@code ClosingFuture}. If possible, prefer calling {@link #call(CombiningCallable,
2084     *       Executor)} instead, with a function that returns the next value directly.
2085     *   <li>Call {@link DeferredCloser#eventuallyClose(Object, Executor) closer.eventuallyClose()}
2086     *       for every closeable object this step creates in order to capture it for later closing.
2087     *   <li>Return a {@code ClosingFuture}. To turn a {@link ListenableFuture} into a {@code
2088     *       ClosingFuture} call {@link #from(ListenableFuture)}.
2089     * </ul>
2090     *
2091     * <p>The same warnings about doing heavyweight operations within {@link
2092     * ClosingFuture#transformAsync(AsyncClosingFunction, Executor)} apply here.
2093     */
2094    public <U extends @Nullable Object> ClosingFuture<U> callAsync(
2095        final AsyncClosingFunction5<V1, V2, V3, V4, V5, U> function, Executor executor) {
2096      return callAsync(
2097          new AsyncCombiningCallable<U>() {
2098            @Override
2099            public ClosingFuture<U> call(DeferredCloser closer, Peeker peeker) throws Exception {
2100              return function.apply(
2101                  closer,
2102                  peeker.getDone(future1),
2103                  peeker.getDone(future2),
2104                  peeker.getDone(future3),
2105                  peeker.getDone(future4),
2106                  peeker.getDone(future5));
2107            }
2108
2109            @Override
2110            public String toString() {
2111              return function.toString();
2112            }
2113          },
2114          executor);
2115    }
2116  }
2117
2118  @Override
2119  public String toString() {
2120    // TODO(dpb): Better toString, in the style of Futures.transform etc.
2121    return toStringHelper(this).add("state", state.get()).addValue(future).toString();
2122  }
2123
2124  @SuppressWarnings({"removal", "Finalize"}) // b/260137033
2125  @Override
2126  protected void finalize() {
2127    if (state.get().equals(OPEN)) {
2128      logger.get().log(SEVERE, "Uh oh! An open ClosingFuture has leaked and will close: {0}", this);
2129      FluentFuture<V> unused = finishToFuture();
2130    }
2131  }
2132
2133  private static void closeQuietly(final @Nullable AutoCloseable closeable, Executor executor) {
2134    if (closeable == null) {
2135      return;
2136    }
2137    try {
2138      executor.execute(
2139          () -> {
2140            try {
2141              closeable.close();
2142            } catch (Exception e) {
2143              /*
2144               * In guava-jre, any kind of Exception may be thrown because `closeable` has type
2145               * `AutoCloseable`.
2146               *
2147               * In guava-android, the only kinds of Exception that may be thrown are
2148               * RuntimeException and IOException because `closeable` has type `Closeable`—except
2149               * that we have to account for sneaky checked exception.
2150               */
2151              restoreInterruptIfIsInterruptedException(e);
2152              logger.get().log(WARNING, "thrown by close()", e);
2153            }
2154          });
2155    } catch (RejectedExecutionException e) {
2156      if (logger.get().isLoggable(WARNING)) {
2157        logger
2158            .get()
2159            .log(
2160                WARNING,
2161                String.format("while submitting close to %s; will close inline", executor),
2162                e);
2163      }
2164      closeQuietly(closeable, directExecutor());
2165    }
2166  }
2167
2168  private void checkAndUpdateState(State oldState, State newState) {
2169    checkState(
2170        compareAndUpdateState(oldState, newState),
2171        "Expected state to be %s, but it was %s",
2172        oldState,
2173        newState);
2174  }
2175
2176  private boolean compareAndUpdateState(State oldState, State newState) {
2177    return state.compareAndSet(oldState, newState);
2178  }
2179
2180  // TODO(dpb): Should we use a pair of ArrayLists instead of an IdentityHashMap?
2181  private static final class CloseableList extends IdentityHashMap<AutoCloseable, Executor>
2182      implements Closeable {
2183    private final DeferredCloser closer = new DeferredCloser(this);
2184    private volatile boolean closed;
2185    private volatile @Nullable CountDownLatch whenClosed;
2186
2187    <V extends @Nullable Object, U extends @Nullable Object>
2188        ListenableFuture<U> applyClosingFunction(
2189            ClosingFunction<? super V, U> transformation, @ParametricNullness V input)
2190            throws Exception {
2191      // TODO(dpb): Consider ways to defer closing without creating a separate CloseableList.
2192      CloseableList newCloseables = new CloseableList();
2193      try {
2194        return immediateFuture(transformation.apply(newCloseables.closer, input));
2195      } finally {
2196        add(newCloseables, directExecutor());
2197      }
2198    }
2199
2200    <V extends @Nullable Object, U extends @Nullable Object>
2201        FluentFuture<U> applyAsyncClosingFunction(
2202            AsyncClosingFunction<V, U> transformation, @ParametricNullness V input)
2203            throws Exception {
2204      // TODO(dpb): Consider ways to defer closing without creating a separate CloseableList.
2205      CloseableList newCloseables = new CloseableList();
2206      try {
2207        ClosingFuture<U> closingFuture = transformation.apply(newCloseables.closer, input);
2208        closingFuture.becomeSubsumedInto(newCloseables);
2209        return closingFuture.future;
2210      } finally {
2211        add(newCloseables, directExecutor());
2212      }
2213    }
2214
2215    @Override
2216    public void close() {
2217      if (closed) {
2218        return;
2219      }
2220      synchronized (this) {
2221        if (closed) {
2222          return;
2223        }
2224        closed = true;
2225      }
2226      for (Map.Entry<AutoCloseable, Executor> entry : entrySet()) {
2227        closeQuietly(entry.getKey(), entry.getValue());
2228      }
2229      clear();
2230      if (whenClosed != null) {
2231        whenClosed.countDown();
2232      }
2233    }
2234
2235    void add(@Nullable AutoCloseable closeable, Executor executor) {
2236      checkNotNull(executor);
2237      if (closeable == null) {
2238        return;
2239      }
2240      synchronized (this) {
2241        if (!closed) {
2242          put(closeable, executor);
2243          return;
2244        }
2245      }
2246      closeQuietly(closeable, executor);
2247    }
2248
2249    /**
2250     * Returns a latch that reaches zero when this objects' deferred closeables have been closed.
2251     */
2252    CountDownLatch whenClosedCountDown() {
2253      if (closed) {
2254        return new CountDownLatch(0);
2255      }
2256      synchronized (this) {
2257        if (closed) {
2258          return new CountDownLatch(0);
2259        }
2260        checkState(whenClosed == null);
2261        return whenClosed = new CountDownLatch(1);
2262      }
2263    }
2264  }
2265
2266  /**
2267   * Returns an object that can be used to wait until this objects' deferred closeables have all had
2268   * {@link Runnable}s that close them submitted to each one's closing {@link Executor}.
2269   */
2270  @VisibleForTesting
2271  CountDownLatch whenClosedCountDown() {
2272    return closeables.whenClosedCountDown();
2273  }
2274
2275  /** The state of a {@link CloseableList}. */
2276  enum State {
2277    /** The {@link CloseableList} has not been subsumed or closed. */
2278    OPEN,
2279
2280    /**
2281     * The {@link CloseableList} has been subsumed into another. It may not be closed or subsumed
2282     * into any other.
2283     */
2284    SUBSUMED,
2285
2286    /**
2287     * Some {@link ListenableFuture} has a callback attached that will close the {@link
2288     * CloseableList}, but it has not yet run. The {@link CloseableList} may not be subsumed.
2289     */
2290    WILL_CLOSE,
2291
2292    /**
2293     * The callback that closes the {@link CloseableList} is running, but it has not completed. The
2294     * {@link CloseableList} may not be subsumed.
2295     */
2296    CLOSING,
2297
2298    /** The {@link CloseableList} has been closed. It may not be further subsumed. */
2299    CLOSED,
2300
2301    /**
2302     * {@link ClosingFuture#finishToValueAndCloser(ValueAndCloserConsumer, Executor)} has been
2303     * called. The step may not be further subsumed, nor may {@link #finishToFuture()} be called.
2304     */
2305    WILL_CREATE_VALUE_AND_CLOSER,
2306  }
2307}