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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
|
/**************************************************************************/
/* */
/* Copyright (c) 2001, 2009 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. */
/* */
/**************************************************************************/
#ifndef ClientStore_H
#define ClientStore_H
#include "Message.h"
#include "Split.h"
#include "ChannelStore.h"
class StaticCompressor;
class ClientStore : public ChannelStore
{
public:
ClientStore(StaticCompressor *compressor);
virtual ~ClientStore();
//
// Get the store based on the index.
//
MessageStore *getRequestStore(unsigned char opcode) const
{
return requests_[opcode];
}
SplitStore *getSplitStore(int resource) const
{
return splits_[resource];
}
int getSplitTotalSize() const
{
return SplitStore::getTotalSize();
}
int getSplitTotalStorageSize() const
{
return SplitStore::getTotalStorageSize();
}
CommitStore *getCommitStore() const
{
return commits_;
}
int getCommitSize() const
{
return commits_ -> getSize();
}
void dumpSplitStore(int resource) const
{
splits_[resource] -> dump();
}
void dumpCommitStore() const
{
commits_ -> dump();
}
void dumpSplitStores() const;
SplitStore *createSplitStore(int resource)
{
splits_[resource] = new SplitStore(compressor_, commits_, resource);
return splits_[resource];
}
void destroySplitStore(int resource)
{
delete splits_[resource];
splits_[resource] = NULL;
}
//
// Actually save the message store
// to disk according to proxy mode.
//
int saveRequestStores(ostream *cachefs, md5_state_t *md5StateStream,
md5_state_t *md5StateClient, T_checksum_action checksumAction,
T_data_action dataAction) const;
int loadRequestStores(istream *cachefs, md5_state_t *md5StateStream,
T_checksum_action checksumAction, T_data_action dataAction) const;
private:
//
// A client store contains requests.
//
MessageStore *requests_[CHANNEL_STORE_OPCODE_LIMIT];
//
// Client messages being split.
//
SplitStore *splits_[CHANNEL_STORE_RESOURCE_LIMIT];
//
// Messages having been recomposed.
//
CommitStore *commits_;
//
// Passed forward to the other stores.
//
StaticCompressor *compressor_;
};
#endif /* ClientStore_H */
|