/* * This file is a part of the SteamWar software. * * Copyright (C) 2022 SteamWar.de-Serverteam * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ package de.steamwar.command; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; public @interface CommandMetaData { /** * This annotation is only for internal use. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) @interface Method { Class[] value(); int minParameterCount() default 0; int maxParameterCount() default Integer.MAX_VALUE; } /** * This annotation denotes what types are allowed as parameter types the annotation annotated with can use. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) @interface Parameter { Class[] value(); } /** * This annotation can be used in conjunction with a class that implement {@link AbstractValidator} to * create custom validator short hands for commands. The validator class itself should contain a constructor * with two parameters the first is the annotation this annotation is used on and the second is of type {@link Class}. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) @interface ImplicitValidator { /** * The validator class that should be used. */ Class handler(); /** * Defines when this validator should be processed. Negative numbers denote that this will be * processed before {@link AbstractSWCommand.Validator} and positive numbers * denote that this will be processed after {@link AbstractSWCommand.Validator}. */ int order(); } }