LibreOffice Module lotuswordpro (master) 1
lwpobjid.cxx
Go to the documentation of this file.
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
59 ************************************************************************/
60
61#include <lwpobjid.hxx>
62#include <lwpfilehdr.hxx>
63#include <lwpobjfactory.hxx>
64#include <lwpglobalmgr.hxx>
65
67 : m_nLow(0)
68 , m_nHigh(0)
69 , m_nIndex(0)
70 , m_bIsCompressed(false)
71{
72}
78{
79 pStrm->ReadUInt32(m_nLow);
80 pStrm->ReadUInt16(m_nHigh);
81}
86{
87 m_nLow = pObj->QuickReaduInt32();
88 m_nHigh = pObj->QuickReaduInt16();
89 return DiskSize();
90}
97{
98 //note the m_nLow store the index instead of time from the timetable as in LWP
99 m_bIsCompressed = false;
101 {
102 Read(pStrm);
103 return;
104 }
105
106 pStrm->ReadUInt8(m_nIndex);
107
108 if (m_nIndex)
109 {
110 m_bIsCompressed = true;
111 //m_nLow = index; //note the m_nLow stores the index instead of the actual time id
113 LwpObjectFactory* pFactory = pGlobal->GetLwpObjFactory();
114 LwpIndexManager& rIdxMgr = pFactory->GetIndexManager();
115 m_nLow = rIdxMgr.GetObjTime(static_cast<sal_uInt16>(m_nIndex));
116 }
117 else
118 {
119 pStrm->ReadUInt32(m_nLow);
120 }
121 pStrm->ReadUInt16(m_nHigh);
123}
124
131{
132 m_bIsCompressed = false;
134 {
135 return Read(pStrm);
136 }
137
138 m_nIndex = pStrm->QuickReaduInt8();
139 if (m_nIndex)
140 {
141 m_bIsCompressed = true;
142 //m_nLow = index; //note the m_nLow stores the index instead of the actual time id
144 LwpObjectFactory* pFactory = pGlobal->GetLwpObjFactory();
145 LwpIndexManager& rIdxMgr = pFactory->GetIndexManager();
146 m_nLow = rIdxMgr.GetObjTime(static_cast<sal_uInt16>(m_nIndex));
147 }
148 else
149 m_nLow = pStrm->QuickReaduInt32();
150 m_nHigh = pStrm->QuickReaduInt16();
151 return DiskSizeIndexed();
152}
160{
161 sal_uInt8 diff = pObj->QuickReaduInt8();
162
163 if (diff == 255)
164 {
165 Read(pObj);
166 }
167 else
168 {
169 m_nLow = prev.GetLow();
170 m_nHigh = prev.GetHigh() + diff + 1;
171 }
172}
177{
178 return sizeof(sal_uInt8) + ((m_nIndex != 0) ? 0 : sizeof(m_nLow)) + sizeof(m_nHigh);
179}
184{
185 if (IsNull())
186 {
187 return nullptr;
188 }
190 LwpObjectFactory* pObjMgr = pGlobal->GetLwpObjFactory();
191 rtl::Reference<LwpObject> pObj = pObjMgr->QueryObject(*this);
192 if (tag != VO_INVALID && (pObj.is()))
193 {
194 if (static_cast<sal_uInt32>(tag) != pObj->GetTag())
195 {
196 pObj.clear();
197 }
198 }
199 return pObj;
200}
201
202/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
static sal_uInt16 m_nFileRevision
Definition: lwpfilehdr.hxx:77
static LwpGlobalMgr * GetInstance(LwpSvStream *pSvStream=nullptr)
LwpObjectFactory * GetLwpObjFactory()
LwpIndexManager, to read all index records and maintain the index information.
Definition: lwpidxmgr.hxx:81
sal_uInt32 GetObjTime(sal_uInt16 index)
Definition: lwpidxmgr.hxx:109
object factory used for lwp object creation and maintenance
rtl::Reference< LwpObject > QueryObject(const LwpObjectID &objID)
@descr query object by object id object is created if not in the factory
LwpIndexManager & GetIndexManager()
object id class
Definition: lwpobjid.hxx:79
sal_uInt16 GetHigh() const
Definition: lwpobjid.hxx:130
void Read(LwpSvStream *pStrm)
@descr Read object id with format: low(4bytes)+high(2bytes) from stream for LWP7 record
Definition: lwpobjid.cxx:77
sal_uInt32 DiskSizeIndexed() const
@descr return the size of indexed object id
Definition: lwpobjid.cxx:176
sal_uInt16 m_nHigh
Definition: lwpobjid.hxx:84
void ReadCompressed(LwpObjectStream *pObj, LwpObjectID const &prev)
@descr Read object id with compressed format from object stream if diff == 255: 255+lowid+highid else...
Definition: lwpobjid.cxx:159
static sal_uInt32 DiskSize()
@descr return the size of object id with format: low(4bytes)+high(2bytes)
Definition: lwpobjid.hxx:97
void ReadIndexed(LwpSvStream *pStrm)
@descr Read object id with indexed format from stream if index>0, lowid is get from time table per th...
Definition: lwpobjid.cxx:96
rtl::Reference< LwpObject > obj(VO_TYPE tag=VO_INVALID) const
@descr get object from object factory per the object id
Definition: lwpobjid.cxx:183
bool IsNull() const
Definition: lwpobjid.hxx:110
sal_uInt32 GetLow() const
Definition: lwpobjid.hxx:125
sal_uInt32 m_nLow
Definition: lwpobjid.hxx:83
bool m_bIsCompressed
Definition: lwpobjid.hxx:86
sal_uInt8 m_nIndex
Definition: lwpobjid.hxx:85
stream class for LwpObject body data provide stream like interface to read object data
Definition: lwpobjstrm.hxx:77
sal_uInt16 QuickReaduInt16(bool *pFailure=nullptr)
@descr Quick read sal_uInt32
Definition: lwpobjstrm.cxx:200
sal_uInt8 QuickReaduInt8(bool *pFailure=nullptr)
@descr Quick read sal_uInt8
Definition: lwpobjstrm.cxx:230
sal_uInt32 QuickReaduInt32(bool *pFailure=nullptr)
@descr Quick read sal_uInt32
Definition: lwpobjstrm.cxx:189
encapsulate XInputStream to provide SvStream like interfaces
Definition: lwpsvstream.hxx:69
LwpSvStream & ReadUInt16(sal_uInt16 &rUInt16)
Definition: lwpsvstream.cxx:81
LwpSvStream & ReadUInt32(sal_uInt32 &rUInt32)
Definition: lwpsvstream.cxx:87
LwpSvStream & ReadUInt8(sal_uInt8 &rUInt8)
Definition: lwpsvstream.cxx:75
VO_TYPE
Definition: lwpdefs.hxx:69
@ VO_INVALID
Definition: lwpdefs.hxx:206
unsigned char sal_uInt8