/************************************************************************ * * BibTeXDocument.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-2014 by Henrik Just * * All Rights Reserved. * * Version 1.6 (2014-11-28) * */ package writer2latex.bibtex; import java.util.Hashtable; import java.util.Enumeration; import java.io.IOException; import java.io.OutputStream; import java.io.OutputStreamWriter; import writer2latex.api.ConverterFactory; import writer2latex.api.MIMETypes; import writer2latex.api.OutputFile; import writer2latex.latex.LaTeXConfig; import writer2latex.latex.i18n.ClassicI18n; import writer2latex.latex.i18n.I18n; import writer2latex.util.ExportNameCollection; import writer2latex.office.BibMark; import writer2latex.office.BibMark.EntryType;; /** *
Class representing a BibTeX document.
* */ public class BibTeXDocument implements OutputFile { private static final String FILE_EXTENSION = ".bib"; private String sName; private HashtableConstructs a new BibTeX Document.
* *This new document is empty. Bibliographic data must added
* using the put
method.
BibTeXDocument
.
*/
public BibTeXDocument(String sName, boolean bIsMaster) {
this.sName = trimDocumentName(sName);
this.bIsMaster = bIsMaster;
// Use default config (only ascii, no extra font packages)
i18n = new ClassicI18n(new LaTeXConfig());
}
/**
* Returns the Document
name with no file extension.
Document
name with no file extension.
*/
public String getName() {
return sName;
}
/**
* Returns the Document
name with file extension.
Document
name with file extension.
*/
public String getFileName() {
return new String(sName + FILE_EXTENSION);
}
public String getMIMEType() {
return MIMETypes.BIBTEX;
}
public boolean isMasterDocument() {
return bIsMaster;
}
/**
* Writes out the Document
content to the specified
* OutputStream
.
This method may not be thread-safe. * Implementations may or may not synchronize this * method. User code (i.e. caller) must make sure that * calls to this method are thread-safe.
* * @param osOutputStream
to write out the
* Document
content.
*
* @throws IOException If any I/O error occurs.
*/
public void write(OutputStream os) throws IOException {
// BibTeX files are plain ascii
OutputStreamWriter osw = new OutputStreamWriter(os,"ASCII");
osw.write("%% This file was converted to BibTeX by Writer2BibTeX ver. "+ConverterFactory.getVersion()+".\n");
osw.write("%% See http://writer2latex.sourceforge.net for more info.\n");
osw.write("\n");
EnumerationAdd an entry
*/ public void put(BibMark entry) { entries.put(entry.getIdentifier(),entry); exportNames.addName(entry.getIdentifier()); } /* *Get export name for an identifier
*/ public String getExportName(String sIdentifier) { return exportNames.getExportName(sIdentifier); } /* * Utility method to make sure the document name is stripped of any file * extensions before use. */ private String trimDocumentName(String name) { String temp = name.toLowerCase(); if (temp.endsWith(FILE_EXTENSION)) { // strip the extension int nlen = name.length(); int endIndex = nlen - FILE_EXTENSION.length(); name = name.substring(0,endIndex); } return name; } }