001/*
002 * Copyright (c) 2012-2021 Institut National des Sciences Appliquées de Lyon (INSA Lyon) and others
003 *
004 * This program and the accompanying materials are made available under the
005 * terms of the Eclipse Public License 2.0 which is available at
006 * http://www.eclipse.org/legal/epl-2.0.
007 *
008 * SPDX-License-Identifier: EPL-2.0
009 */
010package gololang.annotations;
011
012import java.lang.annotation.Documented;
013import java.lang.annotation.ElementType;
014import java.lang.annotation.Retention;
015import java.lang.annotation.RetentionPolicy;
016import java.lang.annotation.Target;
017
018/**
019 * <code>@DecoratedBy</code> is used to define the reference to the decorator on a decorated function.
020 *
021 * Mainly used for internal stuff, this annotation can be useful to create decorated function in Java.
022 */
023@Retention(RetentionPolicy.RUNTIME)
024@Target(ElementType.METHOD)
025@Documented
026public @interface DecoratedBy {
027  /**
028   * This is the reference to the decorator function.
029   *
030   * @return the reference to the decorator function.
031   */
032  String value();
033}