2000-11-14 13:42:50 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: XMLSectionExport.hxx,v $
|
|
|
|
*
|
2002-04-26 12:16:22 +00:00
|
|
|
* $Revision: 1.17 $
|
2000-11-14 13:42:50 +00:00
|
|
|
*
|
2002-04-26 12:16:22 +00:00
|
|
|
* last change: $Author: dvo $ $Date: 2002-04-26 13:16:22 $
|
2000-11-14 13:42:50 +00:00
|
|
|
*
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
* either of the following licenses
|
|
|
|
*
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
*
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
*
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
* =================================================
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
* Source License Version 1.1 (the "License"); You may not use this file
|
|
|
|
* except in compliance with the License. You may obtain a copy of the
|
|
|
|
* License at http://www.openoffice.org/license.html.
|
|
|
|
*
|
|
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
* obligations concerning the Software.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _XMLOFF_XMLSECTIONEXPORT_HXX_
|
|
|
|
#define _XMLOFF_XMLSECTIONEXPORT_HXX_
|
|
|
|
|
|
|
|
#ifndef _RTL_USTRING_HXX_
|
|
|
|
#include <rtl/ustring.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_UNO_REFERENCE_H_
|
|
|
|
#include <com/sun/star/uno/Reference.h>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_UNO_SEQUENCE_H_
|
|
|
|
#include <com/sun/star/uno/Sequence.h>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_BEANS_PROPERTYVALUE_HPP_
|
|
|
|
#include <com/sun/star/beans/PropertyValue.hpp>
|
|
|
|
#endif
|
2001-06-29 20:07:26 +00:00
|
|
|
#ifndef _XMLOFF_XMLTOKEN_HXX
|
|
|
|
#include "xmltoken.hxx"
|
|
|
|
#endif
|
2000-11-14 13:42:50 +00:00
|
|
|
|
|
|
|
class SvXMLExport;
|
|
|
|
class XMLTextParagraphExport;
|
|
|
|
namespace com { namespace sun { namespace star {
|
|
|
|
namespace text
|
|
|
|
{
|
|
|
|
class XTextSection;
|
|
|
|
class XDocumentIndex;
|
2001-02-13 15:55:00 +00:00
|
|
|
class XTextContent;
|
2000-11-14 13:42:50 +00:00
|
|
|
}
|
|
|
|
namespace beans
|
|
|
|
{
|
|
|
|
class XPropertySet;
|
|
|
|
}
|
|
|
|
namespace container
|
|
|
|
{
|
|
|
|
class XIndexReplace;
|
|
|
|
}
|
|
|
|
} } }
|
|
|
|
|
|
|
|
|
|
|
|
enum SectionTypeEnum
|
|
|
|
{
|
|
|
|
TEXT_SECTION_TYPE_SECTION,
|
|
|
|
|
|
|
|
// indices: keep index valued together and do not change order,
|
|
|
|
// because they are used to index into array
|
|
|
|
TEXT_SECTION_TYPE_TOC,
|
|
|
|
TEXT_SECTION_TYPE_TABLE,
|
|
|
|
TEXT_SECTION_TYPE_ILLUSTRATION,
|
|
|
|
TEXT_SECTION_TYPE_OBJECT,
|
|
|
|
TEXT_SECTION_TYPE_USER,
|
|
|
|
TEXT_SECTION_TYPE_ALPHABETICAL,
|
|
|
|
TEXT_SECTION_TYPE_BIBLIOGRAPHY,
|
|
|
|
|
|
|
|
// index header sections:
|
2000-12-02 20:43:40 +00:00
|
|
|
TEXT_SECTION_TYPE_HEADER,
|
2000-11-14 13:42:50 +00:00
|
|
|
|
|
|
|
TEXT_SECTION_TYPE_UNKNOWN
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class handles the export of sections and indices (which are,
|
|
|
|
* internally, just sections). It is intended to be used only from
|
|
|
|
* within the XMLTextParagraphExport class.
|
|
|
|
*/
|
|
|
|
class XMLSectionExport
|
|
|
|
{
|
|
|
|
const ::rtl::OUString sCondition;
|
|
|
|
const ::rtl::OUString sCreateFromChapter;
|
|
|
|
const ::rtl::OUString sCreateFromEmbeddedObjects;
|
|
|
|
const ::rtl::OUString sCreateFromGraphicObjects;
|
|
|
|
const ::rtl::OUString sCreateFromLabels;
|
|
|
|
const ::rtl::OUString sCreateFromMarks;
|
|
|
|
const ::rtl::OUString sCreateFromOtherEmbeddedObjects;
|
|
|
|
const ::rtl::OUString sCreateFromOutline;
|
|
|
|
const ::rtl::OUString sCreateFromStarCalc;
|
|
|
|
const ::rtl::OUString sCreateFromStarChart;
|
|
|
|
const ::rtl::OUString sCreateFromStarDraw;
|
|
|
|
const ::rtl::OUString sCreateFromStarImage;
|
|
|
|
const ::rtl::OUString sCreateFromStarMath;
|
|
|
|
const ::rtl::OUString sCreateFromTables;
|
|
|
|
const ::rtl::OUString sCreateFromTextFrames;
|
|
|
|
const ::rtl::OUString sDdeCommandElement;
|
|
|
|
const ::rtl::OUString sDdeCommandFile;
|
|
|
|
const ::rtl::OUString sDdeCommandType;
|
|
|
|
const ::rtl::OUString sFileLink;
|
|
|
|
const ::rtl::OUString sIsCaseSensitive;
|
|
|
|
const ::rtl::OUString sIsProtected;
|
|
|
|
const ::rtl::OUString sIsVisible;
|
|
|
|
const ::rtl::OUString sLabelCategory;
|
|
|
|
const ::rtl::OUString sLabelDisplayType;
|
|
|
|
const ::rtl::OUString sLevel;
|
|
|
|
const ::rtl::OUString sLevelFormat;
|
|
|
|
const ::rtl::OUString sLevelParagraphStyles;
|
|
|
|
const ::rtl::OUString sLinkRegion;
|
|
|
|
const ::rtl::OUString sMainEntryCharacterStyleName;
|
|
|
|
const ::rtl::OUString sParaStyleHeading;
|
|
|
|
const ::rtl::OUString sParaStyleLevel;
|
|
|
|
const ::rtl::OUString sTitle;
|
2001-08-23 08:40:43 +00:00
|
|
|
const ::rtl::OUString sName;
|
2000-11-14 13:42:50 +00:00
|
|
|
const ::rtl::OUString sUseAlphabeticalSeparators;
|
|
|
|
const ::rtl::OUString sUseCombinedEntries;
|
|
|
|
const ::rtl::OUString sUseDash;
|
|
|
|
const ::rtl::OUString sUseKeyAsEntry;
|
|
|
|
const ::rtl::OUString sUseLevelFromSource;
|
|
|
|
const ::rtl::OUString sUsePP;
|
|
|
|
const ::rtl::OUString sUseUpperCase;
|
2000-11-17 17:54:34 +00:00
|
|
|
const ::rtl::OUString sIsCommaSeparated;
|
2000-11-20 18:56:50 +00:00
|
|
|
const ::rtl::OUString sIsAutomaticUpdate;
|
|
|
|
const ::rtl::OUString sIsRelativeTabstops;
|
2000-11-21 10:53:19 +00:00
|
|
|
const ::rtl::OUString sCreateFromLevelParagraphStyles;
|
2000-11-30 15:46:20 +00:00
|
|
|
const ::rtl::OUString sDocumentIndex;
|
|
|
|
const ::rtl::OUString sContentSection;
|
2000-12-02 20:43:40 +00:00
|
|
|
const ::rtl::OUString sHeaderSection;
|
2000-11-14 13:42:50 +00:00
|
|
|
|
2001-02-20 12:49:46 +00:00
|
|
|
const ::rtl::OUString sTextSection;
|
|
|
|
const ::rtl::OUString sIsGlobalDocumentSection;
|
2001-05-02 14:04:56 +00:00
|
|
|
const ::rtl::OUString sProtectionKey;
|
2001-06-12 16:46:20 +00:00
|
|
|
const ::rtl::OUString sSortAlgorithm;
|
|
|
|
const ::rtl::OUString sLocale;
|
2002-01-09 11:57:21 +00:00
|
|
|
const ::rtl::OUString sUserIndexName;
|
2001-02-20 12:49:46 +00:00
|
|
|
|
2002-04-26 12:16:22 +00:00
|
|
|
const ::rtl::OUString sIsCurrentlyVisible;
|
|
|
|
|
2000-11-14 13:42:50 +00:00
|
|
|
const ::rtl::OUString sEmpty;
|
|
|
|
|
|
|
|
SvXMLExport& rExport;
|
|
|
|
XMLTextParagraphExport& rParaExport;
|
|
|
|
|
|
|
|
public:
|
|
|
|
XMLSectionExport(SvXMLExport& rExp,
|
|
|
|
XMLTextParagraphExport& rParaExp);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* export section or index start and source elements. This
|
|
|
|
* method handles the section styles, and delegates to the
|
|
|
|
* appropriate section or index method.
|
|
|
|
*/
|
|
|
|
void ExportSectionStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rSection,
|
|
|
|
sal_Bool bAutoStyles);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* export section or index end elements
|
|
|
|
*/
|
|
|
|
void ExportSectionEnd(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rSection,
|
|
|
|
sal_Bool bAutoStyles);
|
|
|
|
|
2001-02-13 15:55:00 +00:00
|
|
|
/**
|
|
|
|
* Should the content of this section be exported?
|
|
|
|
* (E.g. linked sections in global documents are not always exported)
|
|
|
|
*/
|
|
|
|
sal_Bool IsMuteSection(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rSection);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* XTextContent-version of IsMuteSection(Reference<XTextSection>&)
|
|
|
|
* returns *true* for all non-section elements
|
|
|
|
*/
|
|
|
|
sal_Bool IsMuteSection(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextContent > & rSection,
|
|
|
|
/// return value if this content doesn't support the section property
|
|
|
|
sal_Bool bDefault);
|
|
|
|
|
2001-02-20 12:49:46 +00:00
|
|
|
/**
|
|
|
|
* Determine whether rContent is contained in rEnclosingSection. If the
|
|
|
|
* current section of rContent can not be determined, return bDefault.
|
|
|
|
*/
|
|
|
|
sal_Bool IsInSection(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rEnclosingSection,
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextContent > & rContent,
|
|
|
|
/// return value if this content doesn't support the section property
|
|
|
|
sal_Bool bDefault);
|
|
|
|
|
2000-12-02 20:43:40 +00:00
|
|
|
/**
|
|
|
|
* Export the configuration element for bibliography indices.
|
|
|
|
*
|
|
|
|
* (This is part of XMLSectionExport because all section- and
|
|
|
|
* index-related items are handled here.)
|
|
|
|
*/
|
|
|
|
static void ExportBibliographyConfiguration(SvXMLExport& rExport);
|
2000-11-14 13:42:50 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
inline SvXMLExport& GetExport() { return rExport; }
|
|
|
|
inline XMLTextParagraphExport& GetParaExport() { return rParaExport; }
|
|
|
|
|
|
|
|
// export methods for section and index start:
|
|
|
|
|
2000-12-02 20:43:40 +00:00
|
|
|
/// export an index start element.
|
2000-11-30 15:46:20 +00:00
|
|
|
void ExportIndexStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XDocumentIndex > & rSection);
|
|
|
|
|
2000-12-02 20:43:40 +00:00
|
|
|
/// export an index header start element.
|
|
|
|
void ExportIndexHeaderStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rSection);
|
|
|
|
|
2000-11-14 13:42:50 +00:00
|
|
|
/// export a proper section (and source elements)
|
|
|
|
void ExportRegularSectionStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rSection);
|
|
|
|
|
|
|
|
/// export a table of content (and source element)
|
|
|
|
void ExportTableOfContentStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export a table index (and source element)
|
|
|
|
void ExportTableIndexStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export an object index (and source element)
|
|
|
|
void ExportObjectIndexStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export an illustration index (and source element)
|
|
|
|
void ExportIllustrationIndexStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export an alphabetical/keyword index (and source element)
|
|
|
|
void ExportAlphabeticalIndexStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export a user index (and source element)
|
|
|
|
void ExportUserIndexStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export the bibliography (and source element)
|
|
|
|
void ExportBibliographyStart(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rIndex);
|
|
|
|
|
|
|
|
|
|
|
|
// helper methods:
|
|
|
|
|
2000-11-30 15:46:20 +00:00
|
|
|
/**
|
2000-12-02 20:43:40 +00:00
|
|
|
* If this section is an index, the index is written in the
|
|
|
|
* rIndex parameter. The return value is sal_True for all "special"
|
|
|
|
* sections.
|
|
|
|
*
|
|
|
|
* Thus we have:
|
|
|
|
* return sal_False: regular section
|
|
|
|
* return sal_True, xIndex is empty: index header section
|
|
|
|
* return sal_True, xIndex is set: index section */
|
|
|
|
sal_Bool GetIndex(
|
2000-11-30 15:46:20 +00:00
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XTextSection > & rSection,
|
|
|
|
::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::text::XDocumentIndex > & rIndex);
|
|
|
|
|
2000-11-14 13:42:50 +00:00
|
|
|
/// map service name to section type
|
|
|
|
enum SectionTypeEnum MapSectionType(const ::rtl::OUString& rSectionName);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export the index element start (for all index types).
|
|
|
|
*
|
|
|
|
* All additional attributes (usually none) for the index element
|
|
|
|
* should have been set at GetExport() before calling this method.
|
|
|
|
*/
|
|
|
|
void ExportBaseIndexStart(
|
2001-09-24 12:40:55 +00:00
|
|
|
::xmloff::token::XMLTokenEnum eElement,
|
2000-11-14 13:42:50 +00:00
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export the index source element (common for all index types).
|
|
|
|
*
|
|
|
|
* All additional attributes for the source element should have
|
|
|
|
* been set at the GetExport() before calling this method.
|
|
|
|
*/
|
|
|
|
void ExportBaseIndexSource(
|
|
|
|
SectionTypeEnum eType, /// index type
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export the index body (common for all index types).
|
|
|
|
*/
|
|
|
|
void ExportBaseIndexBody(
|
|
|
|
SectionTypeEnum eType, /// index type
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper method to export common attributes for table and
|
|
|
|
* illustration indices
|
|
|
|
*/
|
|
|
|
void ExportTableAndIllustrationIndexSourceAttributes(
|
|
|
|
const ::com::sun::star::uno::Reference <
|
|
|
|
::com::sun::star::beans::XPropertySet > & rSection);
|
|
|
|
|
|
|
|
/// export one template for the specific index type
|
2001-08-27 16:18:32 +00:00
|
|
|
sal_Bool ExportIndexTemplate(
|
2000-11-14 13:42:50 +00:00
|
|
|
SectionTypeEnum eType, /// index type
|
|
|
|
sal_Int32 nLevel, /// outline level (if applicable)
|
|
|
|
const ::com::sun::star::uno::Reference<
|
|
|
|
::com::sun::star::beans::XPropertySet> & rPropSet,
|
|
|
|
::com::sun::star::uno::Sequence<
|
|
|
|
::com::sun::star::uno::Sequence<
|
|
|
|
::com::sun::star::beans::PropertyValue> > & rValues);
|
|
|
|
|
|
|
|
/// export a single template element (e.g. span or tab-stop)
|
|
|
|
void ExportIndexTemplateElement(
|
|
|
|
::com::sun::star::uno::Sequence<
|
|
|
|
::com::sun::star::beans::PropertyValue> & rValues);
|
|
|
|
|
|
|
|
/// export level paragraph styles
|
|
|
|
void ExportLevelParagraphStyles(
|
|
|
|
::com::sun::star::uno::Reference<
|
|
|
|
::com::sun::star::container::XIndexReplace> & xStyles);
|
|
|
|
|
|
|
|
|
|
|
|
/// helper to export boolean properties
|
|
|
|
void ExportBoolean(
|
|
|
|
const ::com::sun::star::uno::Reference<
|
|
|
|
::com::sun::star::beans::XPropertySet> & rPropSet,
|
|
|
|
const ::rtl::OUString& sPropertyName,
|
2001-06-29 20:07:26 +00:00
|
|
|
enum ::xmloff::token::XMLTokenEnum eAttributeName,
|
2000-11-14 13:42:50 +00:00
|
|
|
sal_Bool bDefault,
|
|
|
|
sal_Bool bInvert = sal_False);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|