src/jdk.jfr/share/classes/jdk/jfr/consumer/RecordingFile.java
author egahlin
Wed, 05 Dec 2018 16:40:12 +0100
changeset 52850 f527b24990d7
parent 50113 caf115bb98ad
child 57360 5d043a159d5c
child 58863 c16ac7a2eba4
permissions -rw-r--r--
8205516: JFR tool Reviewed-by: mgronlun
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     2
 * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     4
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    10
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    15
 * accompanied this code).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    16
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    20
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    23
 * questions.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    24
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    25
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    26
package jdk.jfr.consumer;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
import java.io.Closeable;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
import java.io.EOFException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
import java.io.File;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
import java.io.IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
import java.nio.file.NoSuchFileException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    33
import java.nio.file.Path;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
import java.util.ArrayList;
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    35
import java.util.Collections;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
import java.util.HashSet;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
import java.util.List;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
import jdk.jfr.EventType;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
import jdk.jfr.internal.MetadataDescriptor;
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    41
import jdk.jfr.internal.Type;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
import jdk.jfr.internal.consumer.ChunkHeader;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
import jdk.jfr.internal.consumer.RecordingInput;
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    44
import jdk.jfr.internal.consumer.RecordingInternals;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
/**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
 * A recording file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
 * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
 * The following example shows how read and print all events in a recording file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
 * <pre>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
 * <code>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
 * try (RecordingFile recordingFile = new RecordingFile(Paths.get("recording.jfr"))) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
 *   while (recordingFile.hasMoreEvents()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
 *     RecordedEvent event = recordingFile.readEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
 *     System.out.println(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
 *   }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
 * }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
 * </code>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
 * </pre>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
 * @since 9
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    63
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
public final class RecordingFile implements Closeable {
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    65
    static{
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    66
        RecordingInternals.INSTANCE = new RecordingInternals() {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    67
            public List<Type> readTypes(RecordingFile file) throws IOException {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    68
                return file.readTypes();
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    69
            }
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    71
            public boolean isLastEventInChunk(RecordingFile file) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    72
                return file.isLastEventInChunk;
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    73
            }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    74
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    75
            @Override
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    76
            public Object getOffsetDataTime(RecordedObject event, String name) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    77
                return event.getOffsetDateTime(name);
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    78
            }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    79
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    80
            @Override
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    81
            public void sort(List<RecordedEvent> events) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    82
               Collections.sort(events, (e1, e2) -> Long.compare(e1.endTime, e2.endTime));
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    83
            }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    84
        };
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    85
    }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    86
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
    87
    private boolean isLastEventInChunk;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
    private final File file;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
    private RecordingInput input;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    90
    private ChunkParser chunkParser;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
    private RecordedEvent nextEvent;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
    private boolean eof;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
     * Creates a recording file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
     * @param file the path of the file to open, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
     * @throws IOException if it's not a valid recording file, or an I/O error
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
     *         occurred
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
     * @throws NoSuchFileException if the {@code file} can't be located
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   101
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
     * @throws SecurityException if a security manager exists and its
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
     *         {@code checkRead} method denies read access to the file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   105
    public RecordingFile(Path file) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   106
        this.file = file.toFile();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   107
        this.input = new RecordingInput(this.file);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   108
        findNext();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
     * Reads the next event in the recording.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
     * @return the next event, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
     * @throws EOFException if no more events exist in the recording file
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
     * @throws IOException if an I/O error occurs.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
     * @see #hasMoreEvents()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
    public RecordedEvent readEvent() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
        if (eof) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
            ensureOpen();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
            throw new EOFException();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
        }
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   126
        isLastEventInChunk = false;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
        RecordedEvent event = nextEvent;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
        nextEvent = chunkParser.readEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
        if (nextEvent == null) {
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   130
            isLastEventInChunk = true;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
            findNext();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
        return event;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   134
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
     * Returns {@code true} if unread events exist in the recording file,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
     * {@code false} otherwise.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
     * @return {@code true} if unread events exist in the recording, {@code false}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
     *         otherwise.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
    public boolean hasMoreEvents() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
        return !eof;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   145
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
     * Returns a list of all event types in this recording.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
     * @return a list of event types, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
     * @throws IOException if an I/O error occurred while reading from the file
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
     * @see #hasMoreEvents()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
    public List<EventType> readEventTypes() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
        ensureOpen();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   157
        List<EventType> types = new ArrayList<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
        HashSet<Long> foundIds = new HashSet<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
        try (RecordingInput ri = new RecordingInput(file)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
            ChunkHeader ch = new ChunkHeader(ri);
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   161
            aggregateEventTypeForChunk(ch, types, foundIds);
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   162
            while (!ch.isLastChunk()) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   163
                ch = ch.nextHeader();
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   164
                aggregateEventTypeForChunk(ch, types, foundIds);
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   165
            }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   166
        }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   167
        return types;
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   168
    }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   169
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   170
    List<Type> readTypes() throws IOException  {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   171
        ensureOpen();
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   172
        List<Type> types = new ArrayList<>();
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   173
        HashSet<Long> foundIds = new HashSet<>();
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   174
        try (RecordingInput ri = new RecordingInput(file)) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   175
            ChunkHeader ch = new ChunkHeader(ri);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
            aggregateTypeForChunk(ch, types, foundIds);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
            while (!ch.isLastChunk()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
                ch = ch.nextHeader();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
                aggregateTypeForChunk(ch, types, foundIds);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   182
        return types;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
52850
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   185
    private void aggregateTypeForChunk(ChunkHeader ch, List<Type> types, HashSet<Long> foundIds) throws IOException {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   186
        MetadataDescriptor m = ch.readMetadata();
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   187
        for (Type t : m.getTypes()) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   188
            if (!foundIds.contains(t.getId())) {
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   189
                types.add(t);
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   190
                foundIds.add(t.getId());
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   191
            }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   192
        }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   193
    }
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   194
f527b24990d7 8205516: JFR tool
egahlin
parents: 50113
diff changeset
   195
    private static void aggregateEventTypeForChunk(ChunkHeader ch, List<EventType> types, HashSet<Long> foundIds) throws IOException {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   196
        MetadataDescriptor m = ch.readMetadata();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   197
        for (EventType t : m.getEventTypes()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   198
            if (!foundIds.contains(t.getId())) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   199
                types.add(t);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   200
                foundIds.add(t.getId());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   201
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   202
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   203
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   204
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   205
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   206
     * Closes this recording file and releases any system resources that are
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   207
     * associated with it.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   208
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   209
     * @throws IOException if an I/O error occurred
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   210
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   211
    public void close() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   212
        if (input != null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   213
            eof = true;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   214
            input.close();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   215
            chunkParser = null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   216
            input = null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   217
            nextEvent = null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   218
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   219
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   220
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   221
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   222
     * Returns a list of all events in a file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   223
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   224
     * This method is intended for simple cases where it's convenient to read all
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   225
     * events in a single operation. It isn't intended for reading large files.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   226
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   227
     * @param path the path to the file, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   228
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   229
     * @return the events from the file as a {@code List} object; whether the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   230
     *         {@code List} is modifiable or not is implementation dependent and
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   231
     *         therefore not specified, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   232
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   233
     * @throws IOException if an I/O error occurred, it's not a Flight Recorder
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   234
     *         file or a version of a JFR file that can't be parsed
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   235
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   236
     * @throws SecurityException if a security manager exists and its
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   237
     *         {@code checkRead} method denies read access to the file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   238
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   239
    public static List<RecordedEvent> readAllEvents(Path path) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   240
        try (RecordingFile r = new RecordingFile(path)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   241
            List<RecordedEvent> list = new ArrayList<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   242
            while (r.hasMoreEvents()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   243
                list.add(r.readEvent());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   244
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   245
            return list;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   246
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   247
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   248
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   249
    // either sets next to an event or sets eof to true
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   250
    private void findNext() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   251
        while (nextEvent == null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   252
            if (chunkParser == null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   253
                chunkParser = new ChunkParser(input);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   254
            } else if (!chunkParser.isLastChunk()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   255
                chunkParser = chunkParser.nextChunkParser();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   256
            } else {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   257
                eof = true;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   258
                return;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   259
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   260
            nextEvent = chunkParser.readEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   261
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   262
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   263
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   264
    private void ensureOpen() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   265
        if (input == null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   266
            throw new IOException("Stream Closed");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   267
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   268
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   269
}