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 * For LWP filter architecture prototype
59 ************************************************************************/
60 /*************************************************************************
63 ************************************************************************/
65 #include "lwpobjhdr.hxx"
66 #include "lwpdefs.hxx"
67 #include "lwpfilehdr.hxx"
69 LwpObjectHeader::LwpObjectHeader()
70 : m_nTag(0), m_ID(), m_nSize(0), m_bCompressed(false)
71 // m_nHeaderSize(0), m_nVersionID(0), m_nRefCount(0), m_nFlagBits(0),
72 //m_nNextVersionOffset(0), m_nNextVersionID(0),
75 * @descr read header from stream
77 bool LwpObjectHeader::Read(LwpSvStream
&rStrm
)
79 sal_uInt32 nVersionID
= 0;
80 sal_uInt32 nRefCount
= 0;
81 sal_uInt32 nNextVersionOffset
= 0;
82 sal_uInt32 nHeaderSize
= 0;
84 sal_Int64 nStartPos
= rStrm
.Tell();
86 if ( LwpFileHeader::m_nFileRevision
< 0x000B)
88 rStrm
.ReadUInt32( m_nTag
);
90 rStrm
.ReadUInt32( nVersionID
);
91 rStrm
.ReadUInt32( nRefCount
);
92 rStrm
.ReadUInt32( nNextVersionOffset
);
94 nHeaderSize
= sizeof(m_nTag
) + LwpObjectID::DiskSize()
97 + sizeof(nNextVersionOffset
)
100 if ((m_nTag
== TAG_AMI
) || ( LwpFileHeader::m_nFileRevision
< 0x0006))
102 sal_uInt32 nNextVersionID
= 0;
103 rStrm
.ReadUInt32( nNextVersionID
);
104 nHeaderSize
+= sizeof(nNextVersionID
);
106 rStrm
.ReadUInt32( m_nSize
);
110 sal_uInt8 nFlagBits
= 0;
111 sal_uInt16 VOType
= 0;
112 rStrm
.ReadUInt16( VOType
);
113 rStrm
.ReadUInt8( nFlagBits
);
115 m_nTag
= static_cast<sal_uInt32
>(VOType
);
116 m_ID
.ReadIndexed(&rStrm
);
117 nHeaderSize
= sizeof(VOType
) + sizeof(nFlagBits
) + m_ID
.DiskSizeIndexed();
121 switch (nFlagBits
& VERSION_BITS
)
123 case ONE_BYTE_VERSION
:
124 rStrm
.ReadUInt8( tmpByte
);
125 nVersionID
= static_cast<sal_uInt32
>( tmpByte
);
129 case TWO_BYTE_VERSION
:
130 rStrm
.ReadUInt16( tmpShort
);
131 nVersionID
= static_cast<sal_uInt32
>( tmpShort
);
135 case FOUR_BYTE_VERSION
:
136 rStrm
.ReadUInt32( nVersionID
);
139 case DEFAULT_VERSION
: //fall through
145 switch (nFlagBits
& REFCOUNT_BITS
)
147 case ONE_BYTE_REFCOUNT
:
148 rStrm
.ReadUInt8( tmpByte
);
149 nRefCount
= static_cast<sal_uInt32
>( tmpByte
);
153 case TWO_BYTE_REFCOUNT
:
154 rStrm
.ReadUInt16( tmpShort
);
155 nRefCount
= static_cast<sal_uInt32
>( tmpShort
);
159 case FOUR_BYTE_REFCOUNT
: //through
161 rStrm
.ReadUInt32( nRefCount
);
166 if (nFlagBits
& HAS_PREVOFFSET
)
168 rStrm
.ReadUInt32( nNextVersionOffset
);
172 nNextVersionOffset
= BAD_OFFSET
;
174 switch (nFlagBits
& SIZE_BITS
)
177 rStrm
.ReadUInt8( tmpByte
);
178 m_nSize
= static_cast<sal_uInt32
>( tmpByte
);
183 rStrm
.ReadUInt16( tmpShort
);
184 m_nSize
= static_cast<sal_uInt32
>(tmpShort
);
188 case FOUR_BYTE_SIZE
: //go through
190 rStrm
.ReadUInt32( m_nSize
);
195 if (nFlagBits
& DATA_COMPRESSED
)
197 m_bCompressed
= true;
200 sal_Int64 nEndPos
= rStrm
.Tell();
201 return (nStartPos
+ nHeaderSize
== nEndPos
);
204 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */