File indexing completed on 2024-12-01 13:11:46
0001 /* This file is part of the KDE project 0002 0003 Copyright (C) 2013 Inge Wallin <inge@lysator.liu.se> 0004 0005 This library is free software; you can redistribute it and/or 0006 modify it under the terms of the GNU Library General Public 0007 License as published by the Free Software Foundation; either 0008 version 2 of the License, or (at your option) any later version. 0009 0010 This library is distributed in the hope that it will be useful, 0011 but WITHOUT ANY WARRANTY; without even the implied warranty of 0012 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 0013 Library General Public License for more details. 0014 0015 You should have received a copy of the GNU Library General Public License 0016 along with this library; see the file COPYING.LIB. If not, write to 0017 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, 0018 Boston, MA 02110-1301, USA. 0019 */ 0020 0021 #ifndef ODFTEXTREADERBACKEND_H 0022 #define ODFTEXTREADERBACKEND_H 0023 0024 // Calligra 0025 #include <KoXmlStreamReader.h> 0026 #include <KoFilter.h> 0027 0028 // this library 0029 #include "koodfreader_export.h" 0030 #include "OdfTextReader.h" 0031 0032 0033 class OdfReaderContext; 0034 0035 0036 /** @brief A default backend for the OdfTextReader class. 0037 * 0038 * This class defines an interface and the default behaviour for the 0039 * backend to the ODF text reader (@see OdfTextReader). When the 0040 * reader is called upon to traverse a certain XML tree, there will 0041 * be two parameters to the root traverse function: a pointer to a 0042 * backend object and a pointer to a context object. 0043 * 0044 * The reader will traverse (read) the XML tree and for every element 0045 * it comes across it will call a specific function in the backend and 0046 * every call will pass the pointer to the context object. 0047 * 0048 * Each supported XML tag has a corresponding callback function. This 0049 * callback function will be called twice: once when the tag is first 0050 * encountered anc once when the tag is closed. This means that an 0051 * element with no child elements will be called twice in succession. 0052 */ 0053 class KOODFREADER_EXPORT OdfTextReaderBackend 0054 { 0055 public: 0056 explicit OdfTextReaderBackend(); 0057 virtual ~OdfTextReaderBackend(); 0058 0059 // ---------------------------------------------------------------- 0060 // Text level functions: paragraphs, headings, sections, frames, objects, etc 0061 0062 DECLARE_BACKEND_FUNCTION(OfficeAnnotation); 0063 DECLARE_BACKEND_FUNCTION(OfficeAnnotationEnd); 0064 DECLARE_BACKEND_FUNCTION(DcCreator); 0065 DECLARE_BACKEND_FUNCTION(DcDate); 0066 0067 DECLARE_BACKEND_FUNCTION(TextH); 0068 DECLARE_BACKEND_FUNCTION(TextP); 0069 DECLARE_BACKEND_FUNCTION(TextList); 0070 0071 DECLARE_BACKEND_FUNCTION(TableTable); 0072 DECLARE_BACKEND_FUNCTION(TableTableColumnGroup); 0073 DECLARE_BACKEND_FUNCTION(TableTableColumn); 0074 DECLARE_BACKEND_FUNCTION(TableTableColumns); 0075 DECLARE_BACKEND_FUNCTION(TableTableHeaderColumns); 0076 DECLARE_BACKEND_FUNCTION(TableTableHeaderRows); 0077 DECLARE_BACKEND_FUNCTION(TableTableRowGroup); 0078 DECLARE_BACKEND_FUNCTION(TableTableRow); 0079 DECLARE_BACKEND_FUNCTION(TableTableRows); 0080 DECLARE_BACKEND_FUNCTION(TableTableCell); 0081 DECLARE_BACKEND_FUNCTION(TableCoveredTableCell); 0082 0083 // ---------------------------------------------------------------- 0084 // Paragraph level functions: spans, annotations, notes, etc. 0085 // This includes text content itself. 0086 0087 DECLARE_BACKEND_FUNCTION(TextA); 0088 DECLARE_BACKEND_FUNCTION(TextLineBreak); 0089 DECLARE_BACKEND_FUNCTION(TextSpan); 0090 DECLARE_BACKEND_FUNCTION(TextS); 0091 0092 // ---------------------------------------------------------------- 0093 // List level functions: list-header and list-item. 0094 0095 DECLARE_BACKEND_FUNCTION(TextListHeader); 0096 DECLARE_BACKEND_FUNCTION(TextListItem); 0097 DECLARE_BACKEND_FUNCTION(TextSoftPageBreak); 0098 0099 // ---------------------------------------------------------------- 0100 // Some special functions 0101 virtual void characterData(KoXmlStreamReader &reader, OdfReaderContext *context); 0102 virtual void textVariable(const QString &name, const QString &value); 0103 0104 private: 0105 class Private; 0106 Private * const d; 0107 }; 0108 0109 0110 #endif // ODFTEXTREADERBACKEND_H