Link with C++ linker
[oweals/cde.git] / cde / programs / nsgmls / OffsetOrderedList.h
1 /*
2  * CDE - Common Desktop Environment
3  *
4  * Copyright (c) 1993-2012, The Open Group. All rights reserved.
5  *
6  * These libraries and programs are free software; you can
7  * redistribute them and/or modify them under the terms of the GNU
8  * Lesser General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option)
10  * any later version.
11  *
12  * These libraries and programs are distributed in the hope that
13  * they will be useful, but WITHOUT ANY WARRANTY; without even the
14  * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15  * PURPOSE. See the GNU Lesser General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with these librararies and programs; if not, write
20  * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
21  * Floor, Boston, MA 02110-1301 USA
22  */
23 /* $XConsortium: OffsetOrderedList.h /main/1 1996/07/29 16:59:10 cde-hp $ */
24 // Copyright (c) 1994 James Clark
25 // See the file COPYING for copying permission.
26
27 #ifndef OffsetOrderedList_INCLUDED
28 #define OffsetOrderedList_INCLUDED 1
29
30 #include "types.h"
31 #include "Owner.h"
32 #include "NCVector.h"
33 #include "Boolean.h"
34
35 #ifdef SP_NAMESPACE
36 namespace SP_NAMESPACE {
37 #endif
38
39 struct OffsetOrderedListBlock {
40   Offset offset;                // next Offset
41   size_t nextIndex;             // index of first item in next block
42   enum { size = 200 };
43   unsigned char bytes[size];
44 };
45
46 // This is an ordered list of Offsets with no duplicates.
47
48 class OffsetOrderedList {
49 public:
50   OffsetOrderedList();
51   // off must be > the last offset added.
52   void append(Offset off);
53   // Find the last offset in the list <= off.
54   Boolean findPreceding(Offset off, size_t &foundIndex, Offset &foundOffset)
55     const;
56   size_t size() const;
57 private:
58   OffsetOrderedList(const OffsetOrderedList &); // undefined
59   void operator=(const OffsetOrderedList &);    // undefined
60   void addByte(unsigned char b);
61   // bytes used in current block
62   int blockUsed_;
63   NCVector<Owner<OffsetOrderedListBlock> > blocks_;
64 };
65
66 inline
67 size_t OffsetOrderedList::size() const
68 {
69   return blocks_.size() == 0 ? 0 : blocks_.back()->nextIndex;
70 }
71
72 #ifdef SP_NAMESPACE
73 }
74 #endif
75
76 #endif /* not OffsetOrderedList_INCLUDED */