All Downloads are FREE. Search and download functionalities are using the official Maven repository.

fiftyone.common.wrappers.data.BinaryReader Maven / Gradle / Ivy

The newest version!
/* *********************************************************************
 * This Original Work is copyright of 51 Degrees Mobile Experts Limited.
 * Copyright 2023 51 Degrees Mobile Experts Limited, Davidson House,
 * Forbury Square, Reading, Berkshire, United Kingdom RG1 3EU.
 *
 * This Original Work is licensed under the European Union Public Licence
 * (EUPL) v.1.2 and is subject to its terms as set out below.
 *
 * If a copy of the EUPL was not distributed with this file, You can obtain
 * one at https://opensource.org/licenses/EUPL-1.2.
 *
 * The 'Compatible Licences' set out in the Appendix to the EUPL (as may be
 * amended by the European Commission) shall be deemed incompatible for
 * the purposes of the Work and the provisions of the compatibility
 * clause in Article 5 of the EUPL shall not apply.
 *
 * If using the Work as, or as part of, a network application, by
 * including the attribution notice(s) required under Article 5 of the EUPL
 * in the end user terms of the application under an appropriate heading,
 * such notice(s) shall fulfill the requirements of that article.
 * ********************************************************************* */

package fiftyone.common.wrappers.data;

import java.io.Closeable;
import java.io.FileInputStream;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.nio.channels.FileChannel;
import java.nio.channels.FileChannel.MapMode;

public class BinaryReader implements Closeable {

    private final FileChannel channel;
    private ByteBuffer byteBuffer;

    public BinaryReader(FileInputStream fileInputStream) throws IOException {
        channel = fileInputStream.getChannel();
        byteBuffer = channel.map(
            MapMode.READ_ONLY,
            0,
            channel.size());
        byteBuffer.order(ByteOrder.LITTLE_ENDIAN);
    }

    public BinaryReader(ByteBuffer byteBuffer) {
        this.byteBuffer = byteBuffer;
        this.byteBuffer.order(ByteOrder.LITTLE_ENDIAN);
        channel = null;
    }

    public long getSize() {
        return byteBuffer.limit();
    }

    public ByteBuffer getBuffer() {
        return byteBuffer;
    }

    public int getPosition() {
        return byteBuffer.position();
    }

    public void setPosition(int position) {
        byteBuffer.position(position);
    }

    public float readFloat() {
        return byteBuffer.getFloat();
    }

    public short readInt16() {
        return byteBuffer.getShort();
    }

    public int readInt32() {
        return byteBuffer.getInt();
    }

    public long readInt64() {
        return byteBuffer.getLong();
    }

    public String readLine() {
        char c;
        boolean read = false;
        StringBuilder result = new StringBuilder();
        while (getPosition() < getSize() && (c = (char)byteBuffer.get()) != '\n') {
            if (read == false) {
                read = true;
            }
            if (c != '\r') {
                result.append(c);
            }
        }
        return read == true ? result.toString() : null;
    }

    public byte[] readBytes(final int length) {
        byte[] bytes = new byte[length];
        byteBuffer.get(bytes);
        return bytes;
    }

    public byte[] toByteArray() {
        ByteBuffer result = ByteBuffer.allocate((int) getSize());
        // https://www.morling.dev/blog/bytebuffer-and-the-dreaded-nosuchmethoderror/
        ((java.nio.Buffer)byteBuffer).position(0);
        result.put(byteBuffer);
        return result.array();
    }

    public void copyTo(BinaryWriter writer) throws IOException {
        writer.writeBytes(toByteArray());
    }

    public byte readByte() {
        return byteBuffer.get();
    }

    /**
     * Set the byte buffer to null to prevent any further access to the under
     * lying data. This should be done before the channel is closed as the
     * byte buffer could be tied to the channel. Any subsequent access to the
     * methods will fail with a null object exception.
     */
    @Override
    public void close() {
        byteBuffer = null;
        if (channel != null) {
            try {
                channel.close();
            } catch (IOException ex) {
                // Do nothing.
            }
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy