/*
 * Copyright 2017-2020 original 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 io.micronaut.inject;

import io.micronaut.core.type.Executable;

import java.lang.reflect.Method;

Defines an injection point for a method.
Author:Graeme Rocher
Type parameters:
  • <B> – The bean type
  • <T> – The injectable type
Since:1.0
/** * Defines an injection point for a method. * * @param <B> The bean type * @param <T> The injectable type * @author Graeme Rocher * @since 1.0 */
public interface MethodInjectionPoint<B, T> extends CallableInjectionPoint<B>, Executable<B, T> {
Resolves the Method instance. Note that this method will cause reflection metadata to be initialized and should be avoided.
Returns:The setter to invoke to set said property
/** * Resolves the {@link Method} instance. Note that this method will cause reflection * metadata to be initialized and should be avoided. * * @return The setter to invoke to set said property */
Method getMethod();
Returns:The method name
/** * @return The method name */
String getName();
Returns:Is this method a pre-destroy method
/** * @return Is this method a pre-destroy method */
boolean isPreDestroyMethod();
Returns:Is this method a post construct method
/** * @return Is this method a post construct method */
boolean isPostConstructMethod();
Invokes the method.
Params:
  • instance – The instance
  • args – The arguments. Should match the types of getArguments()
Returns:The new value
/** * Invokes the method. * * @param instance The instance * @param args The arguments. Should match the types of getArguments() * @return The new value */
@Override T invoke(B instance, Object... args); }