src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/RecordingInput.java
author egahlin
Tue, 13 Aug 2019 03:58:29 +0200
branchJEP-349-branch
changeset 57717 4ce66d271065
parent 57690 9316d02dd4a5
child 58197 0ef79bd7fb5c
permissions -rw-r--r--
Security handling, but two tests fails with driver
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
     2
 * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
50113
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.internal.consumer;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
import java.io.DataInput;
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.io.RandomAccessFile;
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
    33
import java.nio.file.Path;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
public final class RecordingInput implements DataInput, AutoCloseable {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
57466
faf3a3b0bab6 Reduce RecordingInput cache size
egahlin
parents: 57454
diff changeset
    37
    private final static int DEFAULT_BLOCK_SIZE = 64_000;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
    private static final class Block {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
        private byte[] bytes = new byte[0];
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
        private long blockPosition;
57452
6fabe73e5d9a Reduced allocation pressure. Fix getValue for startTime and duration
egahlin
parents: 57425
diff changeset
    42
        private long blockPositionEnd;
6fabe73e5d9a Reduced allocation pressure. Fix getValue for startTime and duration
egahlin
parents: 57425
diff changeset
    43
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
        boolean contains(long position) {
57452
6fabe73e5d9a Reduced allocation pressure. Fix getValue for startTime and duration
egahlin
parents: 57425
diff changeset
    45
            return position >= blockPosition && position < blockPositionEnd;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
        public void read(RandomAccessFile file, int amount) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
            blockPosition = file.getFilePointer();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
            // reuse byte array, if possible
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
    51
            if (amount > bytes.length) {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
                bytes = new byte[amount];
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
            }
57452
6fabe73e5d9a Reduced allocation pressure. Fix getValue for startTime and duration
egahlin
parents: 57425
diff changeset
    54
            this.blockPositionEnd = blockPosition + amount;
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
    55
            file.readFully(bytes, 0, amount);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
        public byte get(long position) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
            return bytes[(int) (position - blockPosition)];
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
        }
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
    61
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
    62
        public void reset() {
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
    63
            blockPosition = 0;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
    64
            blockPositionEnd = 0;
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
    65
        }
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
    }
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    67
    private final int blockSize;
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    68
    private final FileAccess fileAccess;
57425
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    69
    private RandomAccessFile file;
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    70
    private String filename;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    71
    private Block currentBlock = new Block();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    72
    private Block previousBlock = new Block();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    73
    private long position;
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
    74
    private long size = -1; // Fail fast if setSize(...) has not been called
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
    75
                            // before parsing
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    77
    public RecordingInput(File f, FileAccess fileAccess, int blockSize) throws IOException {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
        this.blockSize = blockSize;
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    79
        this.fileAccess = fileAccess;
57425
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    80
        initialize(f);
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    81
    }
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    82
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    83
    private void initialize(File f) throws IOException {
57717
4ce66d271065 Security handling, but two tests fails with driver
egahlin
parents: 57690
diff changeset
    84
        this.filename = fileAccess.getAbsolutePath(f);
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    85
        this.file = fileAccess.openRAF(f, "r");
57425
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    86
        this.position = 0;
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    87
        this.size = -1;
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
    88
        this.currentBlock.reset();
57717
4ce66d271065 Security handling, but two tests fails with driver
egahlin
parents: 57690
diff changeset
    89
        previousBlock.reset();
4ce66d271065 Security handling, but two tests fails with driver
egahlin
parents: 57690
diff changeset
    90
        if (fileAccess.length(f) < 8) {
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
    91
            throw new IOException("Not a valid Flight Recorder file. File length is only " + f.length() + " bytes.");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
57690
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    95
    public RecordingInput(File f, FileAccess fileAccess) throws IOException {
9316d02dd4a5 Add EventStream::setEndTime(...) and a first stab at priviliged access to local repository
egahlin
parents: 57466
diff changeset
    96
        this(f, fileAccess, DEFAULT_BLOCK_SIZE);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
    }
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
    98
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
    99
    public void positionPhysical(long position) throws IOException {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   100
        file.seek(position);
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   101
    }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   102
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   103
    public final byte readPhysicalByte() throws IOException {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   104
        return file.readByte();
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   105
    }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   106
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   107
    public long readPhysicalLong() throws IOException {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   108
        return file.readLong();
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   109
    }
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
    public final byte readByte() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
        if (!currentBlock.contains(position)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
            position(position);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
        return currentBlock.get(position++);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
    public final void readFully(byte[] dest, int offset, int length) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
        // TODO: Optimize, use Arrays.copy if all bytes are in current block
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
        // array
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
        for (int i = 0; i < length; i++) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
            dest[i + offset] = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   126
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
    public final void readFully(byte[] dst) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
        readFully(dst, 0, dst.length);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
    public final short readRawShort() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   134
        // copied from java.io.Bits
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
        byte b0 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
        byte b1 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
        return (short) ((b1 & 0xFF) + (b0 << 8));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
    public final double readDouble() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
        // copied from java.io.Bits
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
        return Double.longBitsToDouble(readRawLong());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   145
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
    public final float readFloat() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
        // copied from java.io.Bits
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
        return Float.intBitsToFloat(readRawInt());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
    public final int readRawInt() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
        // copied from java.io.Bits
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
        byte b0 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
        byte b1 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
        byte b2 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   157
        byte b3 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
        return ((b3 & 0xFF)) + ((b2 & 0xFF) << 8) + ((b1 & 0xFF) << 16) + ((b0) << 24);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   161
    public final long readRawLong() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   162
        // copied from java.io.Bits
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   163
        byte b0 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   164
        byte b1 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
        byte b2 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
        byte b3 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
        byte b4 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
        byte b5 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
        byte b6 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
        byte b7 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   171
        return ((b7 & 0xFFL)) + ((b6 & 0xFFL) << 8) + ((b5 & 0xFFL) << 16) + ((b4 & 0xFFL) << 24) + ((b3 & 0xFFL) << 32) + ((b2 & 0xFFL) << 40) + ((b1 & 0xFFL) << 48) + (((long) b0) << 56);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   173
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   174
    public final long position() {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
        return position;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
    public final void position(long newPosition) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
        if (!currentBlock.contains(newPosition)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
            if (!previousBlock.contains(newPosition)) {
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   181
                if (newPosition > size) {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   182
                    throw new EOFException("Trying to read at " + newPosition + ", but file is only " + size + " bytes.");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
                long blockStart = trimToFileSize(calculateBlockStart(newPosition));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
                file.seek(blockStart);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   186
                // trim amount to file size
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   187
                long amount = Math.min(size - blockStart, blockSize);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   188
                previousBlock.read(file, (int) amount);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   189
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   190
            // swap previous and current
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   191
            Block tmp = currentBlock;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   192
            currentBlock = previousBlock;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   193
            previousBlock = tmp;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   194
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   195
        position = newPosition;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   196
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   197
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   198
    private final long trimToFileSize(long position) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   199
        return Math.min(size(), Math.max(0, position));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   200
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   201
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   202
    private final long calculateBlockStart(long newPosition) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   203
        // align to end of current block
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   204
        if (currentBlock.contains(newPosition - blockSize)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   205
            return currentBlock.blockPosition + currentBlock.bytes.length;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   206
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   207
        // align before current block
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   208
        if (currentBlock.contains(newPosition + blockSize)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   209
            return currentBlock.blockPosition - blockSize;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   210
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   211
        // not near current block, pick middle
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   212
        return newPosition - blockSize / 2;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   213
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   214
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   215
    public final long size() {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   216
        return size;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   217
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   218
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   219
    public final void close() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   220
        file.close();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   221
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   222
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   223
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   224
    public final int skipBytes(int n) throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   225
        long position = position();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   226
        position(position + n);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   227
        return (int) (position() - position);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   228
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   229
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   230
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   231
    public final boolean readBoolean() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   232
        return readByte() != 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   233
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   234
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   235
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   236
    public int readUnsignedByte() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   237
        return readByte() & 0x00FF;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   238
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   239
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   240
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   241
    public int readUnsignedShort() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   242
        return readShort() & 0xFFFF;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   243
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   244
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   245
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   246
    public final String readLine() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   247
        throw new UnsupportedOperationException();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   248
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   249
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   250
    // NOTE, this method should really be called readString
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   251
    // but can't be renamed without making RecordingInput a
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   252
    // public class.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   253
    //
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   254
    // This method DOES Not read as expected (s2 + utf8 encoded character)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   255
    // instead it read:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   256
    // byte encoding
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   257
    // int size
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   258
    // data (byte or char)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   259
    //
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   260
    // where encoding
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   261
    //
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   262
    // 0, means null
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   263
    // 1, means UTF8 encoded byte array
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   264
    // 2, means char array
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   265
    // 3, means latin-1 (ISO-8859-1) encoded byte array
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   266
    // 4, means ""
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   267
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   268
    public String readUTF() throws IOException {
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   269
        throw new UnsupportedOperationException("Use StringParser");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   270
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   271
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   272
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   273
    public char readChar() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   274
        return (char) readLong();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   275
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   276
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   277
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   278
    public short readShort() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   279
        return (short) readLong();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   280
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   281
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   282
    @Override
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   283
    public int readInt() throws IOException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   284
        return (int) readLong();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   285
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   286
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   287
    public long readLongExpanded() throws IOException {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   288
        final byte[] bytes = currentBlock.bytes;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   289
        final int index = (int) (position - currentBlock.blockPosition);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   290
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   291
        if (index + 8 < bytes.length && index >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   292
            byte b0 = bytes[index];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   293
            if (b0 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   294
                position += 1;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   295
                return (b0 & 0x7FL);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   296
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   297
            int b1 = bytes[index + 1];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   298
            if (b1 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   299
                position += 2;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   300
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   301
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   302
            int b2 = bytes[index + 2];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   303
            if (b2 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   304
                position += 3;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   305
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   306
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   307
            int b3 = bytes[index + 3];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   308
            if (b3 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   309
                position += 4;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   310
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14) + ((b3 & 0x7FL) << 21);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   311
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   312
            int b4 = bytes[index + 4];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   313
            if (b4 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   314
                position += 5;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   315
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   316
                       ((b3 & 0x7FL) << 21) + ((b4 & 0x7FL) << 28);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   317
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   318
            int b5 = bytes[index + 5];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   319
            if (b5 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   320
                position += 6;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   321
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   322
                       ((b3 & 0x7FL) << 21) + ((b4 & 0x7FL) << 28) + ((b5 & 0x7FL) << 35);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   323
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   324
            int b6 = bytes[index + 6];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   325
            if (b6 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   326
                position += 7;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   327
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   328
                       ((b3 & 0x7FL) << 21) + ((b4 & 0x7FL) << 28) + ((b5 & 0x7FL) << 35) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   329
                       ((b6 & 0x7FL) << 42);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   330
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   331
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   332
            int b7 = bytes[index + 7];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   333
            if (b7 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   334
                position += 8;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   335
                return (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   336
                       ((b3 & 0x7FL) << 21) + ((b4 & 0x7FL) << 28) + ((b5 & 0x7FL) << 35) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   337
                       ((b6 & 0x7FL) << 42) + ((b7 & 0x7FL) << 49);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   338
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   339
            int b8 = bytes[index + 8];// read last byte raw
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   340
            position += 9;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   341
            long ret = (b0 & 0x7FL) + ((b1 & 0x7FL) << 7) + ((b2 & 0x7FL) << 14) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   342
                   ((b3 & 0x7FL) << 21) + ((b4 & 0x7FL) << 28) + ((b5 & 0x7FL) << 35) +
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   343
                   ((b6 & 0x7FL) << 42) + ((b7 & 0x7FL) << 49);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   344
            return ret + ((((long) (b8 & 0XFF)) << 56));
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   345
        } else {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   346
            return readLongSlow();
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   347
        }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   348
    }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   349
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   350
    public long readLong() throws IOException {
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   351
        final byte[] bytes = currentBlock.bytes;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   352
        final int index = (int) (position - currentBlock.blockPosition);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   353
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   354
        if (index + 8 < bytes.length && index >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   355
            byte b0 = bytes[index];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   356
            long ret = (b0 & 0x7FL);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   357
            if (b0 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   358
                position += 1;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   359
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   360
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   361
            int b1 = bytes[index + 1];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   362
            ret += (b1 & 0x7FL) << 7;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   363
            if (b1 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   364
                position += 2;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   365
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   366
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   367
            int b2 = bytes[index + 2];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   368
            ret += (b2 & 0x7FL) << 14;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   369
            if (b2 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   370
                position += 3;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   371
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   372
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   373
            int b3 = bytes[index + 3];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   374
            ret += (b3 & 0x7FL) << 21;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   375
            if (b3 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   376
                position += 4;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   377
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   378
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   379
            int b4 = bytes[index + 4];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   380
            ret += (b4 & 0x7FL) << 28;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   381
            if (b4 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   382
                position += 5;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   383
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   384
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   385
            int b5 = bytes[index + 5];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   386
            ret += (b5 & 0x7FL) << 35;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   387
            if (b5 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   388
                position += 6;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   389
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   390
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   391
            int b6 = bytes[index + 6];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   392
            ret += (b6 & 0x7FL) << 42;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   393
            if (b6 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   394
                position += 7;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   395
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   396
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   397
            int b7 = bytes[index + 7];
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   398
            ret += (b7 & 0x7FL) << 49;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   399
            if (b7 >= 0) {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   400
                position += 8;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   401
                return ret;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   402
            }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   403
            int b8 = bytes[index + 8];// read last byte raw
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   404
            position += 9;
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   405
            return ret + (((long) (b8 & 0XFF)) << 56);
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   406
        } else {
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   407
            return readLongSlow();
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   408
        }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   409
    }
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   410
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   411
    private long readLongSlow() throws IOException {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   412
        byte b0 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   413
        long ret = (b0 & 0x7FL);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   414
        if (b0 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   415
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   416
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   417
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   418
        int b1 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   419
        ret += (b1 & 0x7FL) << 7;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   420
        if (b1 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   421
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   422
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   423
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   424
        int b2 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   425
        ret += (b2 & 0x7FL) << 14;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   426
        if (b2 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   427
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   428
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   429
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   430
        int b3 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   431
        ret += (b3 & 0x7FL) << 21;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   432
        if (b3 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   433
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   434
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   435
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   436
        int b4 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   437
        ret += (b4 & 0x7FL) << 28;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   438
        if (b4 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   439
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   440
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   441
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   442
        int b5 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   443
        ret += (b5 & 0x7FL) << 35;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   444
        if (b5 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   445
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   446
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   447
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   448
        int b6 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   449
        ret += (b6 & 0x7FL) << 42;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   450
        if (b6 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   451
            return ret;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   452
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   453
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   454
        int b7 = readByte();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   455
        ret += (b7 & 0x7FL) << 49;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   456
        if (b7 >= 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   457
            return ret;
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   458
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   459
        }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   460
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   461
        int b8 = readByte(); // read last byte raw
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   462
        return ret + (((long) (b8 & 0XFF)) << 56);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   463
    }
57360
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   464
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   465
    public void setValidSize(long size) {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   466
        if (size > this.size) {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   467
            this.size = size;
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   468
        }
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   469
    }
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   470
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   471
    public long getFileSize() throws IOException {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   472
        return file.length();
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   473
    }
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   474
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   475
    public String getFilename() {
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   476
        return filename;
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   477
    }
5d043a159d5c Preview
egahlin
parents: 50113
diff changeset
   478
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   479
    // Purpose of this method is to reuse block cache from a
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   480
    // previous RecordingInput
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   481
    public void setFile(Path path) throws IOException {
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   482
        try {
57425
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
   483
            file.close();
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   484
        } catch (IOException e) {
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   485
            // perhaps deleted
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   486
        }
57425
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
   487
        file = null;
1da8552f0b59 Use one parser per recording stream / thread
egahlin
parents: 57386
diff changeset
   488
        initialize(path.toFile());
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   489
    }
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   490
/*
57386
acdd0dbe37ee First parts of unshared parser + updated javadoc
egahlin
parents: 57360
diff changeset
   491
57454
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   492
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   493
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   494
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   495
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   496
 *
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   497
 *
703fb247dc4e Improve reading long values
egahlin
parents: 57452
diff changeset
   498
 */
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   499
}