com.plotsquared.core.setup.SetupStep Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of plotsquared-core Show documentation
Show all versions of plotsquared-core Show documentation
PlotSquared, a land and world management plugin for Minecraft.
/*
* PlotSquared, a land and world management plugin for Minecraft.
* Copyright (C) IntellectualSites
* Copyright (C) IntellectualSites team and contributors
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package com.plotsquared.core.setup;
import com.plotsquared.core.command.Command;
import com.plotsquared.core.command.RequiredType;
import com.plotsquared.core.player.PlotPlayer;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.checkerframework.checker.nullness.qual.Nullable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
public interface SetupStep {
/**
* Handles the input for this setup step.
*
* @param plotPlayer the plot player executing the command
* @param builder the plot area builder to work on
* @param argument the argument given as input
* @return the next step if input was valid, this setup step otherwise
*/
SetupStep handleInput(final PlotPlayer> plotPlayer, PlotAreaBuilder builder, String argument);
@NonNull Collection getSuggestions();
@Nullable String getDefaultValue();
/**
* Announces this step to the player.
*
* @param plotPlayer the player to announce this step to.
*/
void announce(PlotPlayer> plotPlayer);
/**
* Creates a collection of suggestions for the current input.
*
* @param plotPlayer the player to receive the suggestions.
* @param argument the argument already typed.
* @return a collection of suggestions.
*/
default Collection createSuggestions(final PlotPlayer> plotPlayer, String argument) {
List result = new ArrayList<>(getSuggestions().size());
for (String suggestion : getSuggestions()) {
if (suggestion.startsWith(argument)) {
result.add(new Command(null, false, suggestion, "", RequiredType.NONE, null) {
});
}
}
return result;
}
/**
* This method is called when the SetupProcess reverts to a previous step.
*
* @param builder the builder associated with the setup process.
*/
default void onBack(PlotAreaBuilder builder) {
}
}