fix baseline build (old cairo) - 'cairo_rectangle_int_t' does not name a type
[LibreOffice.git] / lotuswordpro / source / filter / lwptable.cxx
blob420b7e85a170009f30eafc80f4b70b817206cd7b
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*************************************************************************
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
10 * Sun Microsystems Inc., October, 2000
12 * GNU Lesser General Public License Version 2.1
13 * =============================================
14 * Copyright 2000 by Sun Microsystems, Inc.
15 * 901 San Antonio Road, Palo Alto, CA 94303, USA
17 * This library is free software; you can redistribute it and/or
18 * modify it under the terms of the GNU Lesser General Public
19 * License version 2.1, as published by the Free Software Foundation.
21 * This library is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 * Lesser General Public License for more details.
26 * You should have received a copy of the GNU Lesser General Public
27 * License along with this library; if not, write to the Free Software
28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
29 * MA 02111-1307 USA
32 * Sun Industry Standards Source License Version 1.1
33 * =================================================
34 * The contents of this file are subject to the Sun Industry Standards
35 * Source License Version 1.1 (the "License"); You may not use this file
36 * except in compliance with the License. You may obtain a copy of the
37 * License at http://www.openoffice.org/license.html.
39 * Software provided under this License is provided on an "AS IS" basis,
40 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 * See the License for the specific provisions governing your rights and
44 * obligations concerning the Software.
46 * The Initial Developer of the Original Code is: IBM Corporation
48 * Copyright: 2008 by IBM Corporation
50 * All Rights Reserved.
52 * Contributor(s): _______________________________________
55 ************************************************************************/
56 /**
57 * @file
58 * For LWP filter architecture prototype - table object
60 /*************************************************************************
61 * Change History
62 Mar 2005 Created
63 ************************************************************************/
65 #include "lwptable.hxx"
67 LwpSuperTable::LwpSuperTable(LwpObjectHeader &objHdr, LwpSvStream* pStrm):LwpContent(objHdr, pStrm)
70 LwpSuperTable::~LwpSuperTable()
73 void LwpSuperTable::Read()
75 LwpContent::Read();
76 m_pObjStrm->SkipExtra();
80 void LwpSuperTable::Parse(IXFStream* /*pOutputStream*/)
84 //Added by for XFConvert refactor, 03/31/2005
85 void LwpSuperTable::XFConvert(XFContentContainer* /*pCont*/)
89 //End of Add
90 /*****************************************************************************/
91 LwpTable::LwpTable(LwpObjectHeader &objHdr, LwpSvStream* pStrm)
92 : LwpContent(objHdr, pStrm)
93 , m_nRow(0)
94 , m_nColumn(0)
95 , m_nHeight(0)
96 , m_nWidth(0)
97 , m_nDefaultAutoGrowRowHeight(0)
98 , m_nAttributes(0)
101 LwpTable::~LwpTable()
104 void LwpTable::Read()
106 LwpContent::Read();
107 //m_RowCache.Read(m_pObjStrm);
108 //m_ColumnCache.Read(m_pObjStrm);
110 //m_CPNotifyList.Read(m_pObjStrm);
111 //m_CPTempVersionedNotifyList.Read(m_pObjStrm);
113 m_nRow = m_pObjStrm->QuickReaduInt16();
114 m_nColumn = m_pObjStrm->QuickReaduInt16();
116 m_nHeight = m_pObjStrm->QuickReadInt32();
117 m_nWidth = m_pObjStrm->QuickReadInt32();
119 m_nDefaultAutoGrowRowHeight = m_pObjStrm->QuickReadInt32();
121 m_nAttributes = m_pObjStrm->QuickReaduInt16();
123 m_Layout.ReadIndexed(m_pObjStrm);
125 m_DefaultCellStyle.ReadIndexed(m_pObjStrm);
126 if (LwpFileHeader::m_nFileRevision >= 0x0007)
127 m_CPNotifyList.Read(m_pObjStrm);
129 m_pObjStrm->SkipExtra();
132 bool LwpTable::IsNumberDown()
134 if (m_nAttributes & NUMBER_DOWN)
135 return true;
136 return false;
139 void LwpTable::Parse(IXFStream* /*pOutputStream*/)
143 LwpSuperTableLayout* LwpTable::GetSuperTableLayout()
145 LwpTableLayout* pLayout = dynamic_cast<LwpTableLayout*>(m_Layout.obj().get());
146 if(pLayout)
147 return dynamic_cast<LwpSuperTableLayout*>(pLayout->GetParent().obj().get());
149 return NULL;
152 /*****************************************************************************/
153 LwpTableHeading::LwpTableHeading(LwpObjectHeader &objHdr, LwpSvStream* pStrm):LwpTable(objHdr, pStrm)
156 LwpTableHeading::~LwpTableHeading()
159 void LwpTableHeading::Read()
161 m_pObjStrm->SkipExtra();
164 void LwpTableHeading::Parse(IXFStream* /*pOutputStream*/)
168 /*****************************************************************************/
169 LwpParallelColumns::LwpParallelColumns(LwpObjectHeader &objHdr, LwpSvStream* pStrm):LwpTable(objHdr, pStrm)
173 LwpParallelColumns::~LwpParallelColumns()
177 void LwpParallelColumns::Read()
179 LwpTable::Read();
180 cDefaultLeftColumnStyle.ReadIndexed(m_pObjStrm);
181 cDefaultRightColumnStyle.ReadIndexed(m_pObjStrm);
183 m_pObjStrm->SkipExtra();
185 /*****************************************************************************/
186 LwpGlossary::LwpGlossary(LwpObjectHeader &objHdr, LwpSvStream* pStrm):LwpParallelColumns(objHdr, pStrm)
190 LwpGlossary::~LwpGlossary()
193 sal_uInt16 LwpGlossary::GetNumIndexRows()
195 if (GetRow() > 0 && GetRow() <= MAX_NUM_ROWS)
196 return GetRow() - 1; // Minus one row for repeated heading.
197 return 0;
200 void LwpGlossary::Read()
202 LwpParallelColumns::Read();
204 sal_uInt16 FiledEntries = m_pObjStrm->QuickReaduInt16();
205 sal_uInt16 NumIndexRows = GetNumIndexRows();
207 if (FiledEntries < NumIndexRows)
209 /* We'll have to do sequential (slow) searches. */
210 m_pObjStrm->SeekRel( FiledEntries * sizeof(sal_uInt16));
212 else
214 if (NumIndexRows)
216 sal_uInt16 EntriesRead = (FiledEntries > NumIndexRows)? NumIndexRows:FiledEntries;
218 for (sal_uInt16 EntryCount = 1; EntryCount <= EntriesRead; EntryCount++)
219 m_pObjStrm->QuickReaduInt16();
221 if (FiledEntries > EntriesRead)
222 m_pObjStrm->SeekRel((FiledEntries - EntriesRead)* sizeof(sal_uInt16));
224 else
225 m_pObjStrm->SeekRel(FiledEntries * sizeof(sal_uInt16));
228 m_pObjStrm->SkipExtra();
231 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */