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

org.springframework.shell.standard.ShellMethodAvailability Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.shell.standard;

import java.lang.annotation.*;

/**
 * Used to customize the name of the method used to indicate availability of a command.
 *
 * In the absence of this annotation, the dynamic availability of a command method named {@literal foo}
 * is discovered via method {@literal fooAvailability}.
 * 
    *
  • If this annotation is added to the {@literal foo} * method, then its {@link #value()} should be the name of an availability method (in place of * {@literal fooAvailability()}) that returns {@link org.springframework.shell.Availability}.
  • *
  • If placed on a method that returns {@link org.springframework.shell.Availability} and takes no argument, * then the {@link #value()} of this annotation should be the command names (or aliases) of the * commands this availability indicator is for. The special value of {@literal "*"} (the default) matches * all commands implemented in the current class.
  • *
* * @author Eric Bottard */ @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.METHOD}) @Documented public @interface ShellMethodAvailability { /** * @return the name of the availability method for this command method, or if placed on an availability method, the names of * the commands it is for. */ String[] value() default "*"; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy