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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/*
* Permission to copy, display and distribute the Service Component Architecture Specification and/or
* portions thereof, without modification, in any medium without fee or royalty is hereby granted, provided
* that you include the following on ALL copies of the Service Component Architecture Specification, or
* portions thereof, that you make:
* 1. A link or URL to the Service Component Architecture Specification at this location:
* http://www.osoa.org/display/Main/Service+Component+Architecture+Specifications
* 2. The full text of the copyright notice as shown in the Service Component Architecture Specification.
* BEA, Cape Clear, IBM, Interface21, IONA, Oracle, Primeton, Progress Software, Red Hat, Rogue Wave,
* SAP, Siemens, Software AG., Sun, Sybase, TIBCO (collectively, the "Authors") agree to grant you a
* royalty-free license, under reasonable, non-discriminatory terms and conditions to patents that they deem
* necessary to implement the Service Component Architecture Specification.
* THE Service Component Architecture SPECIFICATION IS PROVIDED "AS IS," AND THE
* AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED,
* REGARDING THIS SPECIFICATION AND THE IMPLEMENTATION OF ITS CONTENTS,
* INCLUDING, BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
* PARTICULAR PURPOSE, NON-INFRINGEMENT OR TITLE.
* THE AUTHORS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL
* OR CONSEQUENTIAL DAMAGES ARISING OUT OF OR RELATING TO ANY USE OR
* DISTRIBUTION OF THE Service Components Architecture SPECIFICATION.
* The name and trademarks of the Authors may NOT be used in any manner, including advertising or
* publicity pertaining to the Service Component Architecture Specification or its contents without specific,
*/
package org.osoa.sca.annotations;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
/**
* Annotation used to indicate the service interfaces exposed by a Java class.
*
* @version $Rev$ $Date$
*/
@Target({TYPE})
@Retention(RUNTIME)
public @interface Service {
/**
* Array of interfaces that should be exposed as services.
*
* @return a list of interfaces that should be exposed as services
*/
Class<?>[] interfaces() default {};
/**
* Shortcut allowing a single interface to be exposed.
*
* @return a single service interfaces to be exposed
*/
Class<?> value() default Void.class;
}
|