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

com.sun.star.lib.uno.adapter.XInputStreamToInputStreamAdapter Maven / Gradle / Ivy

There is a newer version: 24.2.3
Show newest version
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
 */
package com.sun.star.lib.uno.adapter;

import java.io.IOException;

import com.sun.star.io.XInputStream;

import java.io.InputStream;

/**
 * The XInputStreamToInputStreamAdapter wraps
 * the UNO XInputStream object in a Java
 * InputStream.  This allows users to access
 * an XInputStream as if it were an
 * InputStream.
 */
public final class XInputStreamToInputStreamAdapter extends InputStream {

    /**
     *  Internal handle to the XInputStream
     */
    private final XInputStream xin;

    /**
     *  Constructor.
     *
     *  @param  in  The XInputStream to be
     *              accessed as an InputStream.
     */
    public XInputStreamToInputStreamAdapter (XInputStream in) {
        xin = in;
    }

    @Override
    public int available() throws IOException {

        int bytesAvail;

        try {
            bytesAvail = xin.available();
        } catch (Exception e) {
            IOException newEx = new IOException(e.getMessage());
            newEx.initCause(e);
            throw newEx;
        }

        return bytesAvail;
    }

    @Override
    public void close() throws IOException {
        try {
            xin.closeInput();
        } catch (Exception e) {
            IOException newEx = new IOException(e.getMessage());
            newEx.initCause(e);
            throw newEx;
        }
    }

    @Override
    public int read () throws IOException {
        byte [][] tmp = new byte [1][1];
        try {
            long bytesRead = xin.readBytes(tmp, 1);

            if (bytesRead <= 0) {
               return (-1);
            } else {
                int tmpInt = tmp[0][0];
                if (tmpInt< 0 ){
                    tmpInt = 256 +tmpInt;
                }
                return tmpInt;
            }

        } catch (Exception e) {
            IOException newEx = new IOException(e.getMessage());
            newEx.initCause(e);
            throw newEx;
        }
    }

    @Override
    public int read (byte[] b) throws IOException {

        byte [][] tmp = new byte [1][b.length];
        int bytesRead;

        try {
            bytesRead = xin.readBytes(tmp, b.length);
            if (bytesRead <= 0) {
                return -1;
            } else if (bytesRead < b.length) {
                System.arraycopy(tmp[0], 0, b, 0, bytesRead);
            } else {
                System.arraycopy(tmp[0], 0, b, 0, b.length);
            }
        } catch (Exception e) {
            IOException newEx = new IOException(e.getMessage());
            newEx.initCause(e);
            throw newEx;
        }

        return bytesRead;
    }

    @Override
    public int read(byte[] b, int off, int len) throws IOException {
        byte [][] tmp = new byte [1][b.length];
        try {
            long bytesRead;
            int av = xin.available();
            if ( av != 0 && len > av) {
                bytesRead = xin.readBytes(tmp, av);
            }
            else{
                bytesRead = xin.readBytes(tmp,len);
            }
            // Casting bytesRead to an int is okay, since the user can
            // only pass in an integer length to read, so the bytesRead
            // must <= len.

            if (bytesRead <= 0) {
                return -1;
            } else if (bytesRead < len) {
                System.arraycopy(tmp[0], 0, b, off, (int)bytesRead);
            } else {
                System.arraycopy(tmp[0], 0, b, off, len);
            }

            return ((int)bytesRead);
        } catch (Exception e) {
            IOException newEx = new IOException(e.getMessage());
            newEx.initCause(e);
            throw newEx;
        }
    }

    @Override
    public long skip(long n) throws IOException {

        int avail;
        long tmpLongVal = n;
        int  tmpIntVal;

        try {
            avail = xin.available();
        } catch (Exception e) {
            IOException newEx = new IOException(e.getMessage());
            newEx.initCause(e);
            throw newEx;
        }

        do {
            if (tmpLongVal >= Integer.MAX_VALUE) {
               tmpIntVal = Integer.MAX_VALUE;
            } else {
               // Casting is safe here.
               tmpIntVal = (int)tmpLongVal;
            }
            tmpLongVal -= tmpIntVal;

            try {
                xin.skipBytes(tmpIntVal);
            } catch (Exception e) {
                IOException newEx = new IOException(e.getMessage());
                newEx.initCause(e);
                throw newEx;
            }
        } while (tmpLongVal > 0);

        if ( avail != 0 && avail < n) {
            return avail;
        } else {
            return n;
        }
    }

   /**
    *  Tests if this input stream supports the mark and reset methods.
    *  The markSupported method of
    *  XInputStreamToInputStreamAdapter returns false.
    *
    *  @return  false
    */
    @Override
    public boolean markSupported() {
       return false;
    }

    @Override
    public synchronized void mark(int readlimit) {
        // Not supported.
    }

    @Override
    public synchronized void reset() throws IOException {
        // Not supported.
    }
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy