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 #ifndef INCLUDED_LOTUSWORDPRO_SOURCE_FILTER_LWPOBJID_HXX
66 #define INCLUDED_LOTUSWORDPRO_SOURCE_FILTER_LWPOBJID_HXX
68 #include <sal/config.h>
70 #include <rtl/ref.hxx>
72 #include "lwpheader.hxx"
73 #include "lwpobjstrm.hxx"
74 #include "lwpdefs.hxx"
79 * @brief object id class
84 LwpObjectID(sal_uInt32 low
=0, sal_uInt16 high
=0);
91 sal_uInt32
Read( LwpSvStream
*pStrm
);
92 sal_uInt32
Read( LwpObjectStream
*pStrm
);
93 sal_uInt32
ReadIndexed( LwpSvStream
* pStrm
);
94 sal_uInt32
ReadIndexed( LwpObjectStream
*pStrm
);
95 sal_uInt32
ReadCompressed( LwpObjectStream
* pObj
, LwpObjectID
& prev
);
98 * @descr return the size of object id with format: low(4bytes)+high(2bytes)
100 static sal_uInt32
DiskSize() { return sizeof(sal_uInt32
) + sizeof(sal_uInt16
); } // sizeof(m_nLow) + sizeof(m_nHigh)
101 sal_uInt32
DiskSizeIndexed() const;
105 sal_uInt32
GetLow() const ;
106 sal_uInt16
GetHigh() const ;
107 void SetLow(sal_uInt32 nl
);
108 void SetHigh(sal_uInt16 nh
);
110 bool operator == (const LwpObjectID
&Other
) const;
111 bool operator != (const LwpObjectID
&Other
) const;
112 rtl::Reference
<LwpObject
> obj(VO_TYPE tag
=VO_INVALID
) const;
113 size_t HashCode() const;
116 inline bool LwpObjectID::IsNull() const
118 return (m_nLow
== 0) && (m_nHigh
== 0);
121 inline bool LwpObjectID::operator == (const LwpObjectID
&Other
) const
123 return (m_nHigh
== Other
.m_nHigh
) && (m_nLow
== Other
.m_nLow
);
126 inline bool LwpObjectID::operator != (const LwpObjectID
&Other
) const
128 return (m_nHigh
!= Other
.m_nHigh
) || (m_nLow
!= Other
.m_nLow
);
131 inline bool LwpObjectID::IsCompressed()
133 return m_bIsCompressed
;
135 inline sal_uInt32
LwpObjectID::GetLow() const
139 inline sal_uInt16
LwpObjectID::GetHigh() const
143 inline void LwpObjectID::SetLow(sal_uInt32 nl
)
147 inline void LwpObjectID::SetHigh(sal_uInt16 nh
)
151 inline size_t LwpObjectID::HashCode() const
156 str
= OUString(m_nIndex
) + OUString(m_nHigh
);
160 str
= OUString(m_nLow
) + OUString(m_nHigh
);
162 return str
.hashCode();
167 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */