-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathclient.h
88 lines (76 loc) · 2.39 KB
/
client.h
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
/****************/
/* Your Name */
/* Date */
/* CS 244B */
/* Spring 2013 */
/****************/
#include "network.h"
#include <set>
using namespace std;
enum {
NormalReturn = 0,
ErrorReturn = -1,
};
/* ------------------------------------------------------------------ */
#ifdef ASSERT_DEBUG
#define ASSERT(ASSERTION) \
{ assert(ASSERTION); }
#else
#define ASSERT(ASSERTION) \
{ }
#endif
/* ------------------------------------------------------------------ */
/********************/
/* Client Functions */
/********************/
#ifdef __cplusplus
extern "C" {
#endif
extern int InitReplFs(unsigned short portNum, int packetLoss, int numServers);
extern int OpenFile(char * strFileName);
extern int WriteBlock(int fd, char * strData, int byteOffset, int blockSize);
extern int Commit(int fd);
extern int Abort(int fd);
extern int CloseFile(int fd);
#ifdef __cplusplus
}
#endif
/* ------------------------------------------------------------------ */
enum ClientState { CheckStatus, ReqCommit, ReqAbort, ReqClose };
class Client : public NetworkInstance {
public:
Client() : writeSeq_(0), commitId_(0), writeStage_(0),
writeRetransRatio_(WRITE_RETRANS_RATIO) {}
void numServersIs(int numServers) { numServers_ = numServers; }
inline int numServers() const { return numServers_; }
void resetOldServers() { servers_.clear(); serversOpen_.clear();
serversCommit_.clear(); }
void addNewServer(unsigned int serverId) { servers_.insert(serverId); }
inline bool enoughServers() { return servers_.size() >= size_t(numServers_); }
void clientStateReset () {
servers_.clear(); serversOpen_.clear(); serversCommit_.clear();
writeSeq_ = 0; commitId_ = 0; writeStage_ = 0;
}
void clientResetBuffer () {
commitId_ = (++commitId_ >= 0) ? commitId_ : 0;
writeStage_ = 0;
serversCommit_.clear();
}
set<unsigned int> servers_;
set<unsigned int> serversOpen_;
set<unsigned int> serversCommit_;
int writeSeq_; //write sequence begin from 0, negative is invalid
int commitId_;
int writeStage_;
int writeRetransRatio_;
private:
int numServers_;
};
void sendReqServerInit();
bool collectAckInit();
void processAckInit(RFPacket *p);
bool clientReceiveReply(ClientState clientState);
void sendCheckCommitStatusPacket();
void processAckCommitStatus(RFPacket * pack);
void sendReqServerPacket(const int);
void processAckServerPacket(RFPacket * pack);