LeechCraft
0.6.70-13605-g8cd066ad6a
Modular cross-platform feature rich live environment.
idpool.h
Go to the documentation of this file.
1
/**********************************************************************
2
* LeechCraft - modular cross-platform feature rich internet client.
3
* Copyright (C) 2006-2014 Georg Rudoy
4
*
5
* Boost Software License - Version 1.0 - August 17th, 2003
6
*
7
* Permission is hereby granted, free of charge, to any person or organization
8
* obtaining a copy of the software and accompanying documentation covered by
9
* this license (the "Software") to use, reproduce, display, distribute,
10
* execute, and transmit the Software, and to prepare derivative works of the
11
* Software, and to permit third-parties to whom the Software is furnished to
12
* do so, all subject to the following:
13
*
14
* The copyright notices in the Software and this entire statement, including
15
* the above license grant, this restriction and the following disclaimer,
16
* must be included in all copies of the Software, in whole or in part, and
17
* all derivative works of the Software, unless such copies or derivative
18
* works are solely in the form of machine-executable object code generated by
19
* a source language processor.
20
*
21
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23
* FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
24
* SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
25
* FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
26
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
27
* DEALINGS IN THE SOFTWARE.
28
**********************************************************************/
29
30
#pragma once
31
32
#include "
utilconfig.h
"
33
#include <QByteArray>
34
#include <QSet>
35
#include <QDataStream>
36
#include <QtDebug>
37
38
namespace
LC
39
{
40
namespace
Util
41
{
48
template
<
typename
T>
49
class
IDPool
50
{
51
T CurrentID_;
52
public
:
57
IDPool
(
const
T&
id
= T ())
58
: CurrentID_ (id)
59
{
60
}
61
64
virtual
~IDPool
()
65
{
66
}
67
72
T
GetID
()
73
{
74
return
++CurrentID_;
75
}
76
81
void
SetID
(T
id
)
82
{
83
CurrentID_ = id;
84
}
85
90
void
FreeID
(T
id
)
91
{
92
Q_UNUSED (
id
);
93
}
94
99
QByteArray
SaveState
()
const
100
{
101
QByteArray result;
102
{
103
QDataStream ostr (&result, QIODevice::WriteOnly);
104
quint8 ver = 1;
105
ostr << ver;
106
ostr << CurrentID_;
107
}
108
return
result;
109
}
110
116
void
LoadState
(
const
QByteArray& state)
117
{
118
if
(state.isEmpty ())
119
return
;
120
121
QDataStream istr (state);
122
quint8 ver;
123
istr >> ver;
124
if
(ver == 1)
125
istr >> CurrentID_;
126
else
127
qWarning () << Q_FUNC_INFO
128
<<
"unknown version"
129
<< ver
130
<<
", not restoring state."
;
131
}
132
};
133
}
134
}
utilconfig.h
LC::Util::IDPool::SaveState
QByteArray SaveState() const
Saves the state of this pool.
Definition:
idpool.h:176
LC::Util::IDPool::LoadState
void LoadState(const QByteArray &state)
Recovers the state of this pool.
Definition:
idpool.h:193
LC::Util::IDPool::GetID
T GetID()
Returns next ID.
Definition:
idpool.h:149
LC::Util::IDPool::IDPool
IDPool(const T &id=T())
Creates a pool with the given initial value.
Definition:
idpool.h:134
LC::Util::IDPool::FreeID
void FreeID(T id)
Frees the id.
Definition:
idpool.h:167
LC
Definition:
constants.h:34
LC::Util::IDPool::SetID
void SetID(T id)
Forcefully sets the current ID.
Definition:
idpool.h:158
LC::Util::IDPool::~IDPool
virtual ~IDPool()
Destroys the pool.
Definition:
idpool.h:141
src
util
idpool.h
Generated by
1.8.16