Class Variable<T>
java.lang.Object
io.github.syst3ms.skriptparser.lang.Variable<T>
- Type Parameters:
T- the common supertype of the possibly multiple values of the variable
- All Implemented Interfaces:
Expression<T>, SyntaxElement
A reference to a variable, whose value is only known at runtime. It can be local to the event, meaning it isn't
defined outside of the event it was first defined in. It can also be a list of multiple values. It can also be both.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionacceptsChange(ChangeMode mode) Determines whether this expression can be changed according to a specificChangeMode, and what type of values it can be changed with.voidchange(TriggerContext ctx, ChangeMode mode, Object[] changeWith) Changes this expression with the given values according to the given mode<C> Optional<? extends Expression<C>> convertExpression(Class<C> to) Converts this expression from it's current type (T) to another type, using converters.getIndex(TriggerContext ctx) getRaw(TriggerContext ctx) Returns the raw value stored inside the variable map.T[]getValues(TriggerContext ctx) Retrieves all values of this Expression, accounting for possible modifiers.booleaninit(Expression<?>[] expressions, int matchedPattern, ParseContext parseContext) Initializes this SyntaxElement before being used.booleanbooleanWhen this expression is looped, returns what the loop reference (as in loop-<reference>) should be in order to describe each element of the values of this expression.booleanisSingle()iterator(TriggerContext ctx) voidsetReturnType(Class<?> returnType) toString(TriggerContext ctx, boolean debug) Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface Expression
acceptsChange, acceptsChange, check, check, getArray, getSingle, getSource, isAndList, setAndList, stream
-
Constructor Details
-
Variable
-
-
Method Details
-
init
@Contract("_, _, _ -> fail") public boolean init(Expression<?>[] expressions, int matchedPattern, ParseContext parseContext) Description copied from interface:SyntaxElementInitializes this SyntaxElement before being used. This method is always called before all the others in an extending class, the only exception beingCodeSection.loadSection(FileSection, ParserState, SkriptLogger).- Specified by:
initin interfaceSyntaxElement- Parameters:
expressions- an array of expressions representing all the expressions that are being passed to this syntax element. As opposed to Skript, elements of this array can't benull.matchedPattern- the index of the pattern that was successfully matched. It corresponds to the order of the syntaxes in registrationparseContext- an object containing additional information about the parsing of this syntax element, like regex matches and parse marks- Returns:
trueif the syntax element was initialized successfully,falseotherwise.- See Also:
-
getValues
Description copied from interface:ExpressionRetrieves all values of this Expression, accounting for possible modifiers. This means that if this is an or-list, it will choose a random value to return.- Specified by:
getValuesin interfaceExpression<T>- Parameters:
ctx- the event- Returns:
- an array of the values
- See Also:
-
getIndex
- Parameters:
ctx- the event- Returns:
- the index of this Variable
-
getRaw
Returns the raw value stored inside the variable map. This can either be the object this Variable is referencing to or some sort of Map containing nested nodes.- Parameters:
ctx- the event- Returns:
- the raw value
-
isSingle
public boolean isSingle()- Specified by:
isSinglein interfaceExpression<T>- Returns:
- whether this expression returns a single value. By default, this is defined on registration, but it can be overridden.
-
getReturnType
- Specified by:
getReturnTypein interfaceExpression<T>- Returns:
- the return type of this expression. By default, this is defined on registration, but, like Expression.isSingle(), can be overriden.
-
setReturnType
-
acceptsChange
Description copied from interface:ExpressionDetermines whether this expression can be changed according to a specificChangeMode, and what type of values it can be changed with.- Specified by:
acceptsChangein interfaceExpression<T>- Parameters:
mode- the mode this Expression would be changed with- Returns:
- an array of classes describing what types this Expression can be changed with, empty if it
shouldn't be changed with the given change mode. If the change mode is
ChangeMode.DELETEorChangeMode.RESET, then an empty array should be returned.
-
change
public void change(TriggerContext ctx, ChangeMode mode, Object[] changeWith) throws UnsupportedOperationException Description copied from interface:ExpressionChanges this expression with the given values according to the given mode- Specified by:
changein interfaceExpression<T>- Parameters:
ctx- the eventmode- the mode of changechangeWith- the values to change this Expression with- Throws:
UnsupportedOperationException
-
iterator
- Specified by:
iteratorin interfaceExpression<T>- Parameters:
ctx- the event- Returns:
- an iterator of the values of this expression
-
variablesIterator
-
convertExpression
Description copied from interface:ExpressionConverts this expression from it's current type (T) to another type, using converters.- Specified by:
convertExpressionin interfaceExpression<T>- Type Parameters:
C- the type to convert this Expression to- Parameters:
to- the class of the type to convert this Expression to- Returns:
- a converted Expression, or
nullif it couldn't be converted
-
isLoopOf
Description copied from interface:ExpressionWhen this expression is looped, returns what the loop reference (as in loop-<reference>) should be in order to describe each element of the values of this expression.- Specified by:
isLoopOfin interfaceExpression<T>- Parameters:
s- the loop reference- Returns:
- whether the given reference describes this expression's elements. By default, returns
trueif the parameter is"value" - See Also:
-
isIndexLoop
-
toString
- Specified by:
toStringin interfaceSyntaxElement- Parameters:
ctx- the eventdebug- whether to show additional information or not- Returns:
- a
Stringthat should aim to resemble what is written in the script as closely as possible
-