/************************************************************************ * * OutputFile.java * * Copyright: 2002-2015 by Henrik Just * * This file is part of Writer2LaTeX. * * Writer2LaTeX is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Writer2LaTeX 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Writer2LaTeX. If not, see . * * Version 1.6 (2015-05-05) * */ package writer2latex.api; import java.io.OutputStream; import java.io.IOException; /** An OutputFile represents a single file in a * {@link ConverterResult}, which is output from a {@link Converter} * implementation. */ public interface OutputFile { /** Writes the OutputFile to an OutputStream. * * @param os OutputStream to which the content should be written * @throws IOException if any I/O error occurs */ public void write(OutputStream os) throws IOException; /** Returns the file name of the OutputFile. This includes * the file extension and may also include a relative path, always using * / as separator. * * @return the file name of this OutputFile */ public String getFileName(); /** Get the MIME type of the OutputFile. * * @return string representation of the MIME type */ public String getMIMEType(); /** Test whether this document is part of the main document flow (master documents) or * an auxiliary document * * @return true if this document is a master document */ public boolean isMasterDocument(); /** Test whether this document contains mathematical formulas * * @return true if the document contains formulas */ public boolean containsMath(); }