annotate src/SLList.cc @ 2568:ed6532d8bf12

[project @ 1996-12-06 05:39:13 by jwe]
author jwe
date Fri, 06 Dec 1996 05:39:13 +0000
parents
children 2480ef198c46
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2568
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
1 // This may look like C code, but it is really -*- C++ -*-
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
2 /*
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
3 Copyright (C) 1988, 1992 Free Software Foundation
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
4 written by Doug Lea (dl@rocky.oswego.edu)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
5
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
6 This file is part of the GNU C++ Library. This library is free
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
7 software; you can redistribute it and/or modify it under the terms of
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
8 the GNU Library General Public License as published by the Free
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
9 Software Foundation; either version 2 of the License, or (at your
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
10 option) any later version. This library is distributed in the hope
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
11 that it will be useful, but WITHOUT ANY WARRANTY; without even the
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
12 implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
13 PURPOSE. See the GNU Library General Public License for more details.
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
14 You should have received a copy of the GNU Library General Public
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
15 License along with this library; if not, write to the Free Software
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
16 Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
17 */
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
18
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
19 #if defined (__GNUG__)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
20 #pragma implementation
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
21 #endif
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
22
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
23 #ifdef HAVE_CONFIG_H
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
24 #include <config.h>
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
25 #endif
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
26
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
27 #include <limits.h>
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
28 #include <stream.h>
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
29 #include <builtin.h>
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
30 #include "SLList.h"
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
31
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
32 void BaseSLList::error(const char* msg) const
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
33 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
34 (*lib_error_handler)("SLList", msg);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
35 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
36
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
37 int BaseSLList::length() const
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
38 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
39 int l = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
40 BaseSLNode* t = last;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
41 if (t != 0) do { ++l; t = t->tl; } while (t != last);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
42 return l;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
43 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
44
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
45 void BaseSLList::clear()
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
46 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
47 if (last == 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
48 return;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
49
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
50 BaseSLNode* p = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
51 last->tl = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
52 last = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
53
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
54 while (p != 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
55 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
56 BaseSLNode* nxt = p->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
57 delete_node(p);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
58 p = nxt;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
59 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
60 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
61
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
62
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
63 // Note: This is an internal method. It does *not* free old contents!
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
64
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
65 void BaseSLList::copy(const BaseSLList& a)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
66 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
67 if (a.last == 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
68 last = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
69 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
70 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
71 BaseSLNode* p = a.last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
72 BaseSLNode* h = copy_node(p->item());
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
73 last = h;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
74 for (;;)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
75 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
76 if (p == a.last)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
77 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
78 last->tl = h;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
79 return;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
80 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
81 p = p->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
82 BaseSLNode* n = copy_node(p->item());
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
83 last->tl = n;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
84 last = n;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
85 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
86 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
87 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
88
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
89 BaseSLList& BaseSLList::operator = (const BaseSLList& a)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
90 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
91 if (last != a.last)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
92 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
93 clear();
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
94 copy(a);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
95 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
96 return *this;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
97 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
98
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
99 Pix BaseSLList::prepend(const void *datum)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
100 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
101 return prepend(copy_node(datum));
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
102 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
103
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
104
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
105 Pix BaseSLList::prepend(BaseSLNode* t)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
106 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
107 if (t == 0) return 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
108 if (last == 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
109 t->tl = last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
110 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
111 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
112 t->tl = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
113 last->tl = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
114 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
115 return Pix(t);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
116 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
117
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
118
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
119 Pix BaseSLList::append(const void *datum)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
120 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
121 return append(copy_node(datum));
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
122 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
123
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
124 Pix BaseSLList::append(BaseSLNode* t)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
125 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
126 if (t == 0) return 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
127 if (last == 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
128 t->tl = last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
129 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
130 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
131 t->tl = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
132 last->tl = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
133 last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
134 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
135 return Pix(t);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
136 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
137
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
138 void BaseSLList::join(BaseSLList& b)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
139 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
140 BaseSLNode* t = b.last;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
141 b.last = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
142 if (last == 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
143 last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
144 else if (t != 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
145 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
146 BaseSLNode* f = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
147 last->tl = t->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
148 t->tl = f;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
149 last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
150 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
151 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
152
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
153 Pix BaseSLList::ins_after(Pix p, const void *datum)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
154 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
155 BaseSLNode* u = (BaseSLNode*)p;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
156 BaseSLNode* t = copy_node(datum);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
157 if (last == 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
158 t->tl = last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
159 else if (u == 0) // ins_after 0 means prepend
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
160 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
161 t->tl = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
162 last->tl = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
163 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
164 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
165 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
166 t->tl = u->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
167 u->tl = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
168 if (u == last)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
169 last = t;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
170 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
171 return Pix(t);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
172 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
173
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
174 void BaseSLList::del_after(Pix p)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
175 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
176 BaseSLNode* u = (BaseSLNode*)p;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
177 if (last == 0 || u == last) error("cannot del_after last");
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
178 if (u == 0) u = last; // del_after 0 means delete first
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
179 BaseSLNode* t = u->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
180 if (u == t)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
181 last = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
182 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
183 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
184 u->tl = t->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
185 if (last == t)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
186 last = u;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
187 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
188 delete_node(t);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
189 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
190
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
191 int BaseSLList::owns(Pix p) const
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
192 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
193 BaseSLNode* t = last;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
194 if (t != 0 && p != 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
195 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
196 do
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
197 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
198 if (Pix(t) == p) return 1;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
199 t = t->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
200 } while (t != last);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
201 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
202 return 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
203 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
204
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
205 int BaseSLList::remove_front(void *dst, int signal_error)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
206 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
207 if (last)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
208 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
209 BaseSLNode* t = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
210 copy_item(dst, t->item());
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
211 if (t == last)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
212 last = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
213 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
214 last->tl = t->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
215 delete_node(t);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
216 return 1;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
217 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
218 if (signal_error)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
219 error("remove_front of empty list");
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
220 return 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
221 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
222
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
223 void BaseSLList::del_front()
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
224 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
225 if (last == 0) error("del_front of empty list");
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
226 BaseSLNode* t = last->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
227 if (t == last)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
228 last = 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
229 else
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
230 last->tl = t->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
231 delete_node(t);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
232 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
233
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
234 int BaseSLList::OK() const
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
235 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
236 int v = 1;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
237 if (last != 0)
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
238 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
239 BaseSLNode* t = last;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
240 long count = LONG_MAX; // Lots of chances to find last!
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
241 do
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
242 {
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
243 count--;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
244 t = t->tl;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
245 } while (count > 0 && t != last);
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
246 v &= count > 0;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
247 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
248 if (!v) error("invariant failure");
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
249 return v;
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
250 }
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
251
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
252 /*
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
253 ;;; Local Variables: ***
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
254 ;;; mode: C++ ***
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
255 ;;; End: ***
ed6532d8bf12 [project @ 1996-12-06 05:39:13 by jwe]
jwe
parents:
diff changeset
256 */