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
3e19a93
..
b1df8a1
100644
(file)
--- a/
rpc/connection.h
+++ b/
rpc/connection.h
@@
-2,7
+2,6
@@
#define connection_h
#include "types.h"
#define connection_h
#include "types.h"
-#include <sys/types.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include "pollmgr.h"
#include <arpa/inet.h>
#include <netinet/in.h>
#include "pollmgr.h"
@@
-16,11
+15,11
@@
class connection;
class chanmgr {
public:
class chanmgr {
public:
- virtual bool got_pdu(connection *c, const string & b) = 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 {
string buf;
public:
struct charbuf {
string buf;
@@
-31,18
+30,14
@@
class connection : public aio_callback {
~connection();
int channo() { return fd_; }
~connection();
int channo() { return fd_; }
- bool isdead();
+ bool isdead() { lock ml(m_); return dead_; }
void closeconn();
bool send(const string & b);
void write_cb(int s);
void read_cb(int s);
void closeconn();
bool send(const string & b);
void write_cb(int s);
void read_cb(int s);
- void incref();
- void decref();
- int ref() { lock rl(ref_m_); return refno_; }
-
- int compare(connection *another);
+ time_point<steady_clock> create_time() const { return create_time_; }
private:
private:
@@
-59,11
+54,9
@@
class connection : public aio_callback {
time_point<steady_clock> create_time_;
int waiters_ = 0;
time_point<steady_clock> create_time_;
int waiters_ = 0;
- int refno_ = 1;
int lossy_ = 0;
mutex m_;
int lossy_ = 0;
mutex m_;
- mutex ref_m_;
cond send_complete_;
cond send_wait_;
};
cond send_complete_;
cond send_wait_;
};
@@
-83,7
+76,7
@@
class tcpsconn {
socket_t tcp_; // listens for connections
chanmgr *mgr_;
int lossy_;
socket_t tcp_; // listens for connections
chanmgr *mgr_;
int lossy_;
- map<int, connection *> conns_;
+ map<int, shared_ptr<connection>> conns_;
void process_accept();
};
void process_accept();
};
@@
-95,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