src/jdk.jfr/share/classes/jdk/jfr/consumer/RecordingStream.java
author egahlin
Tue, 13 Aug 2019 03:58:29 +0200
branchJEP-349-branch
changeset 57717 4ce66d271065
parent 57690 9316d02dd4a5
child 57944 f1610739fe86
permissions -rw-r--r--
Security handling, but two tests fails with driver
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     1
/*
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     4
 *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    10
 *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    15
 * accompanied this code).
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    16
 *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    20
 *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    23
 * questions.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    24
 */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    25
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    26
package jdk.jfr.consumer;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    27
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    28
import java.io.IOException;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    29
import java.security.AccessControlContext;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    30
import java.security.AccessController;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    31
import java.time.Duration;
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
    32
import java.time.Instant;
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
    33
import java.util.Map;
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    34
import java.util.function.Consumer;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    35
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    36
import jdk.jfr.Configuration;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    37
import jdk.jfr.Event;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    38
import jdk.jfr.EventSettings;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    39
import jdk.jfr.EventType;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    40
import jdk.jfr.Recording;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    41
import jdk.jfr.internal.PlatformRecording;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    42
import jdk.jfr.internal.PrivateAccess;
57717
4ce66d271065 Security handling, but two tests fails with driver
egahlin
parents: 57690
diff changeset
    43
