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

org.spongepowered.api.placeholder.PlaceholderComponent Maven / Gradle / Ivy

/*
 * This file is part of SpongeAPI, licensed under the MIT License (MIT).
 *
 * Copyright (c) SpongePowered 
 * 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 org.spongepowered.api.placeholder;

import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.ComponentLike;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.spongepowered.api.Sponge;

/**
 * A {@link ComponentLike} that can be used in {@link Component} building methods
 * that represents a placeholder in text.
 *
 * 

A {@link PlaceholderComponent} is the collection of a * {@link PlaceholderParser} along with contextual data in the supplied * {@link PlaceholderContext}, enabling its use in a {@link Component} object. *

* *

Such placeholders will generally be built from tokenized strings, however * these objects make no assumption about the format of text templating. Such a * system can therefore be used by other templating engines without conforming * to a particular standard.

* *

The {@link PlaceholderContext} is fixed when this object is created, but * {@link PlaceholderParser#parse(PlaceholderContext)} is not called until * {@link #asComponent()} is called. Thus, any {@link Component} object that is * created will reflect the time that the {@link Component} object was * requested, and not when this object itself was created. It therefore follows * that implementations must not cache the result of {@link #asComponent()} * unless it is known that the supplied parser is not sensitive * to the time of invocation.

*/ public interface PlaceholderComponent extends ComponentLike { /** * Gets a builder for creating {@link PlaceholderComponent}. * * @return A {@link Builder} */ static Builder builder() { return Sponge.game().builderProvider().provide(Builder.class); } /** * Gets the {@link PlaceholderContext} that is to be supplied to the * {@link PlaceholderParser} to create the {@link Component}. * * @return The {@link PlaceholderContext} */ PlaceholderContext context(); /** * Gets the {@link PlaceholderParser} that handles this placeholder. * * @return The {@link PlaceholderParser} */ PlaceholderParser parser(); /** * Creates a {@link Component} from the supplied {@link PlaceholderParser} * in the context of the supplied {@link PlaceholderContext}. * *

This will always return a {@link Component} object, however, if the * parser could not handle the provided context, this will be * {@link Component#empty()}.

* * @return The parsed {@link Component} */ @Override default @NonNull Component asComponent() { return this.parser().parse(this.context()); } /** * A builder for {@link PlaceholderComponent} objects. */ interface Builder extends org.spongepowered.api.util.Builder { /** * Sets the token that represents a {@link PlaceholderParser} for use * in this {@link PlaceholderComponent}. * * @param parser The {@link PlaceholderParser} to use * @return This, for chaining */ Builder parser(PlaceholderParser parser); /** * Sets the {@link PlaceholderContext} that will be provided to the * {@link PlaceholderParser} to create the {@link Component} when * {@link ComponentLike#asComponent()} ()} is called. * * @param context The {@link PlaceholderContext} to use. * @return This, for chaining */ Builder context(PlaceholderContext context); /** * Builds and returns the placeholder. * * @return The appropriate {@link PlaceholderComponent} * @throws IllegalStateException if the builder has not been completed, * or the associated {@link PlaceholderParser} could not validate the * built {@link PlaceholderComponent}, if applicable. */ @Override PlaceholderComponent build() throws IllegalStateException; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy