src/jdk.jfr/share/classes/jdk/jfr/consumer/RecordingStream.java
author egahlin
Thu, 05 Sep 2019 16:46:50 +0200
branchJEP-349-branch
changeset 58020 f082177c5023
parent 57985 be121cbf3284
child 58129 7b751fe181a5
permissions -rw-r--r--
Improved handling of Thread.interrupt() + cleanup
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>
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    50
 * The following example, shows how to record events using the default
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    51
 * configuration and print the Garbage Collection, CPU Load and JVM Information
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    52
 * event to standard out.
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    53
 *
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    54
 * <pre>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    55
 * <code>
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    56
 * Configuration c = Configuration.getConfiguration("default");
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    57
 * try (RecordingStream rs = new RecordingStream(c)) {
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    58
 *     rs.onEvent("jdk.GarbageCollection", System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    59
 *     rs.onEvent("jdk.CPULoad", System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    60
 *     rs.onEvent("jdk.JVMInformation", System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    61
 *     rs.start();
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    62
 *   }
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    63
 * }
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    64
 * </code>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    65
 * </pre>
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    66
 *
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    67
 */
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    68
public final class RecordingStream implements AutoCloseable, EventStream {
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    69
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    70
    private final Recording recording;
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    71
    private final EventDirectoryStream directoryStream;
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    72
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    73
    /**
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
    74
     * Creates an event stream for the current JVM (Java Virtual Machine).
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    75
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    76
     * @throws IllegalStateException if Flight Recorder can't be created (for
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    77
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    78
     *         support, or if the file repository can't be created or accessed)
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    79
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    80
     * @throws SecurityException if a security manager exists and the caller
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    81
     *         does not have
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    82
     *         {@code FlightRecorderPermission("accessFlightRecorder")}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    83
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    84
    public RecordingStream() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    85
        Utils.checkAccessFlightRecorder();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    86
        AccessControlContext acc = AccessController.getContext();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    87
        this.recording = new Recording();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    88
        this.recording.setFlushInterval(Duration.ofMillis(1000));
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    89
        try {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    90
            this.directoryStream = new EventDirectoryStream(acc, null, SecuritySupport.PRIVILIGED, true);
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    91
        } catch (IOException ioe) {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
    92
            this.recording.close();
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    93
            throw new IllegalStateException(ioe.getMessage());
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    94
        }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    95
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    96
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    97
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    98
     * Creates a recording stream using settings from a configuration.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    99
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   100
     * The following example shows how to create a recording stream that uses a
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   101
     * predefined configuration.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   102
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   103
     * <pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   104
     * <code>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   105
     * var c = Configuration.getConfiguration("default");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   106
     * try (RecordingStream rs = new RecordingStream(c)) {
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   107
     *   rs.onEvent(System.out::println);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   108
     *   rs.start();
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   109
     * }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   110
     * </code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   111
     * </pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   112
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   113
     * @param configuration configuration that contains the settings to be use,
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   114
     *        not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   115
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   116
     * @throws IllegalStateException if Flight Recorder can't be created (for
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   117
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   118
     *         support, or if the file repository can't be created or accessed)
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   119
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   120
     * @throws SecurityException if a security manager is used and
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   121
     *         FlightRecorderPermission "accessFlightRecorder" is not set.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   122
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   123
     * @see Configuration
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   124
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   125
    public RecordingStream(Configuration configuration) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   126
        this();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   127
        recording.setSettings(configuration.getSettings());
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   128
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   129
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   130
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   131
     * Enables the event with the specified name.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   132
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   133
     * If multiple events have the same name (for example, the same class is
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   134
     * loaded in different class loaders), then all events that match the name
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   135
     * are enabled. To enable a specific class, use the {@link #enable(Class)}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   136
     * method or a {@code String} representation of the event type ID.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   137
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   138
     * @param name the settings for the event, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   139
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   140
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   141
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   142
     * @see EventType
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   143
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   144
    public EventSettings enable(String name) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   145
        return recording.enable(name);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   146
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   147
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   148
    /**
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   149
     * Replaces all settings for this recording stream
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   150
     * <p>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   151
     * The following example records 20 second using the "default" configuration
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   152
     * and then changes to settings for the "profile" configuration.
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   153
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   154
     * <pre>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   155
     * <code>
57614
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   156
     *     var defaultConfiguration = Configuration.getConfiguration("default");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   157
     *     var profileConfiguration = Configuration.getConfiguration("profile");
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   158
     *     try (var rs = new RecordingStream(defaultConfiguration) {
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   159
     *        rs.startAsync();
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   160
     *        Thread.sleep(20_000);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   161
     *        rs.setSettings(profileConfiguration.getSettings());
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   162
     *        Thread.sleep(20_000);
b49f5c13baa7 Cleaning up
egahlin
parents: 57449
diff changeset
   163
     *     }
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   164
     * </code>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   165
     * </pre>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   166
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   167
     * @param settings the settings to set, not {@code null}
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   168
     */
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   169
    public void setSettings(Map<String, String> settings) {
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   170
        recording.setSettings(settings);
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   171
    };
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   172
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   173
    /**
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   174
     * Enables event.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   175
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   176
     * @param eventClass the event to enable, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   177
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   178
     * @throws IllegalArgumentException if {@code eventClass} is an abstract
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   179
     *         class or not a subclass of {@link Event}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   180
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   181
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   182
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   183
    public EventSettings enable(Class<? extends Event> eventClass) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   184
        return recording.enable(eventClass);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   185
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   186
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   187
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   188
     * Disables event with the specified name.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   189
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   190
     * If multiple events with same name (for example, the same class is loaded
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   191
     * in different class loaders), then all events that match the name is
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   192
     * disabled. To disable a specific class, use the {@link #disable(Class)}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   193
     * method or a {@code String} representation of the event type ID.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   194
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   195
     * @param name the settings for the event, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   196
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   197
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   198
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   199
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   200
    public EventSettings disable(String name) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   201
        return recording.disable(name);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   202
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   203
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   204
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   205
     * Disables event.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   206
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   207
     * @param eventClass the event to enable, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   208
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   209
     * @throws IllegalArgumentException if {@code eventClass} is an abstract
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   210
     *         class or not a subclass of {@link Event}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   211
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   212
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   213
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   214
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   215
    public EventSettings disable(Class<? extends Event> eventClass) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   216
        return recording.disable(eventClass);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   217
    }
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   218
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   219
    /**
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   220
     * Determines how far back data is kept for the stream, if the stream can't
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   221
     * keep up.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   222
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   223
     * To control the amount of recording data stored on disk, the maximum
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   224
     * length of time to retain the data can be specified. Data stored on disk
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   225
     * that is older than the specified length of time is removed by the Java
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   226
     * Virtual Machine (JVM).
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   227
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   228
     * If neither maximum limit or the maximum age is set, the size of the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   229
     * recording may grow indefinitely if events are on
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   230
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   231
     * @param maxAge the length of time that data is kept, or {@code null} if
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   232
     *        infinite
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   233
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   234
     * @throws IllegalArgumentException if <code>maxAge</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   235
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   236
     * @throws IllegalStateException if the recording is in the {@code CLOSED}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   237
     *         state
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   238
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   239
    public void setMaxAge(Duration maxAge) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   240
        recording.setMaxAge(maxAge);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   241
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   242
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   243
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   244
     * Determines how much data is kept in the disk repository if the stream
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   245
     * can't keep up.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   246
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   247
     * To control the amount of recording data that is stored on disk, the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   248
     * maximum amount of data to retain can be specified. When the maximum limit
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   249
     * is exceeded, the Java Virtual Machine (JVM) removes the oldest chunk to
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   250
     * make room for a more recent chunk.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   251
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   252
     * If neither maximum limit or the maximum age is set, the size of the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   253
     * recording may grow indefinitely.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   254
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   255
     * @param maxSize the amount of data to retain, {@code 0} if infinite
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   256
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   257
     * @throws IllegalArgumentException if <code>maxSize</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   258
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   259
     * @throws IllegalStateException if the recording is in {@code CLOSED} state
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   260
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   261
    public void setMaxSize(long maxSize) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   262
        recording.setMaxSize(maxSize);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   263
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   264
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   265
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   266
     * Determines how often events are made available for streaming.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   267
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   268
     * @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
   269
     *        stream, no {@code null}
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   270
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   271
     * @throws IllegalArgumentException if <code>interval</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   272
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   273
     * @throws IllegalStateException if the stream is closed
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   274
     */
57944
f1610739fe86 Rename RecordingStream::setInterval to setFlushInterval
egahlin
parents: 57717
diff changeset
   275
    public void setFlushInterval(Duration interval) {
f1610739fe86 Rename RecordingStream::setInterval to setFlushInterval
egahlin
parents: 57717
diff changeset
   276
        recording.setFlushInterval(interval);
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   277
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   278
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   279
    @Override
57376
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   280
    public void setReuse(boolean reuse) {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   281
        directoryStream.setReuse(reuse);
57380
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   282
    }
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   283
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   284
    @Override
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   285
    public void setOrdered(boolean ordered) {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   286
        directoryStream.setOrdered(ordered);
57376
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   287
    }
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   288
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   289
    @Override
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   290
    public void setStartTime(Instant startTime) {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   291
        directoryStream.setStartTime(startTime);
57449
099789ceff7d Provide implementation for all added API methods
egahlin
parents: 57432
diff changeset
   292
    }
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   293
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   294
    @Override
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   295
    public void setEndTime(Instant endTime) {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   296
        directoryStream.setStartTime(endTime);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   297
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   298
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   299
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   300
    public void onEvent(String eventName, Consumer<RecordedEvent> action) {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   301
        directoryStream.onEvent(eventName, action);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   302
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   303
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   304
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   305
    public void onEvent(Consumer<RecordedEvent> action) {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   306
        directoryStream.onEvent(action);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   307
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   308
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   309
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   310
    public void onFlush(Runnable action) {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   311
        directoryStream.onFlush(action);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   312
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   313
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   314
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   315
    public void onClose(Runnable action) {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   316
        directoryStream.onClose(action);
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57614
diff changeset
   317
    }
57971
aa7b1ea52413 Add onError handler + various cleanup
egahlin
parents: 57944
diff changeset
   318
aa7b1ea52413 Add onError handler + various cleanup
egahlin
parents: 57944
diff changeset
   319
    @Override
aa7b1ea52413 Add onError handler + various cleanup
egahlin
parents: 57944
diff changeset
   320
    public void onError(Consumer<Throwable> action) {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   321
        directoryStream.onError(action);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   322
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   323
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   324
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   325
    public void close() {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   326
        recording.close();
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   327
        directoryStream.close();
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   328
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   329
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   330
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   331
    public boolean remove(Object action) {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   332
        return directoryStream.remove(action);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   333
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   334
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   335
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   336
    public void start() {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   337
        PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   338
        long startNanos = pr.start();
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   339
        directoryStream.start(startNanos);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   340
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   341
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   342
    @Override
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   343
    public void startAsync() {
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   344
        PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   345
        long startNanos = pr.start();
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   346
        directoryStream.startAsync(startNanos);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   347
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   348
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   349
    @Override
58020
f082177c5023 Improved handling of Thread.interrupt() + cleanup
egahlin
parents: 57985
diff changeset
   350
    public void awaitTermination(Duration timeout) throws InterruptedException {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   351
        directoryStream.awaitTermination(timeout);
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   352
    }
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   353
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   354
    @Override
58020
f082177c5023 Improved handling of Thread.interrupt() + cleanup
egahlin
parents: 57985
diff changeset
   355
    public void awaitTermination() throws InterruptedException {
57985
be121cbf3284 Clean up class hiercharchy
egahlin
parents: 57971
diff changeset
   356
        directoryStream.awaitTermination();
57971
aa7b1ea52413 Add onError handler + various cleanup
egahlin
parents: 57944
diff changeset
   357
    }
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   358
}