Commit 7460d00b authored by Pieter Hintjens's avatar Pieter Hintjens

Merge pull request #598 from hurtonm/master

Use generic session class whenever possible
parents 1beec5e9 fd7e9b8c
...@@ -113,15 +113,3 @@ void zmq::dealer_t::xpipe_terminated (pipe_t *pipe_) ...@@ -113,15 +113,3 @@ void zmq::dealer_t::xpipe_terminated (pipe_t *pipe_)
fq.pipe_terminated (pipe_); fq.pipe_terminated (pipe_);
lb.pipe_terminated (pipe_); lb.pipe_terminated (pipe_);
} }
zmq::dealer_session_t::dealer_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::dealer_session_t::~dealer_session_t ()
{
}
...@@ -69,21 +69,6 @@ namespace zmq ...@@ -69,21 +69,6 @@ namespace zmq
const dealer_t &operator = (const dealer_t&); const dealer_t &operator = (const dealer_t&);
}; };
class dealer_session_t : public session_base_t
{
public:
dealer_session_t (zmq::io_thread_t *io_thread_, bool connect_,
zmq::socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~dealer_session_t ();
private:
dealer_session_t (const dealer_session_t&);
const dealer_session_t &operator = (const dealer_session_t&);
};
} }
#endif #endif
...@@ -117,15 +117,3 @@ bool zmq::pair_t::xhas_out () ...@@ -117,15 +117,3 @@ bool zmq::pair_t::xhas_out ()
return pipe->check_write (); return pipe->check_write ();
} }
zmq::pair_session_t::pair_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::pair_session_t::~pair_session_t ()
{
}
...@@ -57,21 +57,6 @@ namespace zmq ...@@ -57,21 +57,6 @@ namespace zmq
const pair_t &operator = (const pair_t&); const pair_t &operator = (const pair_t&);
}; };
class pair_session_t : public session_base_t
{
public:
pair_session_t (zmq::io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~pair_session_t ();
private:
pair_session_t (const pair_session_t&);
const pair_session_t &operator = (const pair_session_t&);
};
} }
#endif #endif
...@@ -41,15 +41,3 @@ bool zmq::pub_t::xhas_in () ...@@ -41,15 +41,3 @@ bool zmq::pub_t::xhas_in ()
{ {
return false; return false;
} }
zmq::pub_session_t::pub_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
xpub_session_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::pub_session_t::~pub_session_t ()
{
}
...@@ -47,21 +47,6 @@ namespace zmq ...@@ -47,21 +47,6 @@ namespace zmq
const pub_t &operator = (const pub_t&); const pub_t &operator = (const pub_t&);
}; };
class pub_session_t : public xpub_session_t
{
public:
pub_session_t (zmq::io_thread_t *io_thread_, bool connect_,
zmq::socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~pub_session_t ();
private:
pub_session_t (const pub_session_t&);
const pub_session_t &operator = (const pub_session_t&);
};
} }
#endif #endif
...@@ -60,15 +60,3 @@ bool zmq::pull_t::xhas_in () ...@@ -60,15 +60,3 @@ bool zmq::pull_t::xhas_in ()
{ {
return fq.has_in (); return fq.has_in ();
} }
zmq::pull_session_t::pull_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::pull_session_t::~pull_session_t ()
{
}
...@@ -59,21 +59,6 @@ namespace zmq ...@@ -59,21 +59,6 @@ namespace zmq
}; };
class pull_session_t : public session_base_t
{
public:
pull_session_t (zmq::io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~pull_session_t ();
private:
pull_session_t (const pull_session_t&);
const pull_session_t &operator = (const pull_session_t&);
};
} }
#endif #endif
...@@ -60,15 +60,3 @@ bool zmq::push_t::xhas_out () ...@@ -60,15 +60,3 @@ bool zmq::push_t::xhas_out ()
{ {
return lb.has_out (); return lb.has_out ();
} }
zmq::push_session_t::push_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::push_session_t::~push_session_t ()
{
}
...@@ -58,21 +58,6 @@ namespace zmq ...@@ -58,21 +58,6 @@ namespace zmq
const push_t &operator = (const push_t&); const push_t &operator = (const push_t&);
}; };
class push_session_t : public session_base_t
{
public:
push_session_t (zmq::io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~push_session_t ();
private:
push_session_t (const push_session_t&);
const push_session_t &operator = (const push_session_t&);
};
} }
#endif #endif
...@@ -121,15 +121,3 @@ bool zmq::rep_t::xhas_out () ...@@ -121,15 +121,3 @@ bool zmq::rep_t::xhas_out ()
return router_t::xhas_out (); return router_t::xhas_out ();
} }
zmq::rep_session_t::rep_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
router_session_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::rep_session_t::~rep_session_t ()
{
}
...@@ -58,21 +58,6 @@ namespace zmq ...@@ -58,21 +58,6 @@ namespace zmq
}; };
class rep_session_t : public router_session_t
{
public:
rep_session_t (zmq::io_thread_t *io_thread_, bool connect_,
zmq::socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~rep_session_t ();
private:
rep_session_t (const rep_session_t&);
const rep_session_t &operator = (const rep_session_t&);
};
} }
#endif #endif
...@@ -137,7 +137,7 @@ bool zmq::req_t::xhas_out () ...@@ -137,7 +137,7 @@ bool zmq::req_t::xhas_out ()
zmq::req_session_t::req_session_t (io_thread_t *io_thread_, bool connect_, zmq::req_session_t::req_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_, socket_base_t *socket_, const options_t &options_,
const address_t *addr_) : const address_t *addr_) :
dealer_session_t (io_thread_, connect_, socket_, options_, addr_), session_base_t (io_thread_, connect_, socket_, options_, addr_),
state (bottom) state (bottom)
{ {
} }
...@@ -152,15 +152,15 @@ int zmq::req_session_t::push_msg (msg_t *msg_) ...@@ -152,15 +152,15 @@ int zmq::req_session_t::push_msg (msg_t *msg_)
case bottom: case bottom:
if (msg_->flags () == msg_t::more && msg_->size () == 0) { if (msg_->flags () == msg_t::more && msg_->size () == 0) {
state = body; state = body;
return dealer_session_t::push_msg (msg_); return session_base_t::push_msg (msg_);
} }
break; break;
case body: case body:
if (msg_->flags () == msg_t::more) if (msg_->flags () == msg_t::more)
return dealer_session_t::push_msg (msg_); return session_base_t::push_msg (msg_);
if (msg_->flags () == 0) { if (msg_->flags () == 0) {
state = bottom; state = bottom;
return dealer_session_t::push_msg (msg_); return session_base_t::push_msg (msg_);
} }
break; break;
} }
......
...@@ -58,7 +58,7 @@ namespace zmq ...@@ -58,7 +58,7 @@ namespace zmq
const req_t &operator = (const req_t&); const req_t &operator = (const req_t&);
}; };
class req_session_t : public dealer_session_t class req_session_t : public session_base_t
{ {
public: public:
......
...@@ -406,15 +406,3 @@ bool zmq::router_t::identify_peer (pipe_t *pipe_) ...@@ -406,15 +406,3 @@ bool zmq::router_t::identify_peer (pipe_t *pipe_)
return true; return true;
} }
zmq::router_session_t::router_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::router_session_t::~router_session_t ()
{
}
...@@ -119,21 +119,6 @@ namespace zmq ...@@ -119,21 +119,6 @@ namespace zmq
const router_t &operator = (const router_t&); const router_t &operator = (const router_t&);
}; };
class router_session_t : public session_base_t
{
public:
router_session_t (zmq::io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~router_session_t ();
private:
router_session_t (const router_session_t&);
const router_session_t &operator = (const router_session_t&);
};
} }
#endif #endif
...@@ -30,17 +30,6 @@ ...@@ -30,17 +30,6 @@
#include "ctx.hpp" #include "ctx.hpp"
#include "req.hpp" #include "req.hpp"
#include "dealer.hpp"
#include "rep.hpp"
#include "router.hpp"
#include "pub.hpp"
#include "xpub.hpp"
#include "sub.hpp"
#include "xsub.hpp"
#include "push.hpp"
#include "pull.hpp"
#include "pair.hpp"
#include "stream.hpp"
zmq::session_base_t *zmq::session_base_t::create (class io_thread_t *io_thread_, zmq::session_base_t *zmq::session_base_t::create (class io_thread_t *io_thread_,
bool connect_, class socket_base_t *socket_, const options_t &options_, bool connect_, class socket_base_t *socket_, const options_t &options_,
...@@ -53,47 +42,17 @@ zmq::session_base_t *zmq::session_base_t::create (class io_thread_t *io_thread_, ...@@ -53,47 +42,17 @@ zmq::session_base_t *zmq::session_base_t::create (class io_thread_t *io_thread_,
socket_, options_, addr_); socket_, options_, addr_);
break; break;
case ZMQ_DEALER: case ZMQ_DEALER:
s = new (std::nothrow) dealer_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_REP: case ZMQ_REP:
s = new (std::nothrow) rep_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_ROUTER: case ZMQ_ROUTER:
s = new (std::nothrow) router_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_PUB: case ZMQ_PUB:
s = new (std::nothrow) pub_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_XPUB: case ZMQ_XPUB:
s = new (std::nothrow) xpub_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_SUB: case ZMQ_SUB:
s = new (std::nothrow) sub_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_XSUB: case ZMQ_XSUB:
s = new (std::nothrow) xsub_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_PUSH: case ZMQ_PUSH:
s = new (std::nothrow) push_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_PULL: case ZMQ_PULL:
s = new (std::nothrow) pull_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_PAIR: case ZMQ_PAIR:
s = new (std::nothrow) pair_session_t (io_thread_, connect_,
socket_, options_, addr_);
break;
case ZMQ_STREAM: case ZMQ_STREAM:
s = new (std::nothrow) stream_session_t (io_thread_, connect_, s = new (std::nothrow) session_base_t (io_thread_, connect_,
socket_, options_, addr_); socket_, options_, addr_);
break; break;
default: default:
......
...@@ -255,15 +255,3 @@ void zmq::stream_t::identify_peer (pipe_t *pipe_) ...@@ -255,15 +255,3 @@ void zmq::stream_t::identify_peer (pipe_t *pipe_)
outpipes_t::value_type (identity, outpipe)).second; outpipes_t::value_type (identity, outpipe)).second;
zmq_assert (ok); zmq_assert (ok);
} }
zmq::stream_session_t::stream_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::stream_session_t::~stream_session_t ()
{
}
...@@ -92,21 +92,6 @@ namespace zmq ...@@ -92,21 +92,6 @@ namespace zmq
const stream_t &operator = (const stream_t&); const stream_t &operator = (const stream_t&);
}; };
class stream_session_t : public session_base_t
{
public:
stream_session_t (zmq::io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~stream_session_t ();
private:
stream_session_t (const stream_session_t&);
const stream_session_t &operator = (const stream_session_t&);
};
} }
#endif #endif
...@@ -78,15 +78,3 @@ bool zmq::sub_t::xhas_out () ...@@ -78,15 +78,3 @@ bool zmq::sub_t::xhas_out ()
// Overload the XSUB's send. // Overload the XSUB's send.
return false; return false;
} }
zmq::sub_session_t::sub_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
xsub_session_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::sub_session_t::~sub_session_t ()
{
}
...@@ -49,21 +49,6 @@ namespace zmq ...@@ -49,21 +49,6 @@ namespace zmq
const sub_t &operator = (const sub_t&); const sub_t &operator = (const sub_t&);
}; };
class sub_session_t : public xsub_session_t
{
public:
sub_session_t (zmq::io_thread_t *io_thread_, bool connect_,
zmq::socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~sub_session_t ();
private:
sub_session_t (const sub_session_t&);
const sub_session_t &operator = (const sub_session_t&);
};
} }
#endif #endif
...@@ -189,15 +189,3 @@ void zmq::xpub_t::send_unsubscription (unsigned char *data_, size_t size_, ...@@ -189,15 +189,3 @@ void zmq::xpub_t::send_unsubscription (unsigned char *data_, size_t size_,
self->pending_flags.push_back (0); self->pending_flags.push_back (0);
} }
} }
zmq::xpub_session_t::xpub_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::xpub_session_t::~xpub_session_t ()
{
}
...@@ -89,21 +89,6 @@ namespace zmq ...@@ -89,21 +89,6 @@ namespace zmq
const xpub_t &operator = (const xpub_t&); const xpub_t &operator = (const xpub_t&);
}; };
class xpub_session_t : public session_base_t
{
public:
xpub_session_t (zmq::io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~xpub_session_t ();
private:
xpub_session_t (const xpub_session_t&);
const xpub_session_t &operator = (const xpub_session_t&);
};
} }
#endif #endif
...@@ -226,15 +226,3 @@ void zmq::xsub_t::send_subscription (unsigned char *data_, size_t size_, ...@@ -226,15 +226,3 @@ void zmq::xsub_t::send_subscription (unsigned char *data_, size_t size_,
if (!sent) if (!sent)
msg.close (); msg.close ();
} }
zmq::xsub_session_t::xsub_session_t (io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_) :
session_base_t (io_thread_, connect_, socket_, options_, addr_)
{
}
zmq::xsub_session_t::~xsub_session_t ()
{
}
...@@ -86,21 +86,6 @@ namespace zmq ...@@ -86,21 +86,6 @@ namespace zmq
const xsub_t &operator = (const xsub_t&); const xsub_t &operator = (const xsub_t&);
}; };
class xsub_session_t : public session_base_t
{
public:
xsub_session_t (class io_thread_t *io_thread_, bool connect_,
socket_base_t *socket_, const options_t &options_,
const address_t *addr_);
~xsub_session_t ();
private:
xsub_session_t (const xsub_session_t&);
const xsub_session_t &operator = (const xsub_session_t&);
};
} }
#endif #endif
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment