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

jio.console.Command Maven / Gradle / Ivy

package jio.console;


import jio.IO;
import jsonvalues.JsObj;

import java.util.Objects;
import java.util.Optional;
import java.util.function.BiFunction;
import java.util.function.Function;
import java.util.function.Predicate;

/**
 * Represents a command that is modeled with a function that takes three parameters:
 *
 * 
    *
  • a {@link JsObj} with all the configuration information that is specified when starting the console
  • *
  • the {@link State}, which is a map of variables and their values
  • *
  • the command typed in by the user parsed into an array of tokens
  • *
* *

A command returns a JIO effect that executes the command action and returns a string as a result. * The output of a command is, by default, stored in the state variable called "output." This behavior can * be controlled with the method {@link #setSaveOutput(boolean)}.

* *

Commands are used in the console to perform various actions based on user input.

*/ public abstract class Command implements BiFunction>> { /** * Description of the command. */ public final String description; /** * Name of the command. */ public final String name; private final Predicate isCommand; /** * Flag to control whether the output of the command is saved in the state variable 'output.' By default, it is set to * true, meaning that output is saved. */ public boolean isSaveOutput = true; /** * Constructor to create a command from its name, description, and a predicate to check if the text typed in by the * user corresponds to this command. The description will be printed out on the console when typing the help command: *
   *     help name
   * 
* * @param name the name of the command * @param description the description of the command * @param isCommand a predicate to test if the command typed by the user corresponds to this command */ public Command(final String name, final String description, final Predicate isCommand ) { this.description = Objects.requireNonNull(description); this.name = Objects.requireNonNull(name); this.isCommand = Objects.requireNonNull(isCommand); } /** * Constructor to create a command from its name and description. The predicate to check if the text typed in by the * user corresponds to this command is: * * @param name the name of the command * @param description the description of the command */ public Command(final String name, final String description ) { this(name, description, tokens -> name.equalsIgnoreCase(tokens[0]) ); } /** * Sets whether the output of the command should be saved in the state variable 'output.' * * @param saveOutput the flag * @return this command */ public Command setSaveOutput(boolean saveOutput) { isSaveOutput = saveOutput; return this; } @Override public String toString() { return "Command{" + "name='" + name + '\'' + '}'; } /** * Returns a function that, given an array of tokens representing the user input, returns an empty optional if the * user input doesn't correspond to this command, or a JIO effect that executes the command action and returns a * string as the output. * * @param conf the configuration * @param state the state * @return a function that takes the array of tokens typed in by the client and returns the command action wrapped * into an optional. If the optional is empty, it means the user input doesn't correspond to this command. */ Function>> executeIfMatch(JsObj conf, State state) { return tokens -> { try { return isCommand.test(tokens) ? Optional.of(apply(conf, state).apply(tokens)) : Optional.empty(); } catch (Exception e) { return Optional.of(IO.fail(e)); } }; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy