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 ************************************************************************/
56 /*************************************************************************
58 * index manager, to maintain the map between object id and offset
59 ************************************************************************/
61 #ifndef INCLUDED_LOTUSWORDPRO_SOURCE_FILTER_LWPIDXMGR_HXX
62 #define INCLUDED_LOTUSWORDPRO_SOURCE_FILTER_LWPIDXMGR_HXX
64 #include <rtl/ustring.hxx>
65 #include "lwpobjhdr.hxx"
66 #include "lwpobjstrm.hxx"
69 * @brief key structure used to map id to offset
77 * @brief LwpIndexManager, to read all index records and maintain the index information
85 static const sal_uInt8 MAXOBJECTIDS
;
86 std::vector
<LwpKey
*> m_ObjectKeys
; //the <id, offset> ordered vector
87 std::vector
<LwpKey
*> m_RootObjs
; //For those object ids in RootObjIndex
88 std::vector
<sal_uInt32
> m_TimeTable
; //Time table for object low id compression
90 //sal_uInt16 m_nKeyCount;
91 sal_uInt32 m_nKeyCount
; //the count of all object
92 std::vector
<sal_uInt32
> m_TempVec
; // a temp vector , store the offset of leafindex
94 sal_uInt32 m_ChildIndex
[256]; //Offset of leaf index
95 sal_uInt16 m_nLeafCount
;
97 void ReadRootData(LwpObjectStream
*pObjStrm
); //Read root index data
99 //Add new method to handle ObjIndex
100 void ReadObjIndexData(LwpObjectStream
* pObjStrm
);
101 void ReadObjIndex( LwpSvStream
*pStrm
); //Read Obj index
103 void ReadLeafIndex( LwpSvStream
*pStrm
); //Read leaf index obj
104 void ReadLeafData( LwpObjectStream
*pStrm
); //Read leaf index obj data
105 void ReadTimeTable( LwpObjectStream
*pStrm
);
107 void Read( LwpSvStream
*pStrm
);
108 sal_uInt32
GetObjOffset( LwpObjectID objid
);
109 sal_uInt32
GetObjTime( sal_uInt16 index
) { return m_TimeTable
.at(index
-1); }
113 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */