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

me.lucko.luckperms.api.context.ImmutableContextSet Maven / Gradle / Ivy

Go to download

An advanced permissions plugin for Bukkit/Spigot, BungeeCord, Sponge, Nukkit and Velocity.

There is a newer version: 4.4
Show newest version
/*
 * This file is part of LuckPerms, licensed under the MIT License.
 *
 *  Copyright (c) lucko (Luck) 
 *  Copyright (c) contributors
 *
 *  Permission is hereby granted, free of charge, to any person obtaining a copy
 *  of this software and associated documentation files (the "Software"), to deal
 *  in the Software without restriction, including without limitation the rights
 *  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 *  copies of the Software, and to permit persons to whom the Software is
 *  furnished to do so, subject to the following conditions:
 *
 *  The above copyright notice and this permission notice shall be included in all
 *  copies or substantial portions of the Software.
 *
 *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 *  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 *  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 *  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 *  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 *  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 *  SOFTWARE.
 */

package me.lucko.luckperms.api.context;

import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSetMultimap;
import com.google.common.collect.Multimap;
import com.google.common.collect.SetMultimap;

import java.util.Iterator;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
import java.util.Spliterator;

import javax.annotation.Nonnull;
import javax.annotation.concurrent.Immutable;

/**
 * An immutable implementation of {@link ContextSet}.
 *
 * @since 2.16
 */
@Immutable
public final class ImmutableContextSet extends AbstractContextSet implements ContextSet {
    private static final ImmutableContextSet EMPTY = new ImmutableContextSet(ImmutableSetMultimap.of());

    /**
     * Creates an {@link ImmutableContextSet.Builder}.
     *
     * @return a new ImmutableContextSet builder
     * @since 4.1
     */
    @Nonnull
    public static Builder builder() {
        return new Builder();
    }

    /**
     * Creates an {@link ImmutableContextSet} from a context pair.
     *
     * @param key   the key
     * @param value the value
     * @return a new ImmutableContextSet containing one context pair
     * @throws NullPointerException if key or value is null
     */
    @Nonnull
    public static ImmutableContextSet singleton(@Nonnull String key, @Nonnull String value) {
        return new ImmutableContextSet(ImmutableSetMultimap.of(sanitizeKey(key), sanitizeValue(value)));
    }

    /**
     * Creates an {@link ImmutableContextSet} from two context pairs.
     *
     * @param key1 the first key
     * @param value1 the first value
     * @param key2 the second key
     * @param value2 the second value
     * @return a new ImmutableContextSet containing the two pairs
     * @throws NullPointerException if any of the keys or values are null
     * @since 3.1
     */
    @Nonnull
    public static ImmutableContextSet of(@Nonnull String key1, @Nonnull String value1, @Nonnull String key2, @Nonnull String value2) {
        return new ImmutableContextSet(ImmutableSetMultimap.of(
                sanitizeKey(key1),
                sanitizeValue(value1),
                sanitizeKey(key2),
                sanitizeValue(value2)
        ));
    }

    /**
     * Creates an {@link ImmutableContextSet} from an existing {@link Iterable} of {@link Map.Entry}s.
     *
     * @param iterable the iterable to copy from
     * @return a new ImmutableContextSet representing the pairs in the iterable
     * @throws NullPointerException if the iterable is null
     */
    @Nonnull
    public static ImmutableContextSet fromEntries(@Nonnull Iterable> iterable) {
        Objects.requireNonNull(iterable, "iterable");
        ImmutableContextSet.Builder builder = builder();
        for (Map.Entry entry : iterable) {
            builder.add(entry);
        }
        return builder.build();
    }

    /**
     * Creates an {@link ImmutableContextSet} from an existing {@link Map}.
     *
     * @param map the map to copy from
     * @return a new ImmutableContextSet representing the pairs from the map
     * @throws NullPointerException if the map is null
     */
    @Nonnull
    public static ImmutableContextSet fromMap(@Nonnull Map map) {
        return fromEntries(Objects.requireNonNull(map, "map").entrySet());
    }

    /**
     * Creates an {@link ImmutableContextSet} from an existing {@link Multimap}.
     *
     * @param multimap the multimap to copy from
     * @return a new ImmutableContextSet representing the pairs in the multimap
     * @throws NullPointerException if the multimap is null
     * @since 2.16
     */
    @Nonnull
    public static ImmutableContextSet fromMultimap(@Nonnull Multimap multimap) {
        return fromEntries(Objects.requireNonNull(multimap, "multimap").entries());
    }

