blob: 1ba104b59978eb8ac8be55709781eeff8408148e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
|
/**************************************************************************/
/* */
/* Copyright (c) 2001, 2010 NoMachine, http://www.nomachine.com/. */
/* */
/* NXCOMP, NX protocol compression and NX extensions to this software */
/* are copyright of NoMachine. Redistribution and use of the present */
/* software is allowed according to terms specified in the file LICENSE */
/* which comes in the source distribution. */
/* */
/* Check http://www.nomachine.com/licensing.html for applicability. */
/* */
/* NX and NoMachine are trademarks of Medialogic S.p.A. */
/* */
/* All rights reserved. */
/* */
/**************************************************************************/
#include "List.h"
//
// Set the verbosity level.
//
#define PANIC
#define WARNING
#undef TEST
#undef DEBUG
//
// Define this to know how many instances
// are allocated and deallocated.
//
#undef REFERENCES
#ifdef REFERENCES
int List::references_ = 0;
#endif
List::List()
{
#ifdef REFERENCES
references_++;
*logofs << "List: Created new List at "
<< this << " out of " << references_
<< " allocated references.\n" << logofs_flush;
#endif
}
List::~List()
{
#ifdef REFERENCES
references_--;
*logofs << "List: Deleted List at "
<< this << " out of " << references_
<< " allocated references.\n" << logofs_flush;
#endif
}
void List::remove(int value)
{
for (T_list::iterator i = list_.begin(); i != list_.end(); i++)
{
if (*i == value)
{
list_.erase(i);
return;
}
}
#ifdef PANIC
*logofs << "List: PANIC! Should not try to remove "
<< "an element not found in the list.\n"
<< logofs_flush;
#endif
cerr << "Error" << ": Should not try to remove "
<< "an element not found in the list.\n";
HandleAbort();
}
void List::rotate()
{
if (list_.size() > 1)
{
int value = *(list_.begin());
list_.pop_front();
list_.push_back(value);
}
}
|