001/*
002 * Copyright (c) 2016-2017 Daniel Ennis (Aikar) - MIT License
003 *
004 *  Permission is hereby granted, free of charge, to any person obtaining
005 *  a copy of this software and associated documentation files (the
006 *  "Software"), to deal in the Software without restriction, including
007 *  without limitation the rights to use, copy, modify, merge, publish,
008 *  distribute, sublicense, and/or sell copies of the Software, and to
009 *  permit persons to whom the Software is furnished to do so, subject to
010 *  the following conditions:
011 *
012 *  The above copyright notice and this permission notice shall be
013 *  included in all copies or substantial portions of the Software.
014 *
015 *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
016 *  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
017 *  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
018 *  NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
019 *  LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
020 *  OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
021 *  WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
022 */
023
024package co.aikar.commands;
025
026import java.lang.annotation.Annotation;
027
028/**
029 * Holds information about the currently executing command on this thread
030 */
031public class CommandOperationContext <I extends CommandIssuer> {
032
033    private final CommandManager manager;
034    private final I issuer;
035    private final BaseCommand command;
036    private final String commandLabel;
037    private final String[] args;
038    private final boolean isAsync;
039    private RegisteredCommand registeredCommand;
040
041    CommandOperationContext(CommandManager manager, I issuer, BaseCommand command, String commandLabel, String[] args, boolean isAsync) {
042        this.manager = manager;
043        this.issuer = issuer;
044        this.command = command;
045        this.commandLabel = commandLabel;
046        this.args = args;
047        this.isAsync = isAsync;
048    }
049
050    public CommandManager getCommandManager() {
051        return manager;
052    }
053
054    public I getCommandIssuer() {
055        return issuer;
056    }
057
058    public BaseCommand getCommand() {
059        return command;
060    }
061
062    public String getCommandLabel() {
063        return commandLabel;
064    }
065
066    public String[] getArgs() {
067        return args;
068    }
069
070    public boolean isAsync() {
071        return isAsync;
072    }
073
074    public void setRegisteredCommand(RegisteredCommand registeredCommand) {
075        this.registeredCommand = registeredCommand;
076    }
077
078    public RegisteredCommand getRegisteredCommand() {
079        return registeredCommand;
080    }
081
082    /**
083     * This method will not support annotation processors!! use getAnnotationValue or hasAnnotation
084     * @deprecated Use {@link #getAnnotationValue(Class)}
085     */
086    @Deprecated
087    public <T extends Annotation> T getAnnotation(Class<T> anno) {
088        return registeredCommand.method.getAnnotation(anno);
089    }
090
091    public <T extends Annotation> String getAnnotationValue(Class<T> cls) {
092        return manager.getAnnotations().getAnnotationValue(registeredCommand.method, cls);
093    }
094
095    public <T extends Annotation> String getAnnotationValue(Class<T> cls, int options) {
096        return manager.getAnnotations().getAnnotationValue(registeredCommand.method, cls, options);
097    }
098
099    public boolean hasAnnotation(Class<? extends Annotation> anno) {
100        return getAnnotation(anno) != null;
101    }
102
103}