import jdk.jfr.internal.SecuritySupport;
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    44
import jdk.jfr.internal.Utils;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    45
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    46
/**
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    47
 * A recording stream produces events from the current JVM (Java Virtual
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
    48
 * Machine).
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    49
 * <p>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    50
 * The following example records events using the default configuration and
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    51
 * prints the Garbage Collection, CPU Load and JVM Information event.
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    52
 *
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    53
 * <pre>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    54
 * <code>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    55
 * var c = Configuration.getConfiguration("default");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    56
 * try (var rs = new RecordingStream(c)) {
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    57
 *     rs.onEvent("jdk.GarbageCollection", System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    58
 *     rs.onEvent("jdk.CPULoad", System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    59
 *     rs.onEvent("jdk.JVMInformation", System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    60
 *     rs.start();
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    61
 *   }
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    62
 * }
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    63
 * </code>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    64
 * </pre>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    65
 *
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    66
 */
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    67
public final class RecordingStream implements AutoCloseable, EventStream {
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    68
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    69
    private final Recording recording;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    70
    private final EventDirectoryStream stream;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    71
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    72
    /**
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    73
     * Creates an event stream for the current JVM (Java Virtual Machine).
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    74
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    75
     * The following example shows how to create a recording stream that prints
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    76
     * CPU usage and information about garbage collections.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    77
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    78
     * <pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    79
     * <code>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    80
     * try (var rs = new RecordingStream()) {
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    81
     *   rs.enable("jdk.GarbageCollection");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    82
     *   rs.enable("jdk.CPULoad").withPeriod(Duration.ofSeconds(1));
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    83
     *   rs.onEvent(System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    84
     *   rs.start();
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    85
     * }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    86
     * </code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    87
     * </pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    88
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    89
     * @throws IllegalStateException if Flight Recorder can't be created (for
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    90
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    91
     *         support, or if the file repository can't be created or accessed)
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    92
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    93
     * @throws SecurityException if a security manager exists and the caller
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    94
     *         does not have
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    95
     *         {@code FlightRecorderPermission("accessFlightRecorder")}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    96
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    97
    public RecordingStream() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    98
        Utils.checkAccessFlightRecorder();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    99
        AccessControlContext acc = AccessController.getContext();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   100
        this.recording = new Recording();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   101
        this.recording.setFlushInterval(Duration.ofMillis(1000));
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   102
        try {
57717
4ce66d271065 Security handling, but two tests fails with driver
egahlin
parents: 57690
diff changeset
   103
            this.stream = new EventDirectoryStream(acc, null, SecuritySupport.PRIVILIGED, true);
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   104
        } catch (IOException ioe) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   105
            throw new IllegalStateException(ioe.getMessage());
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   106
        }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   107
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   108
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   109
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   110
     * Creates a recording stream using settings from a configuration.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   111
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   112
     * The following example shows how to create a recording stream that uses a
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   113
     * predefined configuration.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   114
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   115
     * <pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   116
     * <code>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   117
     * var c = Configuration.getConfiguration("default");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   118
     * try (RecordingStream rs = new RecordingStream(c)) {
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   119
     *   rs.onEvent(System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   120
     *   rs.start();
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   121
     * }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   122
     * </code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   123
     * </pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   124
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   125
     * @param configuration configuration that contains the settings to be use,
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   126
     *        not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   127
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   128
     * @throws IllegalStateException if Flight Recorder can't be created (for
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   129
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   130
     *         support, or if the file repository can't be created or accessed)
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   131
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   132
     * @throws SecurityException if a security manager is used and
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   133
     *         FlightRecorderPermission "accessFlightRecorder" is not set.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   134
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   135
     * @see Configuration
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   136
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   137
    public RecordingStream(Configuration configuration) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   138
        this();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   139
        recording.setSettings(configuration.getSettings());
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   140
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   141
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   142
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   143
     * Enables the event with the specified name.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   144
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   145
     * If multiple events have the same name (for example, the same class is
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   146
     * loaded in different class loaders), then all events that match the name
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   147
     * are enabled. To enable a specific class, use the {@link #enable(Class)}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   148
     * method or a {@code String} representation of the event type ID.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   149
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   150
     * @param name the settings for the event, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   151
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   152
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   153
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   154
     * @see EventType
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   155
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   156
    public EventSettings enable(String name) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   157
        return recording.enable(name);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   158
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   159
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   160
    /**
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   161
     * Replaces all settings for this recording stream
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   162
     * <p>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   163
     * The following example records 20 second using the "default" configuration
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   164
     * and then changes to settings for the "profile" configuration.
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   165
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   166
     * <pre>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   167
     * <code>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   168
     *     var defaultConfiguration = Configuration.getConfiguration("default");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   169
     *     var profileConfiguration = Configuration.getConfiguration("profile");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   170
     *     try (var rs = new RecordingStream(defaultConfiguration) {
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   171
     *        rs.startAsync();
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   172
     *        Thread.sleep(20_000);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   173
     *        rs.setSettings(profileConfiguration.getSettings());
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   174
     *        Thread.sleep(20_000);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   175
     *     }
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   176
     * </code>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   177
     * </pre>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   178
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   179
     * @param settings the settings to set, not {@code null}
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   180
     */
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   181
    public void setSettings(Map<String, String> settings) {
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   182
        recording.setSettings(settings);
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   183
    };
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   184
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   185
    /**
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   186
     * Enables event.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   187
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   188
     * @param eventClass the event to enable, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   189
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   190
     * @throws IllegalArgumentException if {@code eventClass} is an abstract
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   191
     *         class or not a subclass of {@link Event}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   192
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   193
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   194
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   195
    public EventSettings enable(Class<? extends Event> eventClass) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   196
        return recording.enable(eventClass);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   197
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   198
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   199
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   200
     * Disables event with the specified name.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   201
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   202
     * If multiple events with same name (for example, the same class is loaded
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   203
     * in different class loaders), then all events that match the name is
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   204
     * disabled. To disable a specific class, use the {@link #disable(Class)}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   205
     * method or a {@code String} representation of the event type ID.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   206
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   207
     * @param name the settings for the event, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   208
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   209
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   210
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   211
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   212
    public EventSettings disable(String name) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   213
        return recording.disable(name);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   214
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   215
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   216
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   217
     * Disables event.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   218
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   219
     * @param eventClass the event to enable, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   220
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   221
     * @throws IllegalArgumentException if {@code eventClass} is an abstract
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   222
     *         class or not a subclass of {@link Event}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   223
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   224
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   225
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   226
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   227
    public EventSettings disable(Class<? extends Event> eventClass) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   228
        return recording.disable(eventClass);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   229
    }
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   230
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   231
    /**
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   232
     * Determines how far back data is kept for the stream, if the stream can't
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   233
     * keep up.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   234
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   235
     * To control the amount of recording data stored on disk, the maximum
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   236
     * length of time to retain the data can be specified. Data stored on disk
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   237
     * that is older than the specified length of time is removed by the Java
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   238
     * Virtual Machine (JVM).
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   239
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   240
     * If neither maximum limit or the maximum age is set, the size of the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   241
     * recording may grow indefinitely if events are on
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   242
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   243
     * @param maxAge the length of time that data is kept, or {@code null} if
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   244
     *        infinite
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   245
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   246
     * @throws IllegalArgumentException if <code>maxAge</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   247
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   248
     * @throws IllegalStateException if the recording is in the {@code CLOSED}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   249
     *         state
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   250
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   251
    public void setMaxAge(Duration maxAge) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   252
        recording.setMaxAge(maxAge);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   253
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   254
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   255
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   256
     * Determines how much data is kept in the disk repository if the stream
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   257
     * can't keep up.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   258
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   259
     * To control the amount of recording data that is stored on disk, the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   260
     * maximum amount of data to retain can be specified. When the maximum limit
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   261
     * is exceeded, the Java Virtual Machine (JVM) removes the oldest chunk to
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   262
     * make room for a more recent chunk.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   263
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   264
     * If neither maximum limit or the maximum age is set, the size of the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   265
     * recording may grow indefinitely.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   266
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   267
     * @param maxSize the amount of data to retain, {@code 0} if infinite
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   268
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   269
     * @throws IllegalArgumentException if <code>maxSize</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   270
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   271
     * @throws IllegalStateException if the recording is in {@code CLOSED} state
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   272
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   273
    public void setMaxSize(long maxSize) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   274
        recording.setMaxSize(maxSize);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   275
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   276
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   277
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   278
    public void onEvent(String eventName, Consumer<RecordedEvent> action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   279
        stream.onEvent(eventName, action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   280
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   281
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   282
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   283
    public void onEvent(Consumer<RecordedEvent> action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   284
        stream.onEvent(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   285
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   286
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   287
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   288
    public void onFlush(Runnable action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   289
        stream.onFlush(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   290
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   291
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   292
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   293
    public void onClose(Runnable action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   294
        stream.onClose(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   295
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   296
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   297
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   298
    public void close() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   299
        recording.close();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   300
        stream.close();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   301
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   302
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   303
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   304
    public boolean remove(Object action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   305
        return stream.remove(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   306
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   307
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   308
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   309
    public void start() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   310
        PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   311
        long startNanos = pr.start();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   312
        stream.start(startNanos);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   313
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   314
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   315
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   316
    public void startAsync() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   317
        PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   318
        long startNanos = pr.start();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   319
        stream.startAsync(startNanos);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   320
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   321
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   322
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   323
    public void awaitTermination(Duration timeout) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   324
        stream.awaitTermination(timeout);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   325
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   326
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   327
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   328
     * Determines how often events are made available for streaming.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   329
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   330
     * @param interval the interval at which events are made available to the
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   331
     *        stream, no {@code null}
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   332
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   333
     * @throws IllegalArgumentException if <code>interval</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   334
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   335
     * @throws IllegalStateException if the stream is closed
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   336
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   337
    public void setInterval(Duration duration) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   338
        recording.setFlushInterval(duration);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   339
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   340
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   341
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   342
    public void awaitTermination() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   343
        stream.awaitTermination();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   344
    }
57376
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   345
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   346
    @Override
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   347
    public void setReuse(boolean reuse) {
57432
ba454a26d2c1 SetOrdered and setReuse now work on a directory stream
egahlin
parents: 57425
diff changeset
   348
        stream.setReuse(reuse);
57380
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   349
    }
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   350
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   351
    @Override
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   352
    public void setOrdered(boolean ordered) {
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   353
        stream.setOrdered(ordered);
57376
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   354
    }
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   355
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   356
    @Override
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   357
    public void setStartTime(Instant startTime) {
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   358
        stream.setStartTime(startTime);
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   359
    }
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   360
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   361
    @Override
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   362
    public void setEndTime(Instant endTime) {
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   363
        stream.setStartTime(endTime);
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   364
    }
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   365
}