aboutsummaryrefslogtreecommitdiff
path: root/src/share/classes/javax/management/NotificationInfos.java
blob: cc21d06d3a7926ad227d4db6e89029784e08c8b4 (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*
 * Copyright 2007-2008 Sun Microsystems, Inc.  All Rights Reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Sun designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Sun in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
 * CA 95054 USA or visit www.sun.com if you need additional information or
 * have any questions.
 */

package javax.management;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import javax.management.remote.JMXConnectionNotification;

/**
 * <p>Specifies the kinds of notification an MBean can emit, when this
 * cannot be represented by a single {@link NotificationInfo
 * &#64;NotificationInfo} annotation.</p>
 *
 * <p>For example, this annotation specifies that an MBean can emit
 * {@link AttributeChangeNotification} and {@link
 * JMXConnectionNotification}:</p>
 *
 * <pre>
 * {@code @NotificationInfos}(
 *     {@code @NotificationInfo}(
 *         types = {{@link AttributeChangeNotification#ATTRIBUTE_CHANGE}},
 *         notificationClass = AttributeChangeNotification.class),
 *     {@code @NotificationInfo}(
 *         types = {{@link JMXConnectionNotification#OPENED},
 *                  {@link JMXConnectionNotification#CLOSED}},
 *         notificationClass = JMXConnectionNotification.class)
 * )
 * </pre>
 *
 * <p>If an MBean has both {@code NotificationInfo} and {@code
 * NotificationInfos} on the same class or interface, the effect is
 * the same as if the {@code NotificationInfo} were moved inside the
 * {@code NotificationInfos}.</p>
 */
@Documented
@Inherited
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface NotificationInfos {
    /**
     * <p>The {@link NotificationInfo} annotations.</p>
     */
    NotificationInfo[] value();
}