chromium/base/android/java/src/org/chromium/base/UnownedUserData.java

// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

package org.chromium.base;

/**
 * Marker interface to be implemented by classes which makes them attachable to a host class that
 * holds {@link UnownedUserDataHost} entries.
 * <p>
 * Marking something as a UnownedUserData has no other implications than that the class can be
 * referenced from a {@link UnownedUserDataHost} as a {@link java.lang.ref.WeakReference}.
 * <p>
 * Implementors can also optionally implement the method
 * {@link #onDetachedFromHost(UnownedUserDataHost)}
 * to be informed whenever they have been detached from the host. This can happen when the
 * particular {@link UnownedUserDataHost} they are attached to is destroyed.
 *
 * @see UnownedUserDataHost for more details on ownership and typical usage.
 * @see UnownedUserDataKey for information about the type of key that is required.
 */
public interface UnownedUserData {
    /**
     * Invoked whenever the particular UnownedUserData has been removed from a particular host. If
     * the UnownedUserData has been garbage collected before the UserDataHost is informed of its
     * removal, this method will of course not be invoked.
     * <p>
     * This method is invoked asynchronously, but from the correct thread.
     *
     * @param host from which host the UnownedUserData was detached.
     */
    default void onDetachedFromHost(UnownedUserDataHost host) {}

    /**
     * WARNING: This may be invoked in a re-entrant way, but will be invoked on the correct thread.
     *
     * @return true if the UnownedUserData wants to be informed asynchronously about detachments.
     */
    default boolean informOnDetachmentFromHost() {
        return true;
    }
}