projects
/
invirt/third/libt4.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Includes cleanups
[invirt/third/libt4.git]
/
rpc
/
connection.h
diff --git
a/rpc/connection.h
b/rpc/connection.h
index
f529a35
..
b1df8a1
100644
(file)
--- a/
rpc/connection.h
+++ b/
rpc/connection.h
@@
-1,97
+1,82
@@
#ifndef connection_h
#define connection_h
#ifndef connection_h
#define connection_h
-#include <sys/types.h>
-#include <sys/socket.h>
+#include "types.h"
#include <arpa/inet.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <netinet/in.h>
-#include <cstddef>
-#include <thread>
-
-#include <map>
-#include <limits>
-
#include "pollmgr.h"
#include "pollmgr.h"
+#include "file.h"
-constexpr size_t size_t_max = std::numeric_limits<size_t>::max();
+constexpr size_t size_t_max = numeric_limits<size_t>::max();
-class thread_exit_exception : std::exception {
-};
+class thread_exit_exception : exception {};
class connection;
class chanmgr {
public:
class connection;
class chanmgr {
public:
- virtual bool got_pdu(connection *c, char *b, size_t sz) = 0;
+ virtual bool got_pdu(const shared_ptr<connection> & c, const string & b) = 0;
virtual ~chanmgr() {}
};
virtual ~chanmgr() {}
};
-class connection : public aio_callback {
+class connection : public aio_callback, public enable_shared_from_this<connection> {
public:
struct charbuf {
public:
struct charbuf {
- charbuf(): buf(NULL), sz(0), solong(0) {}
- charbuf (char *b, size_t s) : buf(b), sz(s), solong(0){}
- char *buf;
- size_t sz;
- size_t solong; // number of bytes written or read so far
+ string buf;
+ size_t solong = 0; // number of bytes written or read so far
};
connection(chanmgr *m1, int f1, int lossytest=0);
~connection();
int channo() { return fd_; }
};
connection(chanmgr *m1, int f1, int lossytest=0);
~connection();
int channo() { return fd_; }
- bool isdead();
+ bool isdead() { lock ml(m_); return dead_; }
void closeconn();
void closeconn();
- bool send(char *b, size_t sz);
+ bool send(const string & b);
void write_cb(int s);
void read_cb(int s);
void write_cb(int s);
void read_cb(int s);
- void incref();
- void decref();
- int ref();
+ time_point<steady_clock> create_time() const { return create_time_; }
- int compare(connection *another);
private:
bool readpdu();
bool writepdu();
chanmgr *mgr_;
private:
bool readpdu();
bool writepdu();
chanmgr *mgr_;
- const int fd_;
- bool dead_;
+ const file_t fd_;
+ bool dead_ = false;
charbuf wpdu_;
charbuf rpdu_;
charbuf wpdu_;
charbuf rpdu_;
- std::chrono::time_point<std::chrono::steady_clock> create_time_;
+ time_point<steady_clock> create_time_;
- int waiters_;
- int refno_;
- const int lossy_;
+ int waiters_ = 0;
+ int lossy_ = 0;
- std::mutex m_;
- std::mutex ref_m_;
- std::condition_variable send_complete_;
- std::condition_variable send_wait_;
+ mutex m_;
+ cond send_complete_;
+ cond send_wait_;
};
class tcpsconn {
public:
};
class tcpsconn {
public:
- tcpsconn(chanmgr *m1, unsigned int port, int lossytest=0);
+ tcpsconn(chanmgr *m1, in_port_t port, int lossytest=0);
~tcpsconn();
~tcpsconn();
- inline unsigned int port() { return port_; }
+ inline in_port_t port() { return port_; }
void accept_conn();
private:
void accept_conn();
private:
- unsigned int port_;
- std::mutex m_;
- std::thread th_;
- int pipe_[2];
+ in_port_t port_;
+ mutex m_;
+ thread th_;
+ file_t pipe_[2];
- int tcp_; //file desciptor for accepting connection
+ socket_t tcp_; // listens for connections
chanmgr *mgr_;
int lossy_;
chanmgr *mgr_;
int lossy_;
- std::map<int, connection *> conns_;
+ map<int, shared_ptr<connection>> conns_;
void process_accept();
};
void process_accept();
};
@@
-103,5
+88,5
@@
struct bundle {
int lossy;
};
int lossy;
};
-connection *connect_to_dst(const sockaddr_in &dst, chanmgr *mgr, int lossy=0);
+shared_ptr<connection> connect_to_dst(const sockaddr_in &dst, chanmgr *mgr, int lossy=0);
#endif
#endif