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 ************************************************************************/
61 #ifndef INCLUDED_LOTUSWORDPRO_INC_LWPOBJID_HXX
62 #define INCLUDED_LOTUSWORDPRO_INC_LWPOBJID_HXX
64 #include <sal/config.h>
66 #include <config_lgpl.h>
68 #include <rtl/ref.hxx>
70 #include "lwpobjstrm.hxx"
71 #include "lwpdefs.hxx"
76 * @brief object id class
88 void Read( LwpSvStream
*pStrm
);
89 sal_uInt32
Read( LwpObjectStream
*pStrm
);
90 void ReadIndexed( LwpSvStream
* pStrm
);
91 sal_uInt32
ReadIndexed( LwpObjectStream
*pStrm
);
92 void ReadCompressed( LwpObjectStream
* pObj
, LwpObjectID
const & prev
);
95 * @descr return the size of object id with format: low(4bytes)+high(2bytes)
97 static sal_uInt32
DiskSize() { return sizeof(sal_uInt32
) + sizeof(sal_uInt16
); } // sizeof(m_nLow) + sizeof(m_nHigh)
98 sal_uInt32
DiskSizeIndexed() const;
101 sal_uInt32
GetLow() const ;
102 sal_uInt16
GetHigh() const ;
104 bool operator == (const LwpObjectID
&Other
) const;
105 bool operator != (const LwpObjectID
&Other
) const;
106 rtl::Reference
<LwpObject
> obj(VO_TYPE tag
=VO_INVALID
) const;
107 size_t HashCode() const;
110 inline bool LwpObjectID::IsNull() const
112 return (m_nLow
== 0) && (m_nHigh
== 0);
115 inline bool LwpObjectID::operator == (const LwpObjectID
&Other
) const
117 return (m_nHigh
== Other
.m_nHigh
) && (m_nLow
== Other
.m_nLow
);
120 inline bool LwpObjectID::operator != (const LwpObjectID
&Other
) const
122 return (m_nHigh
!= Other
.m_nHigh
) || (m_nLow
!= Other
.m_nLow
);
125 inline sal_uInt32
LwpObjectID::GetLow() const
130 inline sal_uInt16
LwpObjectID::GetHigh() const
135 inline size_t LwpObjectID::HashCode() const
137 return static_cast<size_t>(
138 (m_nIndex
== 0 ? 23 * m_nLow
: 27 * m_nIndex
) + 29 * m_nHigh
);
143 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */