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,
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 ************************************************************************/
58 * For LWP filter architecture prototype - table object
61 #include <sal/config.h>
65 #include "lwptable.hxx"
67 LwpSuperTable::LwpSuperTable(LwpObjectHeader
const &objHdr
, LwpSvStream
* pStrm
):LwpContent(objHdr
, pStrm
)
70 LwpSuperTable::~LwpSuperTable()
73 void LwpSuperTable::Read()
76 m_pObjStrm
->SkipExtra();
80 void LwpSuperTable::Parse(IXFStream
* /*pOutputStream*/)
84 void LwpSuperTable::XFConvert(XFContentContainer
* /*pCont*/)
88 /*****************************************************************************/
89 LwpTable::LwpTable(LwpObjectHeader
const &objHdr
, LwpSvStream
* pStrm
)
90 : LwpContent(objHdr
, pStrm
)
95 , m_nDefaultAutoGrowRowHeight(0)
102 void LwpTable::Read()
105 //m_RowCache.Read(m_pObjStrm);
106 //m_ColumnCache.Read(m_pObjStrm);
108 //m_CPNotifyList.Read(m_pObjStrm);
109 //m_CPTempVersionedNotifyList.Read(m_pObjStrm);
111 m_nRow
= m_pObjStrm
->QuickReaduInt16();
112 m_nColumn
= m_pObjStrm
->QuickReaduInt16();
114 m_nHeight
= m_pObjStrm
->QuickReadInt32();
115 m_nWidth
= m_pObjStrm
->QuickReadInt32();
117 m_nDefaultAutoGrowRowHeight
= m_pObjStrm
->QuickReadInt32();
119 m_nAttributes
= m_pObjStrm
->QuickReaduInt16();
121 m_Layout
.ReadIndexed(m_pObjStrm
.get());
123 m_DefaultCellStyle
.ReadIndexed(m_pObjStrm
.get());
124 if (LwpFileHeader::m_nFileRevision
>= 0x0007)
125 m_CPNotifyList
.Read(m_pObjStrm
.get());
127 m_pObjStrm
->SkipExtra();
130 bool LwpTable::IsNumberDown()
132 return (m_nAttributes
& NUMBER_DOWN
) != 0;
135 void LwpTable::Parse(IXFStream
* /*pOutputStream*/)
139 LwpSuperTableLayout
* LwpTable::GetSuperTableLayout()
141 LwpTableLayout
* pLayout
= dynamic_cast<LwpTableLayout
*>(m_Layout
.obj().get());
143 return dynamic_cast<LwpSuperTableLayout
*>(pLayout
->GetParent().obj().get());
148 /*****************************************************************************/
149 LwpTableHeading::LwpTableHeading(LwpObjectHeader
const &objHdr
, LwpSvStream
* pStrm
):LwpTable(objHdr
, pStrm
)
152 LwpTableHeading::~LwpTableHeading()
155 void LwpTableHeading::Read()
157 m_pObjStrm
->SkipExtra();
160 void LwpTableHeading::Parse(IXFStream
* /*pOutputStream*/)
164 /*****************************************************************************/
165 LwpParallelColumns::LwpParallelColumns(LwpObjectHeader
const &objHdr
, LwpSvStream
* pStrm
):LwpTable(objHdr
, pStrm
)
169 LwpParallelColumns::~LwpParallelColumns()
173 void LwpParallelColumns::Read()
176 cDefaultLeftColumnStyle
.ReadIndexed(m_pObjStrm
.get());
177 cDefaultRightColumnStyle
.ReadIndexed(m_pObjStrm
.get());
179 m_pObjStrm
->SkipExtra();
181 /*****************************************************************************/
182 LwpGlossary::LwpGlossary(LwpObjectHeader
const &objHdr
, LwpSvStream
* pStrm
):LwpParallelColumns(objHdr
, pStrm
)
186 LwpGlossary::~LwpGlossary()
189 sal_uInt16
LwpGlossary::GetNumIndexRows()
191 if (GetRow() > 0 && GetRow() <= MAX_NUM_ROWS
)
192 return GetRow() - 1; // Minus one row for repeated heading.
196 void LwpGlossary::Read()
198 LwpParallelColumns::Read();
200 sal_uInt16 FiledEntries
= m_pObjStrm
->QuickReaduInt16();
201 sal_uInt16 NumIndexRows
= GetNumIndexRows();
203 if (FiledEntries
< NumIndexRows
)
205 /* We'll have to do sequential (slow) searches. */
206 m_pObjStrm
->SeekRel( FiledEntries
* sizeof(sal_uInt16
));
212 sal_uInt16 EntriesRead
= std::min(FiledEntries
, NumIndexRows
);
214 for (sal_uInt16 EntryCount
= 1; EntryCount
<= EntriesRead
; EntryCount
++)
215 m_pObjStrm
->QuickReaduInt16();
217 if (FiledEntries
> EntriesRead
)
218 m_pObjStrm
->SeekRel((FiledEntries
- EntriesRead
)* sizeof(sal_uInt16
));
221 m_pObjStrm
->SeekRel(FiledEntries
* sizeof(sal_uInt16
));
224 m_pObjStrm
->SkipExtra();
227 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */