Rearrange w2l list code

git-svn-id: svn://svn.code.sf.net/p/writer2latex/code/trunk@237 f0f2a975-2e09-46c8-9428-3b39399b9f3c
This commit is contained in:
henrikjust 2015-04-14 18:49:10 +00:00
parent 188effe5c6
commit fcd9c12304
12 changed files with 206 additions and 205 deletions

View file

@ -186,9 +186,7 @@ public class ConfigurationDialog extends ConfigurationDialogBase implements XSer
} }
@Override protected void setControls(DialogAccess dlg) { @Override protected void setControls(DialogAccess dlg) {
System.out.println("set controls");
super.setControls(dlg); super.setControls(dlg);
System.out.println("done setting controls");
String[] sCustomIds = config.getOption("template_ids").split(","); String[] sCustomIds = config.getOption("template_ids").split(",");
if (sCustomIds.length>0) { dlg.setComboBoxText("ContentId", sCustomIds[0]); } if (sCustomIds.length>0) { dlg.setComboBoxText("ContentId", sCustomIds[0]); }
if (sCustomIds.length>1) { dlg.setComboBoxText("HeaderId", sCustomIds[1]); } if (sCustomIds.length>1) { dlg.setComboBoxText("HeaderId", sCustomIds[1]); }

View file

@ -20,7 +20,7 @@
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.6 (2015-04-09) * Version 1.6 (2015-04-14)
* *
*/ */
@ -33,7 +33,7 @@ public class ConverterFactory {
// Version information // Version information
private static final String VERSION = "1.5.2"; private static final String VERSION = "1.5.2";
private static final String DATE = "2015-04-09"; private static final String DATE = "2015-04-14";
/** Return the Writer2LaTeX version in the form /** Return the Writer2LaTeX version in the form
* (major version).(minor version).(patch level)<br/> * (major version).(minor version).(patch level)<br/>

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2009 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.2 (2009-04-30) * Version 1.6 (2015-04-15)
* *
*/ */
@ -30,18 +30,14 @@ import org.w3c.dom.Element;
import org.w3c.dom.Node; import org.w3c.dom.Node;
import org.w3c.dom.NodeList; import org.w3c.dom.NodeList;
import writer2latex.latex.util.BeforeAfter;
import writer2latex.latex.util.Context; import writer2latex.latex.util.Context;
//import writer2latex.latex.util.HeadingMap;
import writer2latex.latex.util.StyleMap; import writer2latex.latex.util.StyleMap;
import writer2latex.office.ListStyle;
import writer2latex.office.OfficeReader; import writer2latex.office.OfficeReader;
//import writer2latex.office.TableReader;
import writer2latex.office.XMLString; import writer2latex.office.XMLString;
import writer2latex.util.Misc; import writer2latex.util.Misc;
/** /**
* <p>This class handles basic block content, including the main text body, * This class handles basic block content, such as the main text body,
* sections, tables, lists, headings and paragraphs.</p> * sections, tables, lists, headings and paragraphs.</p>
*/ */
public class BlockConverter extends ConverterHelper { public class BlockConverter extends ConverterHelper {
@ -144,15 +140,15 @@ public class BlockConverter extends ConverterHelper {
} }
else if (sTagName.equals(XMLString.TEXT_LIST)) { // oasis else if (sTagName.equals(XMLString.TEXT_LIST)) { // oasis
handleList(child,ldp,ic); palette.getListCv().handleList(child,ldp,ic);
} }
else if (sTagName.equals(XMLString.TEXT_UNORDERED_LIST)) { else if (sTagName.equals(XMLString.TEXT_UNORDERED_LIST)) {
handleList(child,ldp,ic); palette.getListCv().handleList(child,ldp,ic);
} }
else if (sTagName.equals(XMLString.TEXT_ORDERED_LIST)) { else if (sTagName.equals(XMLString.TEXT_ORDERED_LIST)) {
handleList(child,ldp,ic); palette.getListCv().handleList(child,ldp,ic);
} }
else if (sTagName.equals(XMLString.TABLE_TABLE)) { else if (sTagName.equals(XMLString.TABLE_TABLE)) {
// Next node *could* be a caption // Next node *could* be a caption
@ -230,148 +226,5 @@ public class BlockConverter extends ConverterHelper {
} }
/** <p> Process a list (text:ordered-lst or text:unordered-list tag)</p>
* @param node The element containing the list
* @param ldp the <code>LaTeXDocumentPortion</code> to which
* LaTeX code should be added
* @param oc the current context
*/
public void handleList(Element node, LaTeXDocumentPortion ldp, Context oc) {
// Set up new context
Context ic = (Context) oc.clone();
ic.incListLevel();
if ("true".equals(node.getAttribute(XMLString.TEXT_CONTINUE_NUMBERING))) { ic.setInContinuedList(true); }
// Get the style name, if we don't know it already
if (ic.getListStyleName()==null) {
ic.setListStyleName(node.getAttribute(XMLString.TEXT_STYLE_NAME));
}
// Use the style to determine the type of list
ListStyle style = ofr.getListStyle(ic.getListStyleName());
boolean bOrdered = style!=null && style.isNumber(ic.getListLevel());
// If the list contains headings, ignore it!
if (ic.isIgnoreLists() || listContainsHeadings(node)) {
ic.setIgnoreLists(true);
traverseList(node,ldp,ic);
return;
}
// Apply the style
BeforeAfter ba = new BeforeAfter();
palette.getListSc().applyListStyle(bOrdered,ba,ic);
// Export the list
if (ba.getBefore().length()>0) { ldp.append(ba.getBefore()).nl(); }
traverseList(node,ldp,ic);
if (ba.getAfter().length()>0) { ldp.append(ba.getAfter()).nl(); }
}
/*
* Process the contents of a list
*/
private void traverseList (Element node, LaTeXDocumentPortion ldp, Context oc) {
if (node.hasChildNodes()) {
NodeList list = node.getChildNodes();
int nLen = list.getLength();
for (int i = 0; i < nLen; i++) {
Node child = list.item(i);
if (child.getNodeType() == Node.ELEMENT_NODE) {
String nodeName = child.getNodeName();
palette.getInfo().addDebugInfo((Element)child,ldp);
if (nodeName.equals(XMLString.TEXT_LIST_ITEM)) {
handleListItem((Element)child,ldp,oc);
}
if (nodeName.equals(XMLString.TEXT_LIST_HEADER)) {
handleListItem((Element)child,ldp,oc);
}
}
}
}
}
private void handleListItem(Element node, LaTeXDocumentPortion ldp, Context oc) {
// Are we ignoring this list?
if (oc.isIgnoreLists()) {
traverseBlockText(node,ldp,oc);
return;
}
// Apply the style
BeforeAfter ba = new BeforeAfter();
palette.getListSc().applyListItemStyle(
oc.getListStyleName(), oc.getListLevel(),
node.getNodeName().equals(XMLString.TEXT_LIST_HEADER),
"true".equals(node.getAttribute(XMLString.TEXT_RESTART_NUMBERING)),
Misc.getPosInteger(node.getAttribute(XMLString.TEXT_START_VALUE),1)-1,
ba,oc);
// export the list item (note the special treatment of lists in tables)
if (ba.getBefore().length()>0) {
ldp.append(ba.getBefore());
if (config.formatting()>=LaTeXConfig.CONVERT_MOST && !oc.isInTable()) { ldp.nl(); }
}
traverseBlockText(node,ldp,oc);
if (ba.getAfter().length()>0 || oc.isInTable()) { ldp.append(ba.getAfter()).nl(); }
}
/*
* Helper: Check to see, if this list contains headings
* (in that case we will ignore the list!)
*/
private boolean listContainsHeadings (Node node) {
if (node.hasChildNodes()) {
NodeList nList = node.getChildNodes();
int len = nList.getLength();
for (int i = 0; i < len; i++) {
Node child = nList.item(i);
if (child.getNodeType() == Node.ELEMENT_NODE) {
String nodeName = child.getNodeName();
if (nodeName.equals(XMLString.TEXT_LIST_ITEM)) {
if (listItemContainsHeadings(child)) return true;
}
if (nodeName.equals(XMLString.TEXT_LIST_HEADER)) {
if (listItemContainsHeadings(child)) return true;
}
}
}
}
return false;
}
private boolean listItemContainsHeadings(Node node) {
if (node.hasChildNodes()) {
NodeList nList = node.getChildNodes();
int len = nList.getLength();
for (int i = 0; i < len; i++) {
Node child = nList.item(i);
if (child.getNodeType() == Node.ELEMENT_NODE) {
String nodeName = child.getNodeName();
if(nodeName.equals(XMLString.TEXT_H)) {
return true;
}
if (nodeName.equals(XMLString.TEXT_LIST)) {
if (listContainsHeadings(child)) return true;
}
if (nodeName.equals(XMLString.TEXT_ORDERED_LIST)) {
if (listContainsHeadings(child)) return true;
}
if (nodeName.equals(XMLString.TEXT_UNORDERED_LIST)) {
if (listContainsHeadings(child)) return true;
}
}
}
}
return false;
}
} }

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2008 by Henrik Just * Copyright: 2002-2016 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.0 (2008-09-08) * Version 1.6 (2015-04-15)
* *
*/ */
@ -43,7 +43,6 @@ public abstract class ConverterHelper {
this.palette = palette; this.palette = palette;
} }
public void appendDeclarations(LaTeXDocumentPortion pack, LaTeXDocumentPortion decl) { public abstract void appendDeclarations(LaTeXDocumentPortion pack, LaTeXDocumentPortion decl);
}
} }

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-19) * Version 1.6 (2015-04-14)
* *
*/ */
@ -65,7 +65,6 @@ public final class ConverterPalette extends ConverterBase {
private I18n i18n; private I18n i18n;
private ColorConverter colorCv; private ColorConverter colorCv;
private CharStyleConverter charSc; private CharStyleConverter charSc;
private ListStyleConverter listSc;
private PageStyleConverter pageSc; private PageStyleConverter pageSc;
private BlockConverter blockCv; private BlockConverter blockCv;
private ParConverter parCv; private ParConverter parCv;
@ -74,6 +73,7 @@ public final class ConverterPalette extends ConverterBase {
private BibConverter bibCv; private BibConverter bibCv;
private SectionConverter sectionCv; private SectionConverter sectionCv;
private TableConverter tableCv; private TableConverter tableCv;
private ListConverter listCv;
private NoteConverter noteCv; private NoteConverter noteCv;
private CaptionConverter captionCv; private CaptionConverter captionCv;
private InlineConverter inlineCv; private InlineConverter inlineCv;
@ -102,7 +102,6 @@ public final class ConverterPalette extends ConverterBase {
public I18n getI18n() { return i18n; } public I18n getI18n() { return i18n; }
public ColorConverter getColorCv() { return colorCv; } public ColorConverter getColorCv() { return colorCv; }
public CharStyleConverter getCharSc() { return charSc; } public CharStyleConverter getCharSc() { return charSc; }
public ListStyleConverter getListSc() { return listSc; }
public PageStyleConverter getPageSc() { return pageSc; } public PageStyleConverter getPageSc() { return pageSc; }
public BlockConverter getBlockCv() { return blockCv; } public BlockConverter getBlockCv() { return blockCv; }
public ParConverter getParCv() { return parCv; } public ParConverter getParCv() { return parCv; }
@ -111,6 +110,7 @@ public final class ConverterPalette extends ConverterBase {
public BibConverter getBibCv() { return bibCv; } public BibConverter getBibCv() { return bibCv; }
public SectionConverter getSectionCv() { return sectionCv; } public SectionConverter getSectionCv() { return sectionCv; }
public TableConverter getTableCv() { return tableCv; } public TableConverter getTableCv() { return tableCv; }
public ListConverter getListCv() { return listCv; }
public NoteConverter getNoteCv() { return noteCv; } public NoteConverter getNoteCv() { return noteCv; }
public CaptionConverter getCaptionCv() { return captionCv; } public CaptionConverter getCaptionCv() { return captionCv; }
public InlineConverter getInlineCv() { return inlineCv; } public InlineConverter getInlineCv() { return inlineCv; }
@ -157,7 +157,6 @@ public final class ConverterPalette extends ConverterBase {
} }
colorCv = new ColorConverter(ofr,config,this); colorCv = new ColorConverter(ofr,config,this);
charSc = new CharStyleConverter(ofr,config,this); charSc = new CharStyleConverter(ofr,config,this);
listSc = new ListStyleConverter(ofr,config,this);
pageSc = new PageStyleConverter(ofr,config,this); pageSc = new PageStyleConverter(ofr,config,this);
blockCv = new BlockConverter(ofr,config,this); blockCv = new BlockConverter(ofr,config,this);
parCv = new ParConverter(ofr,config,this); parCv = new ParConverter(ofr,config,this);
@ -166,6 +165,7 @@ public final class ConverterPalette extends ConverterBase {
bibCv = new BibConverter(ofr,config,this); bibCv = new BibConverter(ofr,config,this);
sectionCv = new SectionConverter(ofr,config,this); sectionCv = new SectionConverter(ofr,config,this);
tableCv = new TableConverter(ofr,config,this); tableCv = new TableConverter(ofr,config,this);
listCv = new ListConverter(ofr,config,this);
noteCv = new NoteConverter(ofr,config,this); noteCv = new NoteConverter(ofr,config,this);
captionCv = new CaptionConverter(ofr,config,this); captionCv = new CaptionConverter(ofr,config,this);
inlineCv = new InlineConverter(ofr,config,this); inlineCv = new InlineConverter(ofr,config,this);
@ -211,13 +211,13 @@ public final class ConverterPalette extends ConverterBase {
charSc.appendDeclarations(packages,declarations); charSc.appendDeclarations(packages,declarations);
headingCv.appendDeclarations(packages,declarations); headingCv.appendDeclarations(packages,declarations);
parCv.appendDeclarations(packages,declarations); parCv.appendDeclarations(packages,declarations);
listSc.appendDeclarations(packages,declarations);
pageSc.appendDeclarations(packages,declarations); pageSc.appendDeclarations(packages,declarations);
blockCv.appendDeclarations(packages,declarations); blockCv.appendDeclarations(packages,declarations);
indexCv.appendDeclarations(packages,declarations); indexCv.appendDeclarations(packages,declarations);
bibCv.appendDeclarations(packages,declarations); bibCv.appendDeclarations(packages,declarations);
sectionCv.appendDeclarations(packages,declarations); sectionCv.appendDeclarations(packages,declarations);
tableCv.appendDeclarations(packages,declarations); tableCv.appendDeclarations(packages,declarations);
listCv.appendDeclarations(packages,declarations);
captionCv.appendDeclarations(packages,declarations); captionCv.appendDeclarations(packages,declarations);
inlineCv.appendDeclarations(packages,declarations); inlineCv.appendDeclarations(packages,declarations);
fieldCv.appendDeclarations(packages,declarations); fieldCv.appendDeclarations(packages,declarations);

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-18) * Version 1.6 (2015-04-15)
* *
*/ */
@ -182,7 +182,7 @@ public class FieldConverter extends ConverterHelper {
.append("\\renewcommand\\the") .append("\\renewcommand\\the")
.append(seqnames.getExportName(sName)) .append(seqnames.getExportName(sName))
.append("{").append(sPrefix) .append("{").append(sPrefix)
.append(ListStyleConverter.numFormat(sNumFormat)) .append(ListConverter.numFormat(sNumFormat))
.append("{").append(seqnames.getExportName(sName)) .append("{").append(seqnames.getExportName(sName))
.append("}}").nl(); .append("}}").nl();
} }

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-15) * Version 1.6 (2015-04-14)
* *
*/ */
@ -277,7 +277,7 @@ public class HeadingConverter extends ConverterHelper {
ListStyle outline = ofr.getOutlineStyle(); ListStyle outline = ofr.getOutlineStyle();
String[] sNumFormat = new String[6]; String[] sNumFormat = new String[6];
for (int i=nMaxLevel; i>=1; i--) { for (int i=nMaxLevel; i>=1; i--) {
sNumFormat[i] = ListStyleConverter.numFormat(outline.getLevelProperty(i, sNumFormat[i] = ListConverter.numFormat(outline.getLevelProperty(i,
XMLString.STYLE_NUM_FORMAT)); XMLString.STYLE_NUM_FORMAT));
if (sNumFormat[i]==null || "".equals(sNumFormat[i])) { if (sNumFormat[i]==null || "".equals(sNumFormat[i])) {
nSecnumdepth = i-1; nSecnumdepth = i-1;

View file

@ -1,6 +1,6 @@
/************************************************************************ /************************************************************************
* *
* ListStyleConverter.java * ListConverter.java
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public * modify it under the terms of the GNU Lesser General Public
@ -16,37 +16,40 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-06) * Version 1.6 (2015-04-14)
* *
*/ */
package writer2latex.latex; package writer2latex.latex;
import java.util.Hashtable; import java.util.Hashtable;
import writer2latex.util.*; import org.w3c.dom.Element;
import writer2latex.office.*; import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import writer2latex.latex.util.BeforeAfter; import writer2latex.latex.util.BeforeAfter;
import writer2latex.latex.util.Context; import writer2latex.latex.util.Context;
import writer2latex.office.ListStyle;
import writer2latex.office.OfficeReader;
import writer2latex.office.XMLString;
import writer2latex.util.Misc;
/* This class creates LaTeX code from OOo list styles public class ListConverter extends StyleConverter {
*/
public class ListStyleConverter extends StyleConverter {
boolean bNeedSaveEnumCounter = false; boolean bNeedSaveEnumCounter = false;
private Hashtable<String, String[]> listStyleLevelNames = new Hashtable<String, String[]>(); private Hashtable<String, String[]> listStyleLevelNames = new Hashtable<String, String[]>();
/** <p>Constructs a new <code>ListStyleConverter</code>.</p>
*/ /** Construct a new <code>ListConverter</code>
public ListStyleConverter(OfficeReader ofr, LaTeXConfig config, */
ConverterPalette palette) { public ListConverter(OfficeReader ofr, LaTeXConfig config, ConverterPalette palette) {
super(ofr,config,palette); super(ofr,config,palette);
} }
public void appendDeclarations(LaTeXDocumentPortion pack, LaTeXDocumentPortion decl) { @Override public void appendDeclarations(LaTeXDocumentPortion pack, LaTeXDocumentPortion decl) {
if (config.formatting()>=LaTeXConfig.CONVERT_MOST || !styleNames.isEmpty()) { if (config.formatting()>=LaTeXConfig.CONVERT_MOST || !styleNames.isEmpty()) {
decl.append("% List styles").nl(); decl.append("% List styles").nl();
// May need an extra counter to handle continued numbering in lists // May need an extra counter to handle continued numbering in lists
@ -66,8 +69,149 @@ public class ListStyleConverter extends StyleConverter {
} }
} }
/** <p> Process a list (text:ordered-lst or text:unordered-list tag)</p>
* @param node The element containing the list
* @param ldp the <code>LaTeXDocumentPortion</code> to which
* LaTeX code should be added
* @param oc the current context
*/
public void handleList(Element node, LaTeXDocumentPortion ldp, Context oc) {
// Set up new context
Context ic = (Context) oc.clone();
ic.incListLevel();
if ("true".equals(node.getAttribute(XMLString.TEXT_CONTINUE_NUMBERING))) { ic.setInContinuedList(true); }
// Get the style name, if we don't know it already
if (ic.getListStyleName()==null) {
ic.setListStyleName(node.getAttribute(XMLString.TEXT_STYLE_NAME));
}
// Use the style to determine the type of list
ListStyle style = ofr.getListStyle(ic.getListStyleName());
boolean bOrdered = style!=null && style.isNumber(ic.getListLevel());
// If the list contains headings, ignore it!
if (ic.isIgnoreLists() || listContainsHeadings(node)) {
ic.setIgnoreLists(true);
traverseList(node,ldp,ic);
return;
}
// Apply the style
BeforeAfter ba = new BeforeAfter();
applyListStyle(bOrdered,ba,ic);
// Export the list
if (ba.getBefore().length()>0) { ldp.append(ba.getBefore()).nl(); }
traverseList(node,ldp,ic);
if (ba.getAfter().length()>0) { ldp.append(ba.getAfter()).nl(); }
}
/*
* Process the contents of a list
*/
private void traverseList (Element node, LaTeXDocumentPortion ldp, Context oc) {
if (node.hasChildNodes()) {
NodeList list = node.getChildNodes();
int nLen = list.getLength();
for (int i = 0; i < nLen; i++) {
Node child = list.item(i);
if (child.getNodeType() == Node.ELEMENT_NODE) {
String nodeName = child.getNodeName();
palette.getInfo().addDebugInfo((Element)child,ldp);
if (nodeName.equals(XMLString.TEXT_LIST_ITEM)) {
handleListItem((Element)child,ldp,oc);
}
if (nodeName.equals(XMLString.TEXT_LIST_HEADER)) {
handleListItem((Element)child,ldp,oc);
}
}
}
}
}
private void handleListItem(Element node, LaTeXDocumentPortion ldp, Context oc) {
// Are we ignoring this list?
if (oc.isIgnoreLists()) {
palette.getBlockCv().traverseBlockText(node,ldp,oc);
return;
}
// Apply the style
BeforeAfter ba = new BeforeAfter();
applyListItemStyle(
oc.getListStyleName(), oc.getListLevel(),
node.getNodeName().equals(XMLString.TEXT_LIST_HEADER),
"true".equals(node.getAttribute(XMLString.TEXT_RESTART_NUMBERING)),
Misc.getPosInteger(node.getAttribute(XMLString.TEXT_START_VALUE),1)-1,
ba,oc);
// export the list item (note the special treatment of lists in tables)
if (ba.getBefore().length()>0) {
ldp.append(ba.getBefore());
if (config.formatting()>=LaTeXConfig.CONVERT_MOST && !oc.isInTable()) { ldp.nl(); }
}
palette.getBlockCv().traverseBlockText(node,ldp,oc);
if (ba.getAfter().length()>0 || oc.isInTable()) { ldp.append(ba.getAfter()).nl(); }
}
/*
* Helper: Check to see, if this list contains headings
* (in that case we will ignore the list!)
*/
private boolean listContainsHeadings (Node node) {
if (node.hasChildNodes()) {
NodeList nList = node.getChildNodes();
int len = nList.getLength();
for (int i = 0; i < len; i++) {
Node child = nList.item(i);
if (child.getNodeType() == Node.ELEMENT_NODE) {
String nodeName = child.getNodeName();
if (nodeName.equals(XMLString.TEXT_LIST_ITEM)) {
if (listItemContainsHeadings(child)) return true;
}
if (nodeName.equals(XMLString.TEXT_LIST_HEADER)) {
if (listItemContainsHeadings(child)) return true;
}
}
}
}
return false;
}
private boolean listItemContainsHeadings(Node node) {
if (node.hasChildNodes()) {
NodeList nList = node.getChildNodes();
int len = nList.getLength();
for (int i = 0; i < len; i++) {
Node child = nList.item(i);
if (child.getNodeType() == Node.ELEMENT_NODE) {
String nodeName = child.getNodeName();
if(nodeName.equals(XMLString.TEXT_H)) {
return true;
}
if (nodeName.equals(XMLString.TEXT_LIST)) {
if (listContainsHeadings(child)) return true;
}
if (nodeName.equals(XMLString.TEXT_ORDERED_LIST)) {
if (listContainsHeadings(child)) return true;
}
if (nodeName.equals(XMLString.TEXT_UNORDERED_LIST)) {
if (listContainsHeadings(child)) return true;
}
}
}
}
return false;
}
// Convert style information
/** <p>Apply a list style to an ordered or unordered list.</p> */ /** <p>Apply a list style to an ordered or unordered list.</p> */
public void applyListStyle(boolean bOrdered, BeforeAfter ba, Context oc) { private void applyListStyle(boolean bOrdered, BeforeAfter ba, Context oc) {
// Step 1. We may have a style map, this always takes precedence // Step 1. We may have a style map, this always takes precedence
String sDisplayName = ofr.getListStyles().getDisplayName(oc.getListStyleName()); String sDisplayName = ofr.getListStyles().getDisplayName(oc.getListStyleName());
if (config.getListStyleMap().contains(sDisplayName)) { if (config.getListStyleMap().contains(sDisplayName)) {
@ -134,7 +278,7 @@ public class ListStyleConverter extends StyleConverter {
} }
/** <p>Apply a list style to a list item.</p> */ /** <p>Apply a list style to a list item.</p> */
public void applyListItemStyle(String sStyleName, int nLevel, boolean bHeader, private void applyListItemStyle(String sStyleName, int nLevel, boolean bHeader,
boolean bRestart, int nStartValue, BeforeAfter ba, Context oc) { boolean bRestart, int nStartValue, BeforeAfter ba, Context oc) {
// Step 1. We may have a style map, this always takes precedence // Step 1. We may have a style map, this always takes precedence
String sDisplayName = ofr.getListStyles().getDisplayName(sStyleName); String sDisplayName = ofr.getListStyles().getDisplayName(sStyleName);

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-18) * Version 1.6 (2015-04-15)
* *
*/ */
@ -298,15 +298,15 @@ public class NoteConverter extends ConverterHelper {
} }
else if (nodeName.equals(XMLString.TEXT_LIST)) { // oasis else if (nodeName.equals(XMLString.TEXT_LIST)) { // oasis
palette.getBlockCv().handleList(child,ldp,oc); palette.getListCv().handleList(child,ldp,oc);
} }
if (nodeName.equals(XMLString.TEXT_ORDERED_LIST)) { if (nodeName.equals(XMLString.TEXT_ORDERED_LIST)) {
palette.getBlockCv().handleList(child,ldp,oc); palette.getListCv().handleList(child,ldp,oc);
} }
if (nodeName.equals(XMLString.TEXT_UNORDERED_LIST)) { if (nodeName.equals(XMLString.TEXT_UNORDERED_LIST)) {
palette.getBlockCv().handleList(child,ldp,oc); palette.getListCv().handleList(child,ldp,oc);
} }
} }
} }
@ -343,7 +343,7 @@ public class NoteConverter extends ConverterHelper {
String sFormat = notes.getProperty(XMLString.STYLE_NUM_FORMAT); String sFormat = notes.getProperty(XMLString.STYLE_NUM_FORMAT);
if (sFormat!=null) { if (sFormat!=null) {
ldp.append("\\renewcommand\\the").append(sType).append("note{") ldp.append("\\renewcommand\\the").append(sType).append("note{")
.append(ListStyleConverter.numFormat(sFormat)) .append(ListConverter.numFormat(sFormat))
.append("{").append(sType).append("note}}").nl(); .append("{").append(sType).append("note}}").nl();
} }

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-19 * Version 1.6 (2015-04-15)
* *
*/ */
@ -271,7 +271,7 @@ public class PageStyleConverter extends StyleConverter {
String sNumFormat = pageLayout.getProperty(XMLString.STYLE_NUM_FORMAT); String sNumFormat = pageLayout.getProperty(XMLString.STYLE_NUM_FORMAT);
if (sNumFormat!=null) { if (sNumFormat!=null) {
ldp.append(" \\renewcommand\\thepage{") ldp.append(" \\renewcommand\\thepage{")
.append(ListStyleConverter.numFormat(sNumFormat)) .append(ListConverter.numFormat(sNumFormat))
.append("{page}}").nl(); .append("{page}}").nl();
} }
String sPageNumber = pageLayout.getProperty(XMLString.STYLE_FIRST_PAGE_NUMBER); String sPageNumber = pageLayout.getProperty(XMLString.STYLE_FIRST_PAGE_NUMBER);

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2014 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.4 (2014-09-16) * Version 1.6 (2015-04-15)
* *
*/ */
@ -293,6 +293,9 @@ public class TableFormatter extends ConverterHelper {
} }
} }
@Override public void appendDeclarations(LaTeXDocumentPortion pack, LaTeXDocumentPortion decl) {
}
/** is this a longtable? */ /** is this a longtable? */
public boolean isLongtable() { return bIsLongtable; } public boolean isLongtable() { return bIsLongtable; }
@ -467,4 +470,5 @@ public class TableFormatter extends ConverterHelper {
palette.getColorCv().applyBgColor("\\cellcolor",sCellColor[nRow][nCol],ba,context); palette.getColorCv().applyBgColor("\\cellcolor",sCellColor[nRow][nCol],ba,context);
} }
} }

View file

@ -16,11 +16,11 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA * MA 02111-1307 USA
* *
* Copyright: 2002-2008 by Henrik Just * Copyright: 2002-2015 by Henrik Just
* *
* All Rights Reserved. * All Rights Reserved.
* *
* Version 1.0 (2008-09-08) * Version 1.6 (2015-04-15)
* *
*/ */
@ -43,6 +43,10 @@ import writer2latex.latex.ConverterPalette;
*/ */
public class Info extends ConverterHelper { public class Info extends ConverterHelper {
@Override public void appendDeclarations(LaTeXDocumentPortion pack, LaTeXDocumentPortion decl) {
// Currently nothing
}
public Info(OfficeReader ofr, LaTeXConfig config, ConverterPalette palette) { public Info(OfficeReader ofr, LaTeXConfig config, ConverterPalette palette) {
super(ofr,config,palette); super(ofr,config,palette);
} }
@ -72,5 +76,4 @@ public class Info extends ConverterHelper {
} }
} }
} }