1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*************************************************************************
3 *
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
6 *
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
9 *
10 * Sun Microsystems Inc., October, 2000
11 *
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
16 *
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.
20 *
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.
25 *
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
30 *
31 *
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.
38 *
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.
45 *
46 * The Initial Developer of the Original Code is: IBM Corporation
47 *
48 * Copyright: 2008 by IBM Corporation
49 *
50 * All Rights Reserved.
51 *
52 * Contributor(s): _______________________________________
53 *
54 *
55 ************************************************************************/
56 /**
57 * @file
58 * For LWP filter architecture prototype - table object
59 */
60
61 #include <sal/config.h>
62
63 #include <algorithm>
64
65 #include <lwpfilehdr.hxx>
66 #include "lwptable.hxx"
67
LwpSuperTable(LwpObjectHeader const & objHdr,LwpSvStream * pStrm)68 LwpSuperTable::LwpSuperTable(LwpObjectHeader const& objHdr, LwpSvStream* pStrm)
69 : LwpContent(objHdr, pStrm)
70 {
71 }
72
~LwpSuperTable()73 LwpSuperTable::~LwpSuperTable() {}
74
Read()75 void LwpSuperTable::Read()
76 {
77 LwpContent::Read();
78 m_pObjStrm->SkipExtra();
79 }
80
Parse(IXFStream *)81 void LwpSuperTable::Parse(IXFStream* /*pOutputStream*/) {}
82
XFConvert(XFContentContainer *)83 void LwpSuperTable::XFConvert(XFContentContainer* /*pCont*/) {}
84
85 /*****************************************************************************/
LwpTable(LwpObjectHeader const & objHdr,LwpSvStream * pStrm)86 LwpTable::LwpTable(LwpObjectHeader const& objHdr, LwpSvStream* pStrm)
87 : LwpContent(objHdr, pStrm)
88 , m_nRow(0)
89 , m_nColumn(0)
90 , m_nHeight(0)
91 , m_nWidth(0)
92 , m_nDefaultAutoGrowRowHeight(0)
93 , m_nAttributes(0)
94 {
95 }
96
~LwpTable()97 LwpTable::~LwpTable() {}
98
Read()99 void LwpTable::Read()
100 {
101 LwpContent::Read();
102 //m_RowCache.Read(m_pObjStrm);
103 //m_ColumnCache.Read(m_pObjStrm);
104
105 //m_CPNotifyList.Read(m_pObjStrm);
106 //m_CPTempVersionedNotifyList.Read(m_pObjStrm);
107
108 m_nRow = m_pObjStrm->QuickReaduInt16();
109 m_nColumn = m_pObjStrm->QuickReaduInt16();
110
111 m_nHeight = m_pObjStrm->QuickReadInt32();
112 m_nWidth = m_pObjStrm->QuickReadInt32();
113
114 m_nDefaultAutoGrowRowHeight = m_pObjStrm->QuickReadInt32();
115
116 m_nAttributes = m_pObjStrm->QuickReaduInt16();
117
118 m_Layout.ReadIndexed(m_pObjStrm.get());
119
120 m_DefaultCellStyle.ReadIndexed(m_pObjStrm.get());
121 if (LwpFileHeader::m_nFileRevision >= 0x0007)
122 m_CPNotifyList.Read(m_pObjStrm.get());
123
124 m_pObjStrm->SkipExtra();
125 }
126
IsNumberDown() const127 bool LwpTable::IsNumberDown() const { return (m_nAttributes & NUMBER_DOWN) != 0; }
128
Parse(IXFStream *)129 void LwpTable::Parse(IXFStream* /*pOutputStream*/) {}
130
GetSuperTableLayout()131 LwpSuperTableLayout* LwpTable::GetSuperTableLayout()
132 {
133 LwpTableLayout* pLayout = dynamic_cast<LwpTableLayout*>(m_Layout.obj().get());
134 if (pLayout)
135 return dynamic_cast<LwpSuperTableLayout*>(pLayout->GetParent().obj().get());
136
137 return nullptr;
138 }
139
140 /*****************************************************************************/
LwpTableHeading(LwpObjectHeader const & objHdr,LwpSvStream * pStrm)141 LwpTableHeading::LwpTableHeading(LwpObjectHeader const& objHdr, LwpSvStream* pStrm)
142 : LwpTable(objHdr, pStrm)
143 {
144 }
145
~LwpTableHeading()146 LwpTableHeading::~LwpTableHeading() {}
147
Read()148 void LwpTableHeading::Read() { m_pObjStrm->SkipExtra(); }
149
Parse(IXFStream *)150 void LwpTableHeading::Parse(IXFStream* /*pOutputStream*/) {}
151
152 /*****************************************************************************/
LwpParallelColumns(LwpObjectHeader const & objHdr,LwpSvStream * pStrm)153 LwpParallelColumns::LwpParallelColumns(LwpObjectHeader const& objHdr, LwpSvStream* pStrm)
154 : LwpTable(objHdr, pStrm)
155 {
156 }
157
~LwpParallelColumns()158 LwpParallelColumns::~LwpParallelColumns() {}
159
Read()160 void LwpParallelColumns::Read()
161 {
162 LwpTable::Read();
163 cDefaultLeftColumnStyle.ReadIndexed(m_pObjStrm.get());
164 cDefaultRightColumnStyle.ReadIndexed(m_pObjStrm.get());
165
166 m_pObjStrm->SkipExtra();
167 }
168 /*****************************************************************************/
LwpGlossary(LwpObjectHeader const & objHdr,LwpSvStream * pStrm)169 LwpGlossary::LwpGlossary(LwpObjectHeader const& objHdr, LwpSvStream* pStrm)
170 : LwpParallelColumns(objHdr, pStrm)
171 {
172 }
173
~LwpGlossary()174 LwpGlossary::~LwpGlossary() {}
GetNumIndexRows() const175 sal_uInt16 LwpGlossary::GetNumIndexRows() const
176 {
177 if (GetRow() > 0 && GetRow() <= MAX_NUM_ROWS)
178 return GetRow() - 1; // Minus one row for repeated heading.
179 return 0;
180 }
181
Read()182 void LwpGlossary::Read()
183 {
184 LwpParallelColumns::Read();
185
186 sal_uInt16 FiledEntries = m_pObjStrm->QuickReaduInt16();
187 sal_uInt16 NumIndexRows = GetNumIndexRows();
188
189 if (FiledEntries < NumIndexRows)
190 {
191 /* We'll have to do sequential (slow) searches. */
192 m_pObjStrm->SeekRel(FiledEntries * sizeof(sal_uInt16));
193 }
194 else
195 {
196 if (NumIndexRows)
197 {
198 sal_uInt16 EntriesRead = std::min(FiledEntries, NumIndexRows);
199
200 for (sal_uInt16 EntryCount = 1; EntryCount <= EntriesRead; EntryCount++)
201 m_pObjStrm->QuickReaduInt16();
202
203 if (FiledEntries > EntriesRead)
204 m_pObjStrm->SeekRel((FiledEntries - EntriesRead) * sizeof(sal_uInt16));
205 }
206 else
207 m_pObjStrm->SeekRel(FiledEntries * sizeof(sal_uInt16));
208 }
209
210 m_pObjStrm->SkipExtra();
211 }
212
213 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
214