Some new Writer2xhtml options
git-svn-id: svn://svn.code.sf.net/p/writer2latex/code/trunk@48 f0f2a975-2e09-46c8-9428-3b39399b9f3c
This commit is contained in:
parent
ccc8741301
commit
5311ac0b6b
20 changed files with 365 additions and 186 deletions
21
build.xml
21
build.xml
|
@ -2,7 +2,7 @@
|
|||
############################################################################
|
||||
# This is the Ant build file for writer2latex
|
||||
# Original: Sep 2004 (mgn)
|
||||
# version 1.2 (2010-02-14)
|
||||
# version 1.2 (2010-03-04)
|
||||
############################################################################
|
||||
-->
|
||||
<project name="w2l" default="help" basedir=".">
|
||||
|
@ -157,12 +157,19 @@
|
|||
<patternset>
|
||||
<exclude name="**/*Test.class"/>
|
||||
<exclude name="**/AllTests.class"/>
|
||||
<include name="**/*.xml"/>
|
||||
<include name="**/*.class"/>
|
||||
<exclude name="writer2latex/Application.class"/>
|
||||
<exclude name="writer2latex/latex/**/*"/>
|
||||
<exclude name="writer2latex/bibtex/**/*"/>
|
||||
<exclude name="org/openoffice/da/comp/writer2latex/**/*"/>
|
||||
<include name="org/openoffice/da/comp/w2lcommon/**/*.class"/>
|
||||
<include name="org/openoffice/da/comp/writer2xhtml/**/*.class"/>
|
||||
<include name="writer2latex/api/**/*.class"/>
|
||||
<include name="writer2latex/base/**/*.class"/>
|
||||
<include name="writer2latex/office/**/*.class"/>
|
||||
<include name="writer2latex/util/**/*.class"/>
|
||||
<include name="writer2latex/xhtml/**/*.class"/>
|
||||
<include name="writer2latex/xhtml/**/*.xml"/>
|
||||
<include name="writer2latex/xmerge/**/*.class"/>
|
||||
<!-- include the portions of w2l necessary to convert formulas -->
|
||||
<include name="writer2latex/latex/StarMathConverter.class"/>
|
||||
<include name="writer2latex/latex/LaTeXDocumentPortion.class"/>
|
||||
<include name="writer2latex/latex/i18n/*.class"/>
|
||||
</patternset>
|
||||
</fileset>
|
||||
<!-- also include uno interface as generated from idl -->
|
||||
|
|
|
@ -2,6 +2,21 @@ Changelog for Writer2LaTeX version 1.0 -> 1.2
|
|||
|
||||
---------- version 1.1.1 ----------
|
||||
|
||||
[w2l] Bugfix: Font is now selected correctly in list labels
|
||||
|
||||
[w2x] New option formulas (values starmath, latex, image+starmath (default), image+latex)
|
||||
to control export of formulas in xhtml 1.0 strict
|
||||
|
||||
[w2x] Avoid exporting redundant lang+dir information
|
||||
|
||||
[w2x] New option multilingual (default true) to turn of export of language information
|
||||
(except on the root element <html>)
|
||||
|
||||
[w2x] New option template_ids (default empty) to give the id's used to identity the parts
|
||||
of an xhtml template in the order content,header,footer,panel
|
||||
|
||||
[w2x] New option pretty_print (default true) to turn of pretty printing of xhtml source
|
||||
|
||||
[w2l] Bugfix: Avoid null pointer exception on empty metadata (date)
|
||||
|
||||
[w2x] Bugfix: Avoid null pointer exception on empty metadata (subject, keywords)
|
||||
|
@ -20,7 +35,7 @@ Changelog for Writer2LaTeX version 1.0 -> 1.2
|
|||
[w2x] Added support for text:start-value in outline numbering and list styles (the latter
|
||||
is only relevant if use_list_hack is true)
|
||||
|
||||
[all] Use zeropadding on exported images (ie file-img001 etc.)
|
||||
[all] Use zeropadding on exported images (ie. file-img001 etc.)
|
||||
|
||||
[w2l] Bugfix: Add \par after display equation when formatting>=convert_most
|
||||
|
||||
|
|
Binary file not shown.
Binary file not shown.
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2009 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2009-11-29)
|
||||
* Version 1.2 (2010-03-05)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -279,65 +279,71 @@ public final class ConfigurationDialog
|
|||
return false;
|
||||
}
|
||||
|
||||
// Windows: Test that the given path contains MikTeX
|
||||
private boolean containsMikTeX(String sPath) {
|
||||
// Windows: Test that the given path contains a given executable
|
||||
private boolean containsExecutable(String sPath,String sExecutable) {
|
||||
File dir = new File(sPath);
|
||||
if (dir.exists() && dir.canRead()) {
|
||||
File latex = new File(dir,"latex.exe");
|
||||
return latex.exists();
|
||||
File exe = new File(dir,sExecutable);
|
||||
return exe.exists();
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
// Windows: Configure a certain MikTeX application
|
||||
private void configureMikTeX(String sPath, String sName, String sAppName, String sArguments, StringBuffer info) {
|
||||
private boolean configureMikTeX(String sPath, String sName, String sAppName, String sArguments, StringBuffer info, boolean bRequired) {
|
||||
File app = new File(new File(sPath),sAppName+".exe");
|
||||
if (app.exists()) {
|
||||
externalApps.setApplication(sName, sAppName, sArguments);
|
||||
info.append(" Found "+sName+": "+sAppName+" - OK\n");
|
||||
return true;
|
||||
}
|
||||
else {
|
||||
else if (bRequired) {
|
||||
externalApps.setApplication(sName, "???", "???");
|
||||
info.append(" Failed to find "+sName+"\n");
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
// Configure the applications automatically (OS dependent)
|
||||
private boolean autoConfigure(XWindow xWindow) {
|
||||
String sOsName = System.getProperty("os.name");
|
||||
String sOsVersion = System.getProperty("os.version");
|
||||
String sOsArch = System.getProperty("os.arch");
|
||||
StringBuffer info = new StringBuffer();
|
||||
info.append("Results of configuration:\n\n");
|
||||
info.append("Your system identifies itself as "+sOsName+"\n\n");
|
||||
info.append("Your system identifies itself as "+sOsName+" version "+sOsVersion+ " (" + sOsArch +")\n\n");
|
||||
if (sOsName.startsWith("Windows")) {
|
||||
|
||||
// TODO: Get information from the windows registry using external vbs script
|
||||
// Assume MikTeX
|
||||
String sMikTeXPath = null;
|
||||
String[] sPaths = System.getenv("PATH").split(";");
|
||||
for (String s : sPaths) {
|
||||
if (s.toLowerCase().indexOf("miktex")>-1 && containsMikTeX(s)) {
|
||||
if (s.toLowerCase().indexOf("miktex")>-1 && containsExecutable(s,"latex.exe")) {
|
||||
sMikTeXPath = s;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (sMikTeXPath==null) {
|
||||
for (String s : sPaths) {
|
||||
if (containsMikTeX(s)) {
|
||||
if (containsExecutable(s,"latex.exe")) {
|
||||
sMikTeXPath = s;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
boolean bFoundTexworks = false;
|
||||
if (sMikTeXPath!=null) {
|
||||
info.append("Found MikTeX\n");
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.LATEX, "latex", "--interaction=batchmode %s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.PDFLATEX, "pdflatex", "--interaction=batchmode %s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.XELATEX, "xelatex", "--interaction=batchmode %s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.DVIPS, "dvips", "%s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.BIBTEX, "bibtex", "%s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.MAKEINDEX, "makeindex", "%s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.MK4HT, "mk4ht", "%c %s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.DVIVIEWER, "yap", "--single-instance %s", info);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.LATEX, "latex", "--interaction=batchmode %s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.PDFLATEX, "pdflatex", "--interaction=batchmode %s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.XELATEX, "xelatex", "--interaction=batchmode %s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.DVIPS, "dvips", "%s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.BIBTEX, "bibtex", "%s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.MAKEINDEX, "makeindex", "%s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.MK4HT, "mk4ht", "%c %s", info, true);
|
||||
configureMikTeX(sMikTeXPath, ExternalApps.DVIVIEWER, "yap", "--single-instance %s", info, true);
|
||||
// MikTeX 2.8 provides texworks for pdf viewing
|
||||
bFoundTexworks = configureMikTeX(sMikTeXPath, ExternalApps.PDFVIEWER, "texworks", "%s", info, true);
|
||||
}
|
||||
else {
|
||||
info.append("Failed to find MikTeX\n");
|
||||
|
@ -351,10 +357,29 @@ public final class ConfigurationDialog
|
|||
externalApps.setApplication(ExternalApps.MK4HT, "mk4ht", "%c %s");
|
||||
externalApps.setApplication(ExternalApps.DVIVIEWER, "yap", "--single-instance %s");
|
||||
}
|
||||
// And assume gsview for pdf and ps
|
||||
// gsview32 may not be in the path, but at least this helps a bit
|
||||
externalApps.setApplication(ExternalApps.PDFVIEWER, "gsview32.exe", "-e \"%s\"");
|
||||
externalApps.setApplication(ExternalApps.POSTSCRIPTVIEWER, "gsview32.exe", "-e \"%s\"");
|
||||
info.append("\n");
|
||||
|
||||
// Assume gsview for pdf and ps
|
||||
String sGsview = null;
|
||||
String sProgramFiles = System.getenv("ProgramFiles");
|
||||
if (sProgramFiles!=null) {
|
||||
if (containsExecutable(sProgramFiles+"\\ghostgum\\gsview","gsview32.exe")) {
|
||||
sGsview = sProgramFiles+"\\ghostgum\\gsview\\gsview32.exe";
|
||||
}
|
||||
}
|
||||
|
||||
if (sGsview!=null) {
|
||||
info.append("Found gsview - OK\n");
|
||||
}
|
||||
else {
|
||||
info.append("Failed to find gsview\n");
|
||||
sGsview = "gsview32.exe"; // at least this helps a bit..
|
||||
}
|
||||
if (!bFoundTexworks) {
|
||||
externalApps.setApplication(ExternalApps.PDFVIEWER, sGsview, "-e \"%s\"");
|
||||
}
|
||||
externalApps.setApplication(ExternalApps.POSTSCRIPTVIEWER, sGsview, "-e \"%s\"");
|
||||
|
||||
}
|
||||
else { // Assume a unix-like system supporting the "which" command
|
||||
configureApp(ExternalApps.LATEX, "latex", "--interaction=batchmode %s",info);
|
||||
|
@ -373,6 +398,10 @@ public final class ConfigurationDialog
|
|||
configureApp(ExternalApps.POSTSCRIPTVIEWER, sPsViewers, "%s",info);
|
||||
|
||||
}
|
||||
// Maybe add some info for Ubuntu users
|
||||
// sudo apt-get install texlive
|
||||
// sudo apt-get install texlive-xetex
|
||||
// sudo apt-get install tex4ht
|
||||
displayAutoConfigInfo(info.toString());
|
||||
changeApplication(xWindow);
|
||||
return true;
|
||||
|
|
|
@ -187,7 +187,7 @@ public class DrawConverter extends ConverterHelper {
|
|||
}
|
||||
}
|
||||
else { // flat xml, object is contained in node
|
||||
Element formula = Misc.getChildByTagName(node,XMLString.MATH);
|
||||
Element formula = Misc.getChildByTagName(node,XMLString.MATH); // Since OOo 3.2
|
||||
if (formula==null) {
|
||||
formula = Misc.getChildByTagName(node,XMLString.MATH_MATH);
|
||||
}
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2009 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2009-04-30)
|
||||
* Version 1.2 (2010-03-03)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -396,8 +396,11 @@ public class ListStyleConverter extends StyleConverter {
|
|||
// Apply style
|
||||
ldp.append(baText.getBefore());
|
||||
if (sBullet!=null) {
|
||||
String sFontName = palette.getCharSc().getFontName(style.getLevelProperty(i,XMLString.TEXT_STYLE_NAME));
|
||||
palette.getI18n().pushSpecialTable(sFontName);
|
||||
// Bullets are usually symbols, so this should be OK:
|
||||
ldp.append(palette.getI18n().convert(sBullet,false,"en"));
|
||||
palette.getI18n().popSpecialTable();
|
||||
}
|
||||
ldp.append(baText.getAfter());
|
||||
}
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2009 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2009-09-05)
|
||||
* Version 1.2 (2010-03-02)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -90,11 +90,7 @@ public class BatchConverterImpl extends BatchConverterBase {
|
|||
public OutputFile createIndexFile(String sHeading, IndexPageEntry[] entries) {
|
||||
// Create the index page (with header/footer or from template)
|
||||
XhtmlDocument htmlDoc = new XhtmlDocument("index",XhtmlDocument.XHTML10);
|
||||
htmlDoc.setEncoding(config.xhtmlEncoding());
|
||||
htmlDoc.setNoDoctype(config.xhtmlNoDoctype());
|
||||
htmlDoc.setAddBOM(config.xhtmlAddBOM());
|
||||
htmlDoc.setUseNamedEntities(config.useNamedEntities());
|
||||
htmlDoc.setHexadecimalEntities(config.hexadecimalEntities());
|
||||
htmlDoc.setConfig(config);
|
||||
if (template!=null) { htmlDoc.readFromTemplate(template); }
|
||||
else { htmlDoc.createHeaderFooter(); }
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2010-02-26)
|
||||
* Version 1.2 (2010-03-02)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -442,12 +442,7 @@ public class Converter extends ConverterBase {
|
|||
public Element nextOutFile() {
|
||||
if (nOutFileIndex>=0) { textCv.insertFootnotes(htmlDoc.getContentNode()); }
|
||||
htmlDoc = new XhtmlDocument(getOutFileName(++nOutFileIndex,false),nType);
|
||||
htmlDoc.setEncoding(config.xhtmlEncoding());
|
||||
htmlDoc.setNoDoctype(config.xhtmlNoDoctype());
|
||||
htmlDoc.setAddBOM(config.xhtmlAddBOM());
|
||||
htmlDoc.setUseNamedEntities(config.useNamedEntities());
|
||||
htmlDoc.setHexadecimalEntities(config.hexadecimalEntities());
|
||||
htmlDoc.setXsltPath(config.getXsltPath());
|
||||
htmlDoc.setConfig(config);
|
||||
if (template!=null) { htmlDoc.readFromTemplate(template); }
|
||||
else if (bNeedHeaderFooter) { htmlDoc.createHeaderFooter(); }
|
||||
outFiles.add(nOutFileIndex,htmlDoc);
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2010-02-19)
|
||||
* Version 1.2 (2010-03-03)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -305,9 +305,13 @@ public class DrawConverter extends ConverterHelper {
|
|||
if (MIMETypes.MATH.equals(object.getType()) || MIMETypes.ODF.equals(object.getType())) { // Formula!
|
||||
EmbeddedXMLObject xmlObject = (EmbeddedXMLObject) object;
|
||||
// Document settings = object.getSettingsDOM();
|
||||
Element replacementImage = null;
|
||||
if (ofr.isOpenDocument()) { // look for replacement image
|
||||
replacementImage = Misc.getChildByTagName(getFrame(onode),XMLString.DRAW_IMAGE);
|
||||
}
|
||||
try {
|
||||
hnode.appendChild(converter.createTextNode(" "));
|
||||
getMathCv().convert(xmlObject.getContentDOM().getDocumentElement(),hnode);
|
||||
getMathCv().convert(replacementImage,xmlObject.getContentDOM().getDocumentElement(),hnode);
|
||||
hnode.appendChild(converter.createTextNode(" "));
|
||||
}
|
||||
catch (SAXException e) {
|
||||
|
@ -341,8 +345,12 @@ public class DrawConverter extends ConverterHelper {
|
|||
formula = Misc.getChildByTagName(onode,XMLString.MATH_MATH);
|
||||
}
|
||||
if (formula != null) {
|
||||
Element replacementImage = null;
|
||||
if (ofr.isOpenDocument()) { // look for replacement image
|
||||
replacementImage = Misc.getChildByTagName(getFrame(onode),XMLString.DRAW_IMAGE);
|
||||
}
|
||||
hnode.appendChild(converter.createTextNode(" "));
|
||||
getMathCv().convert(formula,hnode);
|
||||
getMathCv().convert(replacementImage,formula,hnode);
|
||||
hnode.appendChild(converter.createTextNode(" "));
|
||||
}
|
||||
else { // unsupported object
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-11-22)
|
||||
* Version 1.2 (2010-03-01)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -79,7 +79,7 @@ public class FrameStyleConverter extends StyleWithPropertiesConverterHelper {
|
|||
.append(getDefaultTagName(null))
|
||||
.append(".").append(getClassNamePrefix())
|
||||
.append(styleNames.getExportName(sDisplayName))
|
||||
.append(" p {").append(props.toString()).append("}\n");
|
||||
.append(" p {").append(props.toString()).append("}").append(config.prettyPrint() ? "\n" : " ");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-11-22)
|
||||
* Version 1.2 (2010-03-01)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -100,7 +100,8 @@ public class ListStyleConverter extends StyleConverterHelper {
|
|||
buf.append(styleNames.getExportName(sDisplayName));
|
||||
buf.append(" {");
|
||||
buf.append(props.toString());
|
||||
buf.append("}\n");
|
||||
buf.append("}");
|
||||
buf.append(config.prettyPrint() ? "\n" : " ");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2010-02-19)
|
||||
* Version 1.2 (2010-03-04)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -33,48 +33,106 @@ import org.w3c.dom.Element;
|
|||
import org.w3c.dom.NamedNodeMap;
|
||||
|
||||
import writer2latex.office.*;
|
||||
import writer2latex.util.Misc;
|
||||
import writer2latex.xmerge.BinaryGraphicsDocument;
|
||||
import writer2latex.latex.StarMathConverter;
|
||||
|
||||
/** This class converts formulas: Either as MathML, as an image or as plain text (StarMath or LaTeX format)
|
||||
*/
|
||||
public class MathConverter extends ConverterHelper {
|
||||
|
||||
private boolean bSupportMathML;
|
||||
private StarMathConverter smc = null;
|
||||
|
||||
private boolean bSupportMathML;
|
||||
private boolean bUseImage;
|
||||
private boolean bUseLaTeX;
|
||||
|
||||
/** Create a new <code>MathConverter</code>
|
||||
*
|
||||
* @param ofr the OfficeReader to query about the document
|
||||
* @param config the configuration determining the type of export
|
||||
* @param converter the converter instance
|
||||
* @param bSupportMathML true if the formula should be exported as MathML
|
||||
*/
|
||||
public MathConverter(OfficeReader ofr, XhtmlConfig config, Converter converter,
|
||||
boolean bSupportMathML) {
|
||||
|
||||
super(ofr,config,converter);
|
||||
this.bSupportMathML = bSupportMathML;
|
||||
this.bUseImage = config.formulas()==XhtmlConfig.IMAGE_LATEX || config.formulas()==XhtmlConfig.IMAGE_STARMATH;
|
||||
this.bUseLaTeX = config.formulas()==XhtmlConfig.IMAGE_LATEX || config.formulas()==XhtmlConfig.LATEX;
|
||||
|
||||
if (bUseLaTeX) { smc = new StarMathConverter(); }
|
||||
}
|
||||
|
||||
public void convert(Node onode, Node hnode) {
|
||||
/** Convert a formula
|
||||
*
|
||||
* @param image image version of the formula (or null if no image is available)
|
||||
* @param onode the math node
|
||||
* @param hnode the xhtml node to which content should be added
|
||||
*/
|
||||
public void convert(Node image, Node onode, Node hnode) {
|
||||
if (bSupportMathML) {
|
||||
convertNode(onode,hnode);
|
||||
convertAsMathML(onode,hnode);
|
||||
}
|
||||
else {
|
||||
Document htmlDOM = hnode.getOwnerDocument();
|
||||
convertAsImageOrText(image,onode,hnode);
|
||||
}
|
||||
}
|
||||
|
||||
// For plain xhtml: Convert the formula as an image or as plain text
|
||||
private void convertAsImageOrText(Node image, Node onode, Node hnode) {
|
||||
NodeList annotationList = ((Element) onode).getElementsByTagName(XMLString.ANNOTATION); // Since OOo 3.2
|
||||
if (annotationList.getLength()>0) {
|
||||
if (annotationList.getLength()==0) {
|
||||
annotationList = ((Element) onode).getElementsByTagName(XMLString.MATH_ANNOTATION);
|
||||
}
|
||||
if (annotationList.getLength()>0 && annotationList.item(0).hasChildNodes()) {
|
||||
// Insert the StarMath annotation as a kbd element
|
||||
Element kbd = htmlDOM.createElement("kbd");
|
||||
hnode.appendChild(kbd);
|
||||
NodeList list = annotationList.item(0).getChildNodes();
|
||||
int nLen = list.getLength();
|
||||
for (int i=0; i<nLen; i++) {
|
||||
Node child = list.item(i);
|
||||
if (child.getNodeType()==Node.TEXT_NODE) {
|
||||
kbd.appendChild(htmlDOM.createTextNode(child.getNodeValue()));
|
||||
// First create the annotation (either StarMath or LaTeX)
|
||||
String sAnnotation = "";
|
||||
Node child = annotationList.item(0).getFirstChild();
|
||||
while (child!=null) {
|
||||
sAnnotation+=child.getNodeValue();
|
||||
child = child.getNextSibling();
|
||||
}
|
||||
if (bUseLaTeX) { sAnnotation = smc.convert(sAnnotation); }
|
||||
|
||||
// Next insert the image if required and available
|
||||
if (bUseImage) {
|
||||
// Get the image from the ImageLoader
|
||||
String sHref = Misc.getAttribute(onode,XMLString.XLINK_HREF);
|
||||
if (sHref==null || sHref.length()==0 || ofr.isInPackage(sHref)) {
|
||||
BinaryGraphicsDocument bgd = converter.getImageLoader().getImage(image);
|
||||
if (bgd!=null) {
|
||||
String sMIME = bgd.getDocumentMIMEType();
|
||||
if (MIMETypes.PNG.equals(sMIME) || MIMETypes.JPEG.equals(sMIME) || MIMETypes.GIF.equals(sMIME)) {
|
||||
converter.addDocument(bgd);
|
||||
// Create the image and add the StarMath/LaTeX formula as alternative text
|
||||
Element img = converter.createElement("img");
|
||||
img.setAttribute("src",bgd.getFileName());
|
||||
img.setAttribute("class", "formula");
|
||||
img.setAttribute("alt",sAnnotation);
|
||||
|
||||
hnode.appendChild(img);
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
else {
|
||||
hnode.appendChild(htmlDOM.createTextNode("[Warning: formula ignored]"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void convertNode(Node onode, Node hnode) {
|
||||
// Otherwise insert the StarMath/LaTeX annotation as a kbd element
|
||||
Element kbd = converter.createElement("kbd");
|
||||
kbd.setAttribute("class", "formula");
|
||||
hnode.appendChild(kbd);
|
||||
kbd.appendChild(converter.createTextNode(sAnnotation));
|
||||
}
|
||||
else {
|
||||
hnode.appendChild(converter.createTextNode("[Warning: formula ignored]"));
|
||||
}
|
||||
}
|
||||
|
||||
// For xhtml+mathml: Insert the mathml, removing the namespace (if any) and the annotation
|
||||
public void convertAsMathML(Node onode, Node hnode) {
|
||||
if (onode.getNodeType()==Node.ELEMENT_NODE) {
|
||||
if (onode.getNodeName().equals(XMLString.SEMANTICS)) { // Since OOo 3.2
|
||||
// ignore this construction
|
||||
|
@ -120,7 +178,7 @@ public class MathConverter extends ConverterHelper {
|
|||
if (list==null) { return; }
|
||||
int nLen = list.getLength();
|
||||
for (int i=0; i<nLen; i++) {
|
||||
convertNode(list.item(i),hnode);
|
||||
convertAsMathML(list.item(i),hnode);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -144,7 +202,7 @@ public class MathConverter extends ConverterHelper {
|
|||
|
||||
// This method maps {Open|Star}Symbol private use area to real unicode
|
||||
// positions. This is the same table as in w2l/latex/style/symbols.xml.
|
||||
// The named entities list is contributed by Bruno Mascret
|
||||
// The list is contributed by Bruno Mascret
|
||||
private char replacePrivateChar(char c) {
|
||||
switch (c) {
|
||||
case '\uE002': return '\u2666';
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-09-08)
|
||||
* Version 1.2 (2010-03-01)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -105,7 +105,8 @@ public class PageStyleConverter extends StyleConverterHelper {
|
|||
// The export the results
|
||||
buf.append(sIndent)
|
||||
.append(".masterpage").append(styleNames.getExportName(sDisplayName))
|
||||
.append(" {").append(info.props.toString()).append("}\n");
|
||||
.append(" {").append(info.props.toString()).append("}")
|
||||
.append(config.prettyPrint() ? "\n" : " ");
|
||||
}
|
||||
return buf.toString();
|
||||
}
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-09-08)
|
||||
* Version 1.2 (2010-03-01)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -86,7 +86,7 @@ public class ParStyleConverter extends StyleWithPropertiesConverterHelper {
|
|||
applyProperties(style,props,true);
|
||||
props.addValue("clear","left");
|
||||
buf.append(sIndent).append("h").append(i)
|
||||
.append(" {").append(props.toString()).append("}\n");
|
||||
.append(" {").append(props.toString()).append("}").append(config.prettyPrint() ? "\n" : " ");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-11-22)
|
||||
* Version 1.2 (2010-03-01)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -102,7 +102,8 @@ public class PresentationStyleConverter extends FrameStyleConverter {
|
|||
buf.append(sIndent)
|
||||
.append("li.outline")
|
||||
.append(styleNames.getExportName(sDisplayName))
|
||||
.append(" p {").append(props.toString()).append("}\n");
|
||||
.append(" p {").append(props.toString()).append("}")
|
||||
.append(config.prettyPrint() ? "\n" : " ");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-11-22)
|
||||
* Version 1.2 (2010-02-27)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -120,7 +120,7 @@ class StyleConverter extends ConverterHelper {
|
|||
|
||||
// Export used styles to CSS
|
||||
public Node exportStyles(Document htmlDOM) {
|
||||
String sIndent = " ";
|
||||
String sIndent = config.prettyPrint() ? " " : "";
|
||||
|
||||
StringBuffer buf = new StringBuffer();
|
||||
|
||||
|
@ -135,7 +135,7 @@ class StyleConverter extends ConverterHelper {
|
|||
// text properties only!
|
||||
getTextSc().cssTextCommon(defaultStyle,props,true);
|
||||
buf.append(sIndent)
|
||||
.append("body {").append(props.toString()).append("}\n");
|
||||
.append("body {").append(props.toString()).append("}").append(config.prettyPrint() ? "\n" : " ");
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -161,9 +161,9 @@ class StyleConverter extends ConverterHelper {
|
|||
Element htmlStyle = htmlDOM.createElement("style");
|
||||
htmlStyle.setAttribute("media","all");
|
||||
htmlStyle.setAttribute("type","text/css");
|
||||
htmlStyle.appendChild(htmlDOM.createTextNode("\n"));
|
||||
htmlStyle.appendChild(htmlDOM.createTextNode(config.prettyPrint() ? "\n" : " "));
|
||||
htmlStyle.appendChild(htmlDOM.createTextNode(buf.toString()));
|
||||
htmlStyle.appendChild(htmlDOM.createTextNode(" "));
|
||||
if (config.prettyPrint()) { htmlStyle.appendChild(htmlDOM.createTextNode(" ")); }
|
||||
return htmlStyle;
|
||||
}
|
||||
else {
|
||||
|
|
|
@ -16,11 +16,11 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2008 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.0 (2008-11-22)
|
||||
* Version 1.2 (2010-03-03)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -62,7 +62,7 @@ public abstract class StyleWithPropertiesConverterHelper
|
|||
StyleWithProperties style = (StyleWithProperties) getStyles().getStyle(sStyleName);
|
||||
info.sTagName = getDefaultTagName(style);
|
||||
if (style!=null) {
|
||||
applyLang(style,info);
|
||||
if (config.multilingual()) { applyLang(style,info); }
|
||||
applyDirection(style,info);
|
||||
if (style.isAutomatic()) {
|
||||
// Apply parent style + hard formatting
|
||||
|
@ -108,7 +108,8 @@ public abstract class StyleWithPropertiesConverterHelper
|
|||
buf.append(styleNames.getExportName(sDisplayName));
|
||||
buf.append(" {");
|
||||
buf.append(props.toString());
|
||||
buf.append("}\n");
|
||||
buf.append("}");
|
||||
buf.append(config.prettyPrint() ? "\n" : " ");
|
||||
// TODO: Create a method "getStyleDeclarationsInner"
|
||||
// to be used by eg. FrameStyleConverter
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2010-02-14)
|
||||
* Version 1.2 (2010-03-04)
|
||||
*
|
||||
*/
|
||||
|
||||
|
@ -38,7 +38,7 @@ import writer2latex.util.Misc;
|
|||
|
||||
public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
||||
// Implement configuration methods
|
||||
protected int getOptionCount() { return 37; }
|
||||
protected int getOptionCount() { return 42; }
|
||||
protected String getDefaultConfigPath() { return "/writer2latex/xhtml/config/"; }
|
||||
|
||||
// Override setOption: To be backwards compatible, we must accept options
|
||||
|
@ -56,6 +56,12 @@ public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
|||
public static final int IGNORE_HARD = 2;
|
||||
public static final int CONVERT_ALL = 3;
|
||||
|
||||
// Formulas (for xhtml 1.0 strict)
|
||||
public static final int STARMATH = 0;
|
||||
public static final int LATEX = 1;
|
||||
public static final int IMAGE_STARMATH = 2;
|
||||
public static final int IMAGE_LATEX = 3;
|
||||
|
||||
// Options
|
||||
private static final int IGNORE_HARD_LINE_BREAKS = 0;
|
||||
private static final int IGNORE_EMPTY_PARAGRAPHS = 1;
|
||||
|
@ -66,34 +72,39 @@ public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
|||
private static final int ENCODING = 6;
|
||||
private static final int USE_NAMED_ENTITIES = 7;
|
||||
private static final int HEXADECIMAL_ENTITIES = 8;
|
||||
private static final int CUSTOM_STYLESHEET = 9;
|
||||
private static final int FORMATTING = 10;
|
||||
private static final int FRAME_FORMATTING = 11;
|
||||
private static final int SECTION_FORMATTING = 12;
|
||||
private static final int TABLE_FORMATTING = 13;
|
||||
private static final int IGNORE_TABLE_DIMENSIONS = 14;
|
||||
private static final int USE_DUBLIN_CORE = 15;
|
||||
private static final int NOTES = 16;
|
||||
private static final int CONVERT_TO_PX = 17;
|
||||
private static final int SCALING = 18;
|
||||
private static final int COLUMN_SCALING = 19;
|
||||
private static final int FLOAT_OBJECTS = 20;
|
||||
private static final int TABSTOP_STYLE = 21;
|
||||
private static final int USE_LIST_HACK = 22;
|
||||
private static final int SPLIT_LEVEL = 23;
|
||||
private static final int REPEAT_LEVELS = 24;
|
||||
private static final int CALC_SPLIT = 25;
|
||||
private static final int DISPLAY_HIDDEN_SHEETS = 26;
|
||||
private static final int DISPLAY_HIDDEN_ROWS_COLS = 27;
|
||||
private static final int DISPLAY_FILTERED_ROWS_COLS = 28;
|
||||
private static final int APPLY_PRINT_RANGES = 29;
|
||||
private static final int USE_TITLE_AS_HEADING = 30;
|
||||
private static final int USE_SHEET_NAMES_AS_HEADINGS = 31;
|
||||
private static final int XSLT_PATH = 32;
|
||||
private static final int SAVE_IMAGES_IN_SUBDIR = 33;
|
||||
private static final int UPLINK = 34;
|
||||
private static final int DIRECTORY_ICON = 35;
|
||||
private static final int DOCUMENT_ICON = 36;
|
||||
private static final int PRETTY_PRINT = 9;
|
||||
private static final int MULTILINGUAL = 10;
|
||||
private static final int TEMPLATE_IDS = 11;
|
||||
private static final int SEPARATE_STYLESHEET = 12;
|
||||
private static final int CUSTOM_STYLESHEET = 13;
|
||||
private static final int FORMATTING = 14;
|
||||
private static final int FRAME_FORMATTING = 15;
|
||||
private static final int SECTION_FORMATTING = 16;
|
||||
private static final int TABLE_FORMATTING = 17;
|
||||
private static final int IGNORE_TABLE_DIMENSIONS = 18;
|
||||
private static final int USE_DUBLIN_CORE = 19;
|
||||
private static final int NOTES = 20;
|
||||
private static final int CONVERT_TO_PX = 21;
|
||||
private static final int SCALING = 22;
|
||||
private static final int COLUMN_SCALING = 23;
|
||||
private static final int FLOAT_OBJECTS = 24;
|
||||
private static final int TABSTOP_STYLE = 25;
|
||||
private static final int USE_LIST_HACK = 26;
|
||||
private static final int FORMULAS = 27;
|
||||
private static final int SPLIT_LEVEL = 28;
|
||||
private static final int REPEAT_LEVELS = 29;
|
||||
private static final int CALC_SPLIT = 30;
|
||||
private static final int DISPLAY_HIDDEN_SHEETS = 31;
|
||||
private static final int DISPLAY_HIDDEN_ROWS_COLS = 32;
|
||||
private static final int DISPLAY_FILTERED_ROWS_COLS = 33;
|
||||
private static final int APPLY_PRINT_RANGES = 34;
|
||||
private static final int USE_TITLE_AS_HEADING = 35;
|
||||
private static final int USE_SHEET_NAMES_AS_HEADINGS = 36;
|
||||
private static final int XSLT_PATH = 37;
|
||||
private static final int SAVE_IMAGES_IN_SUBDIR = 38;
|
||||
private static final int UPLINK = 39;
|
||||
private static final int DIRECTORY_ICON = 40;
|
||||
private static final int DOCUMENT_ICON = 41;
|
||||
|
||||
protected XhtmlStyleMap xpar = new XhtmlStyleMap();
|
||||
protected XhtmlStyleMap xtext = new XhtmlStyleMap();
|
||||
|
@ -113,6 +124,10 @@ public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
|||
options[ENCODING] = new Option("encoding","UTF-8");
|
||||
options[USE_NAMED_ENTITIES] = new BooleanOption("use_named_entities","false");
|
||||
options[HEXADECIMAL_ENTITIES] = new BooleanOption("hexadecimal_entities","true");
|
||||
options[PRETTY_PRINT] = new BooleanOption("pretty_print","true");
|
||||
options[MULTILINGUAL] = new BooleanOption("multilingual","true");
|
||||
options[TEMPLATE_IDS] = new Option("template_ids","");
|
||||
options[SEPARATE_STYLESHEET] = new BooleanOption("separate_stylesheet","false");
|
||||
options[CUSTOM_STYLESHEET] = new Option("custom_stylesheet","");
|
||||
options[FORMATTING] = new XhtmlFormatOption("formatting","convert_all");
|
||||
options[FRAME_FORMATTING] = new XhtmlFormatOption("frame_formatting","convert_all");
|
||||
|
@ -127,6 +142,15 @@ public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
|||
options[FLOAT_OBJECTS] = new BooleanOption("float_objects","true");
|
||||
options[TABSTOP_STYLE] = new Option("tabstop_style","");
|
||||
options[USE_LIST_HACK] = new BooleanOption("use_list_hack","false");
|
||||
options[FORMULAS] = new IntegerOption("formulas","starmath") {
|
||||
public void setString(String sValue) {
|
||||
super.setString(sValue);
|
||||
if ("latex".equals(sValue)) { nValue = LATEX; }
|
||||
else if ("image+latex".equals(sValue)) { nValue = IMAGE_LATEX; }
|
||||
else if ("starmath".equals(sValue)) { nValue = STARMATH; }
|
||||
else { nValue = IMAGE_STARMATH; }
|
||||
}
|
||||
};
|
||||
options[SPLIT_LEVEL] = new IntegerOption("split_level","0") {
|
||||
public void setString(String sValue) {
|
||||
super.setString(sValue);
|
||||
|
@ -219,6 +243,10 @@ public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
|||
public String xhtmlEncoding() { return options[ENCODING].getString(); }
|
||||
public boolean useNamedEntities() { return ((BooleanOption) options[USE_NAMED_ENTITIES]).getValue(); }
|
||||
public boolean hexadecimalEntities() { return ((BooleanOption) options[HEXADECIMAL_ENTITIES]).getValue(); }
|
||||
public boolean prettyPrint() { return ((BooleanOption) options[PRETTY_PRINT]).getValue(); }
|
||||
public boolean multilingual() { return ((BooleanOption) options[MULTILINGUAL]).getValue(); }
|
||||
public String templateIds() { return options[TEMPLATE_IDS].getString(); }
|
||||
public boolean separateStylesheet() { return ((BooleanOption) options[SEPARATE_STYLESHEET]).getValue(); }
|
||||
public String xhtmlCustomStylesheet() { return options[CUSTOM_STYLESHEET].getString(); }
|
||||
public int xhtmlFormatting() { return ((XhtmlFormatOption) options[FORMATTING]).getValue(); }
|
||||
public int xhtmlFrameFormatting() { return ((XhtmlFormatOption) options[FRAME_FORMATTING]).getValue(); }
|
||||
|
@ -233,6 +261,7 @@ public class XhtmlConfig extends writer2latex.base.ConfigBase {
|
|||
public boolean xhtmlFloatObjects() { return ((BooleanOption) options[FLOAT_OBJECTS]).getValue(); }
|
||||
public String getXhtmlTabstopStyle() { return options[TABSTOP_STYLE].getString(); }
|
||||
public boolean xhtmlUseListHack() { return ((BooleanOption) options[USE_LIST_HACK]).getValue(); }
|
||||
public int formulas() { return ((IntegerOption) options[FORMULAS]).getValue(); }
|
||||
public int getXhtmlSplitLevel() { return ((IntegerOption) options[SPLIT_LEVEL]).getValue(); }
|
||||
public int getXhtmlRepeatLevels() { return ((IntegerOption) options[REPEAT_LEVELS]).getValue(); }
|
||||
public boolean xhtmlCalcSplit() { return ((BooleanOption) options[CALC_SPLIT]).getValue(); }
|
||||
|
|
|
@ -16,15 +16,14 @@
|
|||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*
|
||||
* Copyright: 2002-2009 by Henrik Just
|
||||
* Copyright: 2002-2010 by Henrik Just
|
||||
*
|
||||
* All Rights Reserved.
|
||||
*
|
||||
* Version 1.2 (2009-09-05)
|
||||
* Version 1.2 (2010-03-03)
|
||||
*
|
||||
*/
|
||||
|
||||
//TODO: Remove redundant lang and dir attributes
|
||||
//TODO: Add named entities outside ISO-latin 1
|
||||
|
||||
package writer2latex.xhtml;
|
||||
|
@ -86,7 +85,12 @@ public class XhtmlDocument extends DOMDocument {
|
|||
private char cLimit = 65535;
|
||||
private boolean bNoDoctype = false;
|
||||
private boolean bAddBOM = false;
|
||||
private boolean bPrettyPrint = true;
|
||||
private String sXsltPath = "";
|
||||
private String sContentId = "content";
|
||||
private String sHeaderId = "header";
|
||||
private String sFooterId = "footer";
|
||||
private String sPanelId = "panel";
|
||||
|
||||
// Content
|
||||
private Element headNode = null;
|
||||
|
@ -176,13 +180,13 @@ public class XhtmlDocument extends DOMDocument {
|
|||
|
||||
public void createHeaderFooter() {
|
||||
headerNode = getContentDOM().createElement("div");
|
||||
headerNode.setAttribute("id","header");
|
||||
headerNode.setAttribute("id",sHeaderId);
|
||||
bodyNode.appendChild(headerNode);
|
||||
contentNode = getContentDOM().createElement("div");
|
||||
contentNode.setAttribute("id","content");
|
||||
contentNode.setAttribute("id",sContentId);
|
||||
bodyNode.appendChild(contentNode);
|
||||
footerNode = getContentDOM().createElement("div");
|
||||
footerNode.setAttribute("id","footer");
|
||||
footerNode.setAttribute("id",sFooterId);
|
||||
bodyNode.appendChild(footerNode);
|
||||
}
|
||||
|
||||
|
@ -230,10 +234,10 @@ public class XhtmlDocument extends DOMDocument {
|
|||
}
|
||||
else if ("div".equals(sTagName)) {
|
||||
String sId = elm.getAttribute("id");
|
||||
if ("content".equals(sId)) { contentNode = elm; }
|
||||
else if ("header".equals(sId)) { headerNode = elm; }
|
||||
else if ("footer".equals(sId)) { footerNode = elm; }
|
||||
else if ("panel".equals(sId)) { panelNode = elm; }
|
||||
if (sContentId.equals(sId)) { contentNode = elm; }
|
||||
else if (sHeaderId.equals(sId)) { headerNode = elm; }
|
||||
else if (sFooterId.equals(sId)) { footerNode = elm; }
|
||||
else if (sPanelId.equals(sId)) { panelNode = elm; }
|
||||
}
|
||||
|
||||
Node child = elm.getFirstChild();
|
||||
|
@ -263,44 +267,71 @@ public class XhtmlDocument extends DOMDocument {
|
|||
}
|
||||
}
|
||||
|
||||
public void setEncoding(String s) {
|
||||
s = s.toUpperCase();
|
||||
if ("UTF-16".equals(s)) {
|
||||
sEncoding = s;
|
||||
public void setConfig(XhtmlConfig config) {
|
||||
sEncoding = config.xhtmlEncoding().toUpperCase();
|
||||
if ("UTF-16".equals(sEncoding)) {
|
||||
cLimit = 65535;
|
||||
}
|
||||
else if ("ISO-8859-1".equals(s)) {
|
||||
sEncoding = s;
|
||||
else if ("ISO-8859-1".equals(sEncoding)) {
|
||||
cLimit = 255;
|
||||
}
|
||||
else if ("US-ASCII".equals(s)) {
|
||||
sEncoding = s;
|
||||
else if ("US-ASCII".equals(sEncoding)) {
|
||||
cLimit = 127;
|
||||
}
|
||||
else {
|
||||
sEncoding = "UTF-8";
|
||||
cLimit = 65535;
|
||||
}
|
||||
|
||||
bAddBOM = config.xhtmlAddBOM();
|
||||
bNoDoctype = config.xhtmlNoDoctype();
|
||||
bPrettyPrint = config.prettyPrint();
|
||||
bUseNamedEntities = config.useNamedEntities();
|
||||
bHexadecimalEntities = config.hexadecimalEntities();
|
||||
sXsltPath = config.getXsltPath();
|
||||
|
||||
String[] sTemplateIds = config.templateIds().split(",");
|
||||
int nIdCount = sTemplateIds.length;
|
||||
if (nIdCount>0) sContentId = sTemplateIds[0].trim(); else sContentId = "content";
|
||||
if (nIdCount>1) sHeaderId = sTemplateIds[1].trim(); else sHeaderId = "header";
|
||||
if (nIdCount>2) sFooterId = sTemplateIds[2].trim(); else sFooterId = "footer";
|
||||
if (nIdCount>3) sPanelId = sTemplateIds[3].trim(); else sPanelId = "panel";
|
||||
}
|
||||
|
||||
public String getEncoding() { return sEncoding; }
|
||||
|
||||
public void setNoDoctype(boolean b) { bNoDoctype = b; }
|
||||
|
||||
public void setAddBOM(boolean b) { bAddBOM = b; }
|
||||
|
||||
public void setUseNamedEntities(boolean b) {
|
||||
bUseNamedEntities = b;
|
||||
}
|
||||
|
||||
public void setHexadecimalEntities(boolean b) {
|
||||
bHexadecimalEntities = b;
|
||||
}
|
||||
|
||||
public void setXsltPath(String s) { sXsltPath = s; }
|
||||
|
||||
public String getFileExtension() { return super.getFileExtension(); }
|
||||
|
||||
private void optimize(Element node, String sLang, String sDir) {
|
||||
if (node.hasAttribute("xml:lang")) {
|
||||
if (node.getAttribute("xml:lang").equals(sLang)) {
|
||||
node.removeAttribute("xml:lang");
|
||||
if (node.hasAttribute("lang")) {
|
||||
node.removeAttribute("lang");
|
||||
}
|
||||
}
|
||||
else {
|
||||
sLang = node.getAttribute("xml:lang");
|
||||
}
|
||||
}
|
||||
if (node.hasAttribute("xml:dir")) {
|
||||
if (node.getAttribute("xml:dir").equals(sDir)) {
|
||||
node.removeAttribute("xml:dir");
|
||||
}
|
||||
else {
|
||||
sDir = node.getAttribute("xml:dir");
|
||||
}
|
||||
}
|
||||
|
||||
Node child = node.getFirstChild();
|
||||
while (child!=null) {
|
||||
if (child.getNodeType()==Node.ELEMENT_NODE) {
|
||||
optimize((Element)child, sLang, sDir);
|
||||
}
|
||||
child = child.getNextSibling();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Write out content to the supplied <code>OutputStream</code>.
|
||||
* (with pretty printing)
|
||||
|
@ -334,7 +365,9 @@ public class XhtmlDocument extends DOMDocument {
|
|||
osw.write(getContentDOM().getDoctype().getSystemId());
|
||||
osw.write("\">\n");
|
||||
}
|
||||
write(getContentDOM().getDocumentElement(),0,osw);
|
||||
Element doc = getContentDOM().getDocumentElement();
|
||||
optimize(doc,null,null);
|
||||
write(doc,0,osw);
|
||||
osw.flush();
|
||||
osw.close();
|
||||
}
|
||||
|
@ -357,7 +390,7 @@ public class XhtmlDocument extends DOMDocument {
|
|||
osw.write("<"+node.getNodeName());
|
||||
writeAttributes(node,osw);
|
||||
osw.write(" />");
|
||||
if (nLevel>=0) { osw.write("\n"); }
|
||||
if (bPrettyPrint && nLevel>=0) { osw.write("\n"); }
|
||||
}
|
||||
else if (node.hasChildNodes()) {
|
||||
// Block pretty print from this node?
|
||||
|
@ -374,7 +407,7 @@ public class XhtmlDocument extends DOMDocument {
|
|||
osw.write("<"+node.getNodeName());
|
||||
writeAttributes(node,osw);
|
||||
osw.write(">");
|
||||
if (nLevel>=0 && !bBlockPrettyPrint) { osw.write("\n"); }
|
||||
if (bPrettyPrint && nLevel>=0 && !bBlockPrettyPrint) { osw.write("\n"); }
|
||||
// Print children
|
||||
for (int i = 0; i < nLen; i++) {
|
||||
int nNextLevel;
|
||||
|
@ -385,7 +418,7 @@ public class XhtmlDocument extends DOMDocument {
|
|||
// Print end tag
|
||||
if (nLevel>=0 && !bBlockPrettyPrint) { writeSpaces(nLevel,osw); }
|
||||
osw.write("</"+node.getNodeName()+">");
|
||||
if (nLevel>=0) { osw.write("\n"); }
|
||||
if (bPrettyPrint && nLevel>=0) { osw.write("\n"); }
|
||||
}
|
||||
else { // empty element
|
||||
if (nLevel>=0) { writeSpaces(nLevel,osw); }
|
||||
|
@ -398,7 +431,7 @@ public class XhtmlDocument extends DOMDocument {
|
|||
else {
|
||||
osw.write(" />");
|
||||
}
|
||||
if (nLevel>=0) { osw.write("\n"); }
|
||||
if (bPrettyPrint && nLevel>=0) { osw.write("\n"); }
|
||||
}
|
||||
break;
|
||||
case Node.TEXT_NODE:
|
||||
|
@ -409,7 +442,7 @@ public class XhtmlDocument extends DOMDocument {
|
|||
osw.write("<!-- ");
|
||||
write(node.getNodeValue(),osw);
|
||||
osw.write(" -->");
|
||||
if (nLevel>=0) { osw.write("\n"); }
|
||||
if (bPrettyPrint && nLevel>=0) { osw.write("\n"); }
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -427,8 +460,10 @@ public class XhtmlDocument extends DOMDocument {
|
|||
}
|
||||
|
||||
private void writeSpaces(int nCount, OutputStreamWriter osw) throws IOException {
|
||||
if (bPrettyPrint) {
|
||||
for (int i=0; i<nCount; i++) { osw.write(" "); }
|
||||
}
|
||||
}
|
||||
|
||||
private void write(String s, OutputStreamWriter osw) throws IOException {
|
||||
// Allow null strings, though this means there is a bug somewhere...
|
||||
|
|
Loading…
Add table
Reference in a new issue