    /**
     * Creates an new {@link ImmutableContextSet} from an existing {@link Set}.
     *
     * 

Only really useful for converting between mutable and immutable types.

* * @param contextSet the context set to copy from * @return a new ImmutableContextSet with the same content and the one provided * @throws NullPointerException if contextSet is null */ @Nonnull public static ImmutableContextSet fromSet(@Nonnull ContextSet contextSet) { return Objects.requireNonNull(contextSet, "contextSet").makeImmutable(); } /** * Returns an empty {@link ImmutableContextSet}. * * @return an empty ImmutableContextSet */ @Nonnull public static ImmutableContextSet empty() { return EMPTY; } private final ImmutableSetMultimap map; private final int hashCode; ImmutableContextSet(ImmutableSetMultimap contexts) { this.map = contexts; this.hashCode = this.map.hashCode(); } @Override protected SetMultimap backing() { return this.map; } @Override protected void copyTo(SetMultimap other) { other.putAll(this.map); } @Override public boolean isImmutable() { return true; } @Nonnull @Override @Deprecated // This set is already immutable! public ImmutableContextSet makeImmutable() { return this; } @Nonnull @Override public MutableContextSet mutableCopy() { return MutableContextSet.fromSet(this); } @Nonnull @Override public Set> toSet() { return this.map.entries(); } @Nonnull @Override @Deprecated public Map toMap() { ImmutableMap.Builder m = ImmutableMap.builder(); for (Map.Entry e : this.map.entries()) { m.put(e.getKey(), e.getValue()); } return m.build(); } @Nonnull @Override public Multimap toMultimap() { return this.map; } @Nonnull @Override public Iterator> iterator() { return this.map.entries().iterator(); } @Override public Spliterator> spliterator() { return this.map.entries().spliterator(); } @Override public int hashCode() { return this.hashCode; } @Override public String toString() { return "ImmutableContextSet(contexts=" + this.map + ")"; } /** * A builder for {@link ImmutableContextSet}. * * @since 4.1 */ public static final class Builder { private ImmutableSetMultimap.Builder builder; private Builder() { } private synchronized ImmutableSetMultimap.Builder builder() { if (this.builder == null) { this.builder = ImmutableSetMultimap.builder(); } return this.builder; } private void put(String key, String value) { builder().put(key, value); } /** * Adds a context to the set. * * @param key the key to add * @param value the value to add * @return the builder * @throws NullPointerException if the key or value is null * @see MutableContextSet#add(String, String) */ @Nonnull public Builder add(@Nonnull String key, @Nonnull String value) { put(sanitizeKey(key), sanitizeValue(value)); return this; } /** * Adds a context to the set. * * @param entry the entry to add * @return the builder * @throws NullPointerException if the entry is null * @see MutableContextSet#add(Map.Entry) */ @Nonnull public Builder add(@Nonnull Map.Entry entry) { Objects.requireNonNull(entry, "entry"); add(entry.getKey(), entry.getValue()); return this; } /** * Adds the contexts contained in the given {@link Iterable} to the set. * * @param iterable an iterable of key value context pairs * @return the builder * @throws NullPointerException if iterable is null * @see MutableContextSet#addAll(Iterable) */ @Nonnull public Builder addAll(@Nonnull Iterable> iterable) { for (Map.Entry e : Objects.requireNonNull(iterable, "iterable")) { add(e); } return this; } /** * Adds the contexts contained in the given {@link Map} to the set. * * @param map the map to add from * @return the builder * @throws NullPointerException if the map is null * @see MutableContextSet#addAll(Map) */ @Nonnull public Builder addAll(@Nonnull Map map) { addAll(Objects.requireNonNull(map, "map").entrySet()); return this; } /** * Adds the contexts contained in the given {@link Multimap} to the set. * * @param multimap the multimap to add from * @return the builder * @throws NullPointerException if the map is null * @since 3.4 * @see MutableContextSet#addAll(Multimap) */ @Nonnull public Builder addAll(@Nonnull Multimap multimap) { addAll(Objects.requireNonNull(multimap, "multimap").entries()); return this; } /** * Adds of of the contexts in another {@link ContextSet} to the set. * * @param contextSet the set to add from * @return the builder * @throws NullPointerException if the contextSet is null * @see MutableContextSet#addAll(ContextSet) */ @Nonnull public Builder addAll(@Nonnull ContextSet contextSet) { Objects.requireNonNull(contextSet, "contextSet"); if (contextSet instanceof AbstractContextSet) { AbstractContextSet other = ((AbstractContextSet) contextSet); if (!other.isEmpty()) { builder().putAll(other.backing()); } } else { addAll(contextSet.toMultimap()); } return this; } /** * Creates a {@link ImmutableContextSet} from the values previously * added to the builder. * * @return an {@link ImmutableContextSet} from the builder */ @Nonnull public ImmutableContextSet build() { if (this.builder == null) { return empty(); } else { return new ImmutableContextSet(this.builder.build()); } } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy