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

oms3.compiler.MemoryOutputJavaFileObject Maven / Gradle / Ivy

/*
 * $Id: MemoryOutputJavaFileObject.java 50798ee5e25c 2013-01-09 [email protected] $
 * 
 * This file is part of the Object Modeling System (OMS),
 * 2007-2012, Olaf David and others, Colorado State University.
 *
 * OMS is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, version 2.1.
 *
 * OMS is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with OMS.  If not, see .
 */
package oms3.compiler;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URI;

import javax.tools.SimpleJavaFileObject;

/**
 * A file object that retains contents in memory and does not write
 * out to disk.
 * 
 * @author prunge
 */
public class MemoryOutputJavaFileObject extends SimpleJavaFileObject {

    private ByteArrayOutputStream outputStream;

    /**
     * Constructs a MemoryOutputJavaFileObject.
     *
     * @param uri the URI of the output file.
     * @param kind the file type.
     */
    public MemoryOutputJavaFileObject(URI uri, Kind kind) {
        super(uri, kind);
    }

    /**
     * Opens an output stream to write to the file.  This writes to
     * memory.  This clears any existing output in the file.
     *
     * @return an output stream.
     * 
     * @throws IOException if an I/O error occurs.
     */
    @Override
    public OutputStream openOutputStream() throws IOException {
        outputStream = new ByteArrayOutputStream();
        return outputStream;
    }

    /**
     * Opens an input stream to the file data.  If the file has never
     * been written the input stream will contain no data (i.e. length=0).
     *
     * @return an input stream.
     *
     * @throws IOException if an I/O error occurs.
     */
    @Override
    public InputStream openInputStream() throws IOException {
        if (outputStream != null) {
            return new ByteArrayInputStream(outputStream.toByteArray());
        } else {
            return new ByteArrayInputStream(new byte[0]);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy