/************************************************************************ * * ConverterResultImpl.java * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library 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 this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * Copyright: 2002-2010 by Henrik Just * * All Rights Reserved. * * Version 1.2 (2010-03-28) * */ package writer2latex.base; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.util.Collections; import java.util.List; import java.util.Vector; import java.util.Iterator; import writer2latex.api.ConverterResult; import writer2latex.api.MetaData; import writer2latex.api.OutputFile; import writer2latex.api.ContentEntry; /** ConverterResultImpl is a straightforward implementation of ConverterResult */ public class ConverterResultImpl implements ConverterResult { private List files; private List content; private ContentEntry tocFile; private ContentEntry lofFile; private ContentEntry lotFile; private ContentEntry indexFile; private MetaData metaData = null; private int nMasterCount; /** Construct a new ConverterResultImpl with empty content */ public ConverterResultImpl() { reset(); } /** Resets all data. This empties all OutputFile and ContentEntry objects * objects from this class. This allows reuse of a ConvertResult object. */ public void reset() { files = new Vector(); content = new Vector(); tocFile = null; lofFile = null; lotFile = null; indexFile = null; metaData = null; nMasterCount = 0; } /** Adds an OutputFile to the list * * @param file The OutputFile to add. */ public void addDocument(OutputFile file) { if (file.isMasterDocument()) { files.add(nMasterCount++, file); } else { files.add(file); } } /** Get the first master document * * @return OutputFile the master document */ public OutputFile getMasterDocument() { return files.size()>0 ? files.get(0) : null; } /** * Gets an Iterator to access the List * of OutputFile objects * * @return The Iterator to access the * List of OutputFile objects. */ public Iterator iterator() { return files.iterator(); } /** Add an entry to the "external" table of contents * * @param entry the entry to add */ public void addContentEntry(ContentEntry entry) { content.add(entry); } public List getContent() { return Collections.unmodifiableList(content); } /** Define the entry which contains the table of contents * * @param entry the entry */ public void setTocFile(ContentEntry entry) { tocFile = entry; } public ContentEntry getTocFile() { return tocFile; } /** Define the entry which contains the list of figures * * @param entry the entry */ public void setLofFile(ContentEntry entry) { lofFile = entry; } public ContentEntry getLofFile() { return lofFile; } /** Define the entry which contains the list of tables * * @param entry the entry */ public void setLotFile(ContentEntry entry) { lotFile = entry; } public ContentEntry getLotFile() { return lotFile; } /** Define the entry which contains the alphabetical index * * @param entry the entry */ public void setIndexFile(ContentEntry entry) { indexFile = entry; } public ContentEntry getIndexFile() { return indexFile; } /** Set the meta data of this ConverterResult * * @param metaData the meta data */ public void setMetaData(MetaData metaData) { this.metaData = metaData; } /** Get the meta data of this ConverterResult * * @return the meta data */ public MetaData getMetaData() { return metaData; } /** Write all files to a given directory * * @param dir the directory to use */ public void write(File dir) throws IOException { if (dir!=null && !dir.exists()) throw new IOException("Directory does not exist"); Iterator docEnum = iterator(); while (docEnum.hasNext()) { OutputFile docOut = docEnum.next(); String sDirName = ""; String sFileName = docOut.getFileName(); File subdir = dir; int nSlash = sFileName.indexOf("/"); if (nSlash>-1) { sDirName = sFileName.substring(0,nSlash); sFileName = sFileName.substring(nSlash+1); subdir = new File(dir,sDirName); if (!subdir.exists()) { subdir.mkdir(); } } File outfile = new File (subdir,sFileName); FileOutputStream fos = new FileOutputStream(outfile); docOut.write(fos); fos.flush(); fos.close(); } } }