/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 . */ #ifndef INCLUDED_WRITERFILTER_SOURCE_DMAPPER_TABLEMANAGER_HXX #define INCLUDED_WRITERFILTER_SOURCE_DMAPPER_TABLEMANAGER_HXX #include #include #include #include #include #include #include #include namespace writerfilter { namespace dmapper { /** Class to handle events generated by TableManager::resolveCurrentTable */ class TableDataHandler { public: typedef boost::shared_ptr Pointer_t; /** Handle start of table. @param nRows number of rows in the table @param nDepth depth of the table in surrounding table hierarchy @param pProps properties of the table */ virtual void startTable(unsigned int nRows, unsigned int nDepth, TablePropertyMapPtr pProps) = 0; /** Handle end of table. */ virtual void endTable(unsigned int nestedTableLevel) = 0; /** Handle start of row. @param nCols number of columns in the table @param pProps properties of the row */ virtual void startRow(unsigned int nCols, TablePropertyMapPtr pProps) = 0; /** Handle end of row. */ virtual void endRow() = 0; /** Handle start of cell. @param rT start handle of the cell @param pProps properties of the cell */ virtual void startCell(const css::uno::Reference& xTextRange, TablePropertyMapPtr pProps) = 0; /** Handle end of cell. @param rT end handle of cell */ virtual void endCell(const css::uno::Reference& xTextRange) = 0; protected: ~TableDataHandler() {} }; /** The table manager. This class gets forwarded events from the tokenizer. It gathers the table data and after ending the table generates events for the table structure. The events have to be handles by a TableDataHandler. */ class TableManager { #ifdef DEBUG_WRITERFILTER TagLogger::Pointer_t mpTableLogger; #endif class TableManagerState { /** properties at the current point in document */ TablePropertyMapPtr mpProps; /** properties of the current cell */ TablePropertyMapPtr mpCellProps; /** properties of the current row */ TablePropertyMapPtr mpRowProps; /** properties of the current table */ std::stack mTableProps; /** true if at the end of a row */ bool mbRowEnd; /** true when in a cell */ bool mbInCell; /** true when at the end of a cell */ bool mbCellEnd; public: /** Constructor */ TableManagerState() : mbRowEnd(false), mbInCell(false), mbCellEnd(false) { } virtual ~TableManagerState() { } void startLevel() { TablePropertyMapPtr pProps; mTableProps.push(pProps); } void endLevel() { mTableProps.pop(); } /** Reset to initial state at beginning of row. */ void resetCellSpecifics() { mbRowEnd = false; mbInCell = false; mbCellEnd = false; } void resetProps() { mpProps.reset(); } void setProps(TablePropertyMapPtr pProps) { mpProps = pProps; } TablePropertyMapPtr getProps() { return mpProps; } void resetCellProps() { mpCellProps.reset(); } void setCellProps(TablePropertyMapPtr pProps) { mpCellProps = pProps; } TablePropertyMapPtr getCellProps() { return mpCellProps; } void resetRowProps() { mpRowProps.reset(); } void setRowProps(TablePropertyMapPtr pProps) { mpRowProps = pProps; } TablePropertyMapPtr getRowProps() { return mpRowProps; } void resetTableProps() { if (mTableProps.size() > 0) mTableProps.top().reset(); } void setTableProps(TablePropertyMapPtr pProps) { if (mTableProps.size() > 0) mTableProps.top() = pProps; } TablePropertyMapPtr getTableProps() { TablePropertyMapPtr pResult; if (mTableProps.size() > 0) pResult = mTableProps.top(); return pResult; } void setInCell(bool bInCell) { mbInCell = bInCell; } bool isInCell() const { return mbInCell; } void setCellEnd(bool bCellEnd) { mbCellEnd = bCellEnd; } bool isCellEnd() const { return mbCellEnd; } void setRowEnd(bool bRowEnd) { mbRowEnd = bRowEnd; } bool isRowEnd() const { return mbRowEnd; } }; /** handle for the current position in document */ css::uno::Reference mCurHandle; TableManagerState mState; protected: TablePropertyMapPtr getProps() { return mState.getProps(); } void setProps(TablePropertyMapPtr pProps) { mState.setProps(pProps); } void resetProps() { mState.resetProps(); } TablePropertyMapPtr getCellProps() { return mState.getCellProps(); } void setCellProps(TablePropertyMapPtr pProps) { mState.setCellProps(pProps); } void resetCellProps() { mState.resetCellProps(); } TablePropertyMapPtr getRowProps() { return mState.getRowProps(); } void setRowProps(TablePropertyMapPtr pProps) { mState.setRowProps(pProps); } void resetRowProps() { mState.resetRowProps(); } void setInCell(bool bInCell) { mState.setInCell(bInCell); } bool isInCell() const { return mState.isInCell(); } void setCellEnd(bool bCellEnd) { mState.setCellEnd(bCellEnd); } bool isCellEnd() const { return mState.isCellEnd(); } void setRowEnd(bool bRowEnd) { mState.setRowEnd(bRowEnd); } bool isRowEnd() const { return mState.isRowEnd(); } TablePropertyMapPtr getTableProps() { return mState.getTableProps(); } void setTableProps(TablePropertyMapPtr pProps) { mState.setTableProps(pProps); } void resetTableProps() { mState.resetTableProps(); } css::uno::Reference getHandle() { return mCurHandle; } void setHandle(const css::uno::Reference& rHandle) { mCurHandle = rHandle; } private: typedef boost::shared_ptr< css::uno::Reference > T_p; /** depth of the current cell */ sal_uInt32 mnTableDepthNew; /** depth of the previous cell */ sal_uInt32 mnTableDepth; /** stack of table data for each level of nested tables there is one frame in the stack */ std::stack mTableDataStack; RowData::Pointer_t mpUnfinishedRow; bool mbKeepUnfinishedRow; /** handler for resolveCurrentTable */ TableDataHandler::Pointer_t mpTableDataHandler; /** Set flag which indicates the current handle is in a cell. */ void inCell(); /** Set flag which indicate the current handle is at the end of a cell. */ void endCell(); /** Set the table depth of the current cell. @param nDepth the cell depth */ void cellDepth(sal_uInt32 nDepth); /** Set flag indication the current handle is at the end of a row. */ void endRow(); /** Resolve the current table to the TableDataHandler. */ void resolveCurrentTable(); /** Open a cell at current level. */ void openCell(const css::uno::Reference& handle, TablePropertyMapPtr pProps); /** Close a cell at current level. */ void closeCell(const css::uno::Reference& handle); /** Ensure a cell is open at the current level. */ void ensureOpenCell(TablePropertyMapPtr pProps); protected: /** Return current table depth. */ sal_uInt32 getTableDepthNew() { return mnTableDepthNew; } /** Return the current table difference, i.e. 1 if we are in the first cell of a new table, etc. */ sal_uInt32 getTableDepthDifference() { return mnTableDepthNew - mnTableDepth; } /** Action to be carried out at the end of the last paragraph of a cell. */ virtual void endOfCellAction(); /** Action to be carried out at the end of the "table row" paragraph. */ virtual void endOfRowAction(); /** let the derived class clear their table related data */ virtual void clearData(); /** Should we keep the unfinished row in endLevel to initialize the table data in the following startLevel. */ void setKeepUnfinishedRow(bool bKeep) { mbKeepUnfinishedRow = bKeep; } public: TableManager(); virtual ~TableManager(){} /** Set handler for resolveCurrentTable. @param pTableDataHandler the handler */ void setHandler(TableDataHandler::Pointer_t pTableDataHandler); /** Set the current handle. @param rHandle the handle */ virtual void handle(const css::uno::Reference& rHandle); /** Start a new table level. A new context is pushed onto the table data stack, */ virtual void startLevel(); /** End a table level. The current table is resolved and the context is popped from the stack. */ virtual void endLevel(); /** * Signal that the next paragraph definitely won't be part of any table. */ void endTable() { setRowEnd(false); } /** Tells whether a table has been started or not */ bool isInTable(); /** Handle the start of a paragraph group. */ virtual void startParagraphGroup(); /** Handle the end of a paragraph group. */ virtual void endParagraphGroup(); /** Handle an SPRM at curent handle. @param rSprm the SPRM */ virtual bool sprm(Sprm & rSprm); /** Handle properties at current handle. @param pProps the properites */ virtual void props(TablePropertyMapPtr pProps); /** Handle occurrence of character 0x7. */ virtual void handle0x7(); /** Handle 8 bit text at current handle. @param data array of characters @param len number of characters to handle */ virtual void text(const sal_uInt8 * data, size_t len); /** Handle 16 bit text at current handle. @param data array of characters @param len number of characters to handle */ virtual void utext(const sal_uInt8 * data, size_t len); /** Handle properties of the current cell. @param pProps the properties */ virtual void cellProps(TablePropertyMapPtr pProps); /** Handle properties of a certain cell in the current row. @paran i index of the cell in the current row @param pProps the properties */ virtual void cellPropsByCell(unsigned int i, TablePropertyMapPtr pProps); /** Handle properties of the current row. @param pProps the properties */ virtual void insertRowProps(TablePropertyMapPtr pProps); /** Handle properties of the current table. @param pProps the properties */ virtual void insertTableProps(TablePropertyMapPtr pProps); /** Return if table manager has detected paragraph to ignore. If this function returns true the current paragraph contains only control information, e.g. end of row. */ virtual bool isIgnore() const; #ifdef DEBUG_WRITERFILTER void setTagLogger(TagLogger::Pointer_t _tagLogger) { mpTableLogger = _tagLogger; } #endif }; } } #endif // INCLUDED_WRITERFILTER_INC_RESOURCEMODEL_TABLEMANAGER_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */