summaryrefslogtreecommitdiffstats
path: root/sca-java-2.x/tags/2.0.1-RC1/modules/sca-api/src/main/java/org/oasisopen/sca/annotation/AllowsPassByReference.java
blob: 3350e9413b2f7d279106dcef9f5ad26e6fbcc323 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/*
 * Copyright(C) OASIS(R) 2005,2010. All Rights Reserved.
 * OASIS trademark, IPR and other policies apply.
 */
package org.oasisopen.sca.annotation;

import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

/**
 * The @AllowsPassByReference annotation is used on implementations
 * of remotable interfaces to indicate that interactions with the
 * service from a client within the same address space are allowed
 * to use pass by reference data exchange semantics.
 *
 * The implementation promises that its by-value semantics will be
 * maintained even if the parameters and return values are actually
 * passed by-reference. This means that the service will not modify
 * any operation input parameter or return value, even after returning
 * from the operation.
 *
 * Either a whole class implementing a remotable service or an individual
 * remotable service method implementation can be annotated using the
 * {@literal @AllowsPassByReference} annotation.
 *
 * {@literal @AllowsPassByReference} has no attributes.
 */
@Target({TYPE, METHOD, FIELD, PARAMETER})
@Retention(RUNTIME)
public @interface AllowsPassByReference {
	
	boolean value() default true;
}