mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-22 07:29:31 +08:00
11a410b658
definitions as aliases, to be removed in release 3.0. Also renamed the source files implementing these two socket types. This change does not break existing applications nor bindings, but allows us to fix the documentation and user guide now, rather than keeping the old (confusing) names.
99 lines
2.1 KiB
C++
99 lines
2.1 KiB
C++
/*
|
|
Copyright (c) 2007-2010 iMatix Corporation
|
|
|
|
This file is part of 0MQ.
|
|
|
|
0MQ is free software; you can redistribute it and/or modify it under
|
|
the terms of the Lesser GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
0MQ is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
Lesser GNU General Public License for more details.
|
|
|
|
You should have received a copy of the Lesser GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "../include/zmq.h"
|
|
|
|
#include "pull.hpp"
|
|
#include "err.hpp"
|
|
|
|
zmq::pull_t::pull_t (class app_thread_t *parent_) :
|
|
socket_base_t (parent_)
|
|
{
|
|
options.requires_in = true;
|
|
options.requires_out = false;
|
|
}
|
|
|
|
zmq::pull_t::~pull_t ()
|
|
{
|
|
}
|
|
|
|
void zmq::pull_t::xattach_pipes (class reader_t *inpipe_,
|
|
class writer_t *outpipe_, const blob_t &peer_identity_)
|
|
{
|
|
zmq_assert (inpipe_ && !outpipe_);
|
|
fq.attach (inpipe_);
|
|
}
|
|
|
|
void zmq::pull_t::xdetach_inpipe (class reader_t *pipe_)
|
|
{
|
|
zmq_assert (pipe_);
|
|
fq.detach (pipe_);
|
|
}
|
|
|
|
void zmq::pull_t::xdetach_outpipe (class writer_t *pipe_)
|
|
{
|
|
// There are no outpipes, so this function shouldn't be called at all.
|
|
zmq_assert (false);
|
|
}
|
|
|
|
void zmq::pull_t::xkill (class reader_t *pipe_)
|
|
{
|
|
fq.kill (pipe_);
|
|
}
|
|
|
|
void zmq::pull_t::xrevive (class reader_t *pipe_)
|
|
{
|
|
fq.revive (pipe_);
|
|
}
|
|
|
|
void zmq::pull_t::xrevive (class writer_t *pipe_)
|
|
{
|
|
zmq_assert (false);
|
|
}
|
|
|
|
int zmq::pull_t::xsetsockopt (int option_, const void *optval_,
|
|
size_t optvallen_)
|
|
{
|
|
// No special options for this socket type.
|
|
errno = EINVAL;
|
|
return -1;
|
|
}
|
|
|
|
int zmq::pull_t::xsend (zmq_msg_t *msg_, int flags_)
|
|
{
|
|
errno = ENOTSUP;
|
|
return -1;
|
|
}
|
|
|
|
int zmq::pull_t::xrecv (zmq_msg_t *msg_, int flags_)
|
|
{
|
|
return fq.recv (msg_, flags_);
|
|
}
|
|
|
|
bool zmq::pull_t::xhas_in ()
|
|
{
|
|
return fq.has_in ();
|
|
}
|
|
|
|
bool zmq::pull_t::xhas_out ()
|
|
{
|
|
return false;
|
|
}
|
|
|