All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.deepsymmetry.beatlink.data.SlotReference Maven / Gradle / Ivy

package org.deepsymmetry.beatlink.data;

import org.deepsymmetry.beatlink.CdjStatus;

import java.util.HashMap;
import java.util.Map;

/**
 * Uniquely identifies a media slot on the network from which tracks can be loaded, by the player and slot type.
 * A simple immutable value class, with the property that all instances are interned, such that any instances with
 * the same value will actually be the same object, for fast comparison.
 *
 * @author James Elliott
 */
public class SlotReference {

    /**
     * The player in which this slot is found.
     */
    public final int player;

    /**
     * The specific type of the slot.
     */
    public final CdjStatus.TrackSourceSlot slot;

    /**
     * Create a unique reference to a media slot on the network from which tracks can be loaded.
     *
     * @param player the player in which the slot is found
     * @param slot the specific type of the slot
     *
     * @throws NullPointerException if {@code slot} is {@code null}
     */
    private SlotReference(int player, CdjStatus.TrackSourceSlot slot) {
        this.player = player;
        this.slot = slot;
    }

    /**
     * Holds all the instances of this class as they get created by the static factory methods.
     */
    private static final Map> instances =
            new HashMap>();

    /**
     * Get a unique reference to a media slot on the network from which tracks can be loaded.
     *
     * @param player the player in which the slot is found
     * @param slot the specific type of the slot
     *
     * @return the instance that will always represent the specified slot
     *
     * @throws NullPointerException if {@code slot} is {@code null}
     */
    @SuppressWarnings("WeakerAccess")
    public static synchronized SlotReference getSlotReference(int player, CdjStatus.TrackSourceSlot slot) {
        Map playerMap = instances.get(player);
        if (playerMap == null) {
            playerMap = new HashMap();
            instances.put(player, playerMap);
        }
        SlotReference result = playerMap.get(slot);
        if (result == null) {
            result = new SlotReference(player, slot);
            playerMap.put(slot, result);
        }
        return result;
    }

    /**
     * Get a unique reference to the media slot on the network from which the specified data was loaded.
     *
     * @param dataReference the data whose media slot is of interest
     *
     * @return the instance that will always represent the slot associated with the specified data
     */
    @SuppressWarnings("WeakerAccess")
    public static SlotReference getSlotReference(DataReference dataReference) {
        return getSlotReference(dataReference.player, dataReference.slot);
    }

    @Override
    public String toString() {
        return "SlotReference[player:" + player + ", slot:" + slot + "]";
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy