src/jdk.jfr/share/classes/jdk/jfr/consumer/RecordingStream.java
author egahlin
Tue, 25 Jun 2019 12:03:01 +0200
branchJEP-349-branch
changeset 57425 1da8552f0b59
parent 57386 acdd0dbe37ee
child 57432 ba454a26d2c1
permissions -rw-r--r--
Use one parser per recording stream / thread
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;
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
    32
import java.util.Map;
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    33
import java.util.function.Consumer;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    34
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    35
import jdk.jfr.Configuration;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    36
import jdk.jfr.Event;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    37
import jdk.jfr.EventSettings;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    38
import jdk.jfr.EventType;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    39
import jdk.jfr.Recording;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    40
import jdk.jfr.internal.PlatformRecording;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    41
import jdk.jfr.internal.PrivateAccess;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    42
import jdk.jfr.internal.Utils;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    43
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    44
/**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    45
 * An event stream produces events from a file, directory or a running JVM (Java
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    46
 * Virtual Machine).
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    47
 */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    48
public class RecordingStream implements AutoCloseable, EventStream {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    49
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    50
    private final Recording recording;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    51
    private final EventDirectoryStream stream;
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    52
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    53
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    54
     * Creates an event stream for this JVM (Java Virtual Machine).
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    55
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    56
     * The following example shows how to create a recording stream that prints
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    57
     * CPU usage and information about garbage collections.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    58
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    59
     * <pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    60
     * <code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    61
     * try (RecordingStream  r = new RecordingStream()) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    62
     *   r.enable("jdk.GarbageCollection");
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    63
     *   r.enable("jdk.CPULoad").withPeriod(Duration.ofSeconds(1));
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    64
     *   r.onEvent(System.out::println);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    65
     *   r.start();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    66
     * }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    67
     * </code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    68
     * </pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    69
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    70
     * @throws IllegalStateException if Flight Recorder can't be created (for
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    71
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    72
     *         support, or if the file repository can't be created or accessed)
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    73
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    74
     * @throws SecurityException if a security manager exists and the caller
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    75
     *         does not have
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    76
     *         {@code FlightRecorderPermission("accessFlightRecorder")}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    77
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    78
    public RecordingStream() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    79
        Utils.checkAccessFlightRecorder();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    80
        AccessControlContext acc = AccessController.getContext();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    81
        this.recording = new Recording();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    82
        this.recording.setFlushInterval(Duration.ofMillis(1000));
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    83
        try {
57425
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    84
            this.stream = new EventDirectoryStream(acc, null);
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    85
        } catch (IOException ioe) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    86
            throw new IllegalStateException(ioe.getMessage());
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    87
        }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    88
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    89
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    90
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    91
     * Creates a recording stream using settings from a configuration.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    92
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    93
     * The following example shows how to create a recording stream that uses a
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    94
     * predefined configuration.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    95
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    96
     * <pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    97
     * <code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    98
     * Configuration c = Configuration.getConfiguration("default");
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
    99
     * try (RecordingStream  r = new RecordingStream(c)) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   100
     *   r.onEvent(System.out::println);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   101
     *   r.start();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   102
     * }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   103
     * </code>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   104
     * </pre>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   105
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   106
     * @param configuration configuration that contains the settings to be use,
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   107
     *        not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   108
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   109
     * @throws IllegalStateException if Flight Recorder can't be created (for
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   110
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   111
     *         support, or if the file repository can't be created or accessed)
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   112
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   113
     * @throws SecurityException if a security manager is used and
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   114
     *         FlightRecorderPermission "accessFlightRecorder" is not set.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   115
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   116
     * @see Configuration
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   117
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   118
    public RecordingStream(Configuration configuration) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   119
        this();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   120
        recording.setSettings(configuration.getSettings());
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   121
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   122
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   123
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   124
     * Enables the event with the specified name.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   125
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   126
     * If multiple events have the same name (for example, the same class is
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   127
     * loaded in different class loaders), then all events that match the name
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   128
     * are enabled. To enable a specific class, use the {@link #enable(Class)}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   129
     * method or a {@code String} representation of the event type ID.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   130
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   131
     * @param name the settings for the event, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   132
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   133
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   134
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   135
     * @see EventType
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   136
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   137
    public EventSettings enable(String name) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   138
        return recording.enable(name);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   139
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   140
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   141
    /**
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   142
     * Replaces all settings for this recording stream
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   143
     * <p>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   144
     * The following example shows how to set event settings for a recording.
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   145
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   146
     * <pre>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   147
     * <code>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   148
     *     Map{@literal <}String, String{@literal >} settings = new HashMap{@literal <}{@literal >}();
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   149
     *     settings.putAll(EventSettings.enabled("jdk.CPUSample").withPeriod(Duration.ofSeconds(2)).toMap());
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   150
     *     settings.putAll(EventSettings.enabled(MyEvent.class).withThreshold(Duration.ofSeconds(2)).withoutStackTrace().toMap());
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   151
     *     settings.put("jdk.ExecutionSample#period", "10 ms");
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   152
     *     recordingStream.setSettings(settings);
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   153
     * </code>
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
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   156
     * The following example shows how to merge settings.
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   157
     *
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   158
     * <pre>
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   159
     *     {@code
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   160
     *     Map<String, String> settings = recording.getSettings();
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   161
     *     settings.putAll(additionalSettings);
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   162
     *     recordingStream.setSettings(settings);
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   163
     * }
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   164
     * </pre>
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
     * @param settings the settings to set, not {@code null}
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   167
     */
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   168
    public void setSettings(Map<String, String> settings) {
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   169
        recording.setSettings(settings);
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57380
diff changeset
   170
    };
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
    /**
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   173
     * Enables event.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   174
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   175
     * @param eventClass the event to enable, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   176
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   177
     * @throws IllegalArgumentException if {@code eventClass} is an abstract
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   178
     *         class or not a subclass of {@link Event}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   179
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   180
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   181
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   182
    public EventSettings enable(Class<? extends Event> eventClass) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   183
        return recording.enable(eventClass);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   184
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   185
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   186
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   187
     * Disables event with the specified name.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   188
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   189
     * If multiple events with same name (for example, the same class is loaded
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   190
     * in different class loaders), then all events that match the name is
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   191
     * disabled. To disable a specific class, use the {@link #disable(Class)}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   192
     * method or a {@code String} representation of the event type ID.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   193
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   194
     * @param name the settings for the event, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   195
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   196
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   197
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   198
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   199
    public EventSettings disable(String name) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   200
        return recording.disable(name);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   201
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   202
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   203
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   204
     * Disables event.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   205
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   206
     * @param eventClass the event to enable, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   207
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   208
     * @throws IllegalArgumentException if {@code eventClass} is an abstract
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   209
     *         class or not a subclass of {@link Event}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   210
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   211
     * @return an event setting for further configuration, not {@code null}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   212
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   213
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   214
    public EventSettings disable(Class<? extends Event> eventClass) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   215
        return recording.disable(eventClass);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   216
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   217
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   218
     * Determines how far back data is kept for the stream if the stream can't
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   219
     * keep up.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   220
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   221
     * To control the amount of recording data stored on disk, the maximum
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   222
     * length of time to retain the data can be specified. Data stored on disk
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   223
     * that is older than the specified length of time is removed by the Java
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   224
     * Virtual Machine (JVM).
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   225
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   226
     * If neither maximum limit or the maximum age is set, the size of the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   227
     * recording may grow indefinitely if events are on
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   228
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   229
     * @param maxAge the length of time that data is kept, or {@code null} if
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   230
     *        infinite
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   231
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   232
     * @throws IllegalArgumentException if <code>maxAge</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   233
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   234
     * @throws IllegalStateException if the recording is in the {@code CLOSED}
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   235
     *         state
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   236
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   237
    public void setMaxAge(Duration maxAge) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   238
        recording.setMaxAge(maxAge);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   239
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   240
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   241
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   242
     * Determines how much data is kept in the disk repository if the stream
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   243
     * can't keep up.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   244
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   245
     * To control the amount of recording data that is stored on disk, the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   246
     * maximum amount of data to retain can be specified. When the maximum limit
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   247
     * is exceeded, the Java Virtual Machine (JVM) removes the oldest chunk to
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   248
     * make room for a more recent chunk.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   249
     * <p>
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   250
     * If neither maximum limit or the maximum age is set, the size of the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   251
     * recording may grow indefinitely.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   252
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   253
     * @param maxSize the amount of data to retain, {@code 0} if infinite
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   254
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   255
     * @throws IllegalArgumentException if <code>maxSize</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   256
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   257
     * @throws IllegalStateException if the recording is in {@code CLOSED} state
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   258
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   259
    public void setMaxSize(long maxSize) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   260
        recording.setMaxSize(maxSize);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   261
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   262
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   263
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   264
    public void onEvent(String eventName, Consumer<RecordedEvent> action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   265
        stream.onEvent(eventName, action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   266
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   267
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   268
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   269
    public void onEvent(Consumer<RecordedEvent> action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   270
        stream.onEvent(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   271
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   272
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   273
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   274
    public void onFlush(Runnable action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   275
        stream.onFlush(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   276
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   277
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   278
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   279
    public void onClose(Runnable action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   280
        stream.onClose(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   281
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   282
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   283
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   284
    public void close() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   285
        recording.close();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   286
        stream.close();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   287
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   288
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   289
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   290
    public boolean remove(Object action) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   291
        return stream.remove(action);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   292
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   293
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   294
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   295
    public void start() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   296
        PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   297
        long startNanos = pr.start();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   298
        stream.start(startNanos);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   299
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   300
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   301
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   302
    public void startAsync() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   303
        PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   304
        long startNanos = pr.start();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   305
        stream.startAsync(startNanos);
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 awaitTermination(Duration timeout) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   310
        stream.awaitTermination(timeout);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   311
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   312
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   313
    /**
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   314
     * Determines how often events are made available for streaming.
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   315
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   316
     * @param interval the interval at which events are made available to the
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   317
     *        stream
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   318
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   319
     * @throws IllegalArgumentException if <code>interval</code> is negative
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   320
     *
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   321
     * @throws IllegalStateException if the stream is closed
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   322
     */
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   323
    public void setInterval(Duration duration) {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   324
        recording.setFlushInterval(duration);
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   325
    }
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   326
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   327
    @Override
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   328
    public void awaitTermination() {
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   329
        stream.awaitTermination();
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   330
    }
57376
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   331
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   332
    @Override
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   333
    public void setReuse(boolean reuse) {
57380
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   334
        throw new UnsupportedOperationException("Unordered not implemented yet");
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   335
    }
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   336
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   337
    @Override
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   338
    public void setOrdered(boolean ordered) {
6a7e7743b82f setOrdered and setReuse implemented for file stream, incl. unit tests
egahlin
parents: 57376
diff changeset
   339
        stream.setOrdered(ordered);
57376
8e8a06a3059c Add foundation for event object reuse
egahlin
parents: 57361
diff changeset
   340
    }
57361
53dccc90a5be Preview-addendum
mgronlun
parents:
diff changeset
   341
}