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