2009-07-29 12:07:54 +02:00
|
|
|
/*
|
|
|
|
Copyright (c) 2007-2009 FastMQ Inc.
|
|
|
|
|
|
|
|
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/>.
|
|
|
|
*/
|
|
|
|
|
2009-08-03 11:30:13 +02:00
|
|
|
#ifndef __ZMQ_PIPE_HPP_INCLUDED__
|
|
|
|
#define __ZMQ_PIPE_HPP_INCLUDED__
|
2009-07-29 12:07:54 +02:00
|
|
|
|
2009-09-16 16:49:09 +02:00
|
|
|
#include "../bindings/c/zmq.h"
|
2009-07-29 12:07:54 +02:00
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
#include "stdint.hpp"
|
|
|
|
#include "i_endpoint.hpp"
|
2009-09-21 14:39:59 +02:00
|
|
|
#include "yarray_item.hpp"
|
2009-07-29 12:07:54 +02:00
|
|
|
#include "ypipe.hpp"
|
|
|
|
#include "config.hpp"
|
2009-08-27 10:54:28 +02:00
|
|
|
#include "object.hpp"
|
2009-07-29 12:07:54 +02:00
|
|
|
|
2009-08-03 11:30:13 +02:00
|
|
|
namespace zmq
|
2009-07-29 12:07:54 +02:00
|
|
|
{
|
|
|
|
|
2009-09-21 14:39:59 +02:00
|
|
|
class reader_t : public object_t, public yarray_item_t
|
2009-08-27 10:54:28 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
reader_t (class object_t *parent_, class pipe_t *pipe_,
|
|
|
|
uint64_t hwm_, uint64_t lwm_);
|
|
|
|
~reader_t ();
|
|
|
|
|
2009-08-28 16:51:46 +02:00
|
|
|
void set_endpoint (i_endpoint *endpoint_);
|
|
|
|
|
2009-09-30 10:08:35 +02:00
|
|
|
// Returns true if there is at least one message to read in the pipe.
|
|
|
|
bool check_read ();
|
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
// Reads a message to the underlying pipe.
|
2009-09-23 10:22:54 +02:00
|
|
|
bool read (zmq_msg_t *msg_);
|
2009-08-27 10:54:28 +02:00
|
|
|
|
2009-08-28 16:51:46 +02:00
|
|
|
// Ask pipe to terminate.
|
|
|
|
void term ();
|
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
private:
|
|
|
|
|
|
|
|
// Command handlers.
|
|
|
|
void process_revive ();
|
2009-08-28 16:51:46 +02:00
|
|
|
void process_pipe_term_ack ();
|
2009-08-27 10:54:28 +02:00
|
|
|
|
|
|
|
// The underlying pipe.
|
|
|
|
class pipe_t *pipe;
|
|
|
|
|
|
|
|
// Pipe writer associated with the other side of the pipe.
|
2009-08-28 16:51:46 +02:00
|
|
|
class writer_t *peer;
|
2009-08-27 10:54:28 +02:00
|
|
|
|
|
|
|
// High and low watermarks for in-memory storage (in bytes).
|
|
|
|
uint64_t hwm;
|
|
|
|
uint64_t lwm;
|
|
|
|
|
|
|
|
// Positions of head and tail of the pipe (in bytes).
|
|
|
|
uint64_t head;
|
|
|
|
uint64_t tail;
|
|
|
|
uint64_t last_sent_head;
|
|
|
|
|
|
|
|
// Endpoint (either session or socket) the pipe is attached to.
|
|
|
|
i_endpoint *endpoint;
|
|
|
|
|
|
|
|
reader_t (const reader_t&);
|
|
|
|
void operator = (const reader_t&);
|
|
|
|
};
|
|
|
|
|
2009-09-21 14:39:59 +02:00
|
|
|
class writer_t : public object_t, public yarray_item_t
|
2009-08-27 10:54:28 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
writer_t (class object_t *parent_, class pipe_t *pipe_,
|
|
|
|
uint64_t hwm_, uint64_t lwm_);
|
|
|
|
~writer_t ();
|
|
|
|
|
2009-08-28 16:51:46 +02:00
|
|
|
void set_endpoint (i_endpoint *endpoint_);
|
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
// Checks whether message with specified size can be written to the
|
|
|
|
// pipe. If writing the message would cause high watermark to be
|
|
|
|
// exceeded, the function returns false.
|
|
|
|
bool check_write (uint64_t size_);
|
|
|
|
|
|
|
|
// Writes a message to the underlying pipe. Returns false if the
|
|
|
|
// message cannot be written because high watermark was reached.
|
2009-09-23 10:22:54 +02:00
|
|
|
bool write (zmq_msg_t *msg_);
|
2009-08-27 10:54:28 +02:00
|
|
|
|
|
|
|
// Flush the messages downsteam.
|
|
|
|
void flush ();
|
|
|
|
|
2009-08-28 16:51:46 +02:00
|
|
|
// Ask pipe to terminate.
|
|
|
|
void term ();
|
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
private:
|
|
|
|
|
2009-08-28 16:51:46 +02:00
|
|
|
// Command handlers.
|
|
|
|
void process_pipe_term ();
|
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
// The underlying pipe.
|
|
|
|
class pipe_t *pipe;
|
|
|
|
|
|
|
|
// Pipe reader associated with the other side of the pipe.
|
2009-08-28 16:51:46 +02:00
|
|
|
class reader_t *peer;
|
2009-08-27 10:54:28 +02:00
|
|
|
|
|
|
|
// High and low watermarks for in-memory storage (in bytes).
|
|
|
|
uint64_t hwm;
|
|
|
|
uint64_t lwm;
|
|
|
|
|
|
|
|
// Positions of head and tail of the pipe (in bytes).
|
|
|
|
uint64_t head;
|
|
|
|
uint64_t tail;
|
|
|
|
|
2009-08-28 16:51:46 +02:00
|
|
|
// Endpoint (either session or socket) the pipe is attached to.
|
|
|
|
i_endpoint *endpoint;
|
|
|
|
|
2009-08-27 10:54:28 +02:00
|
|
|
writer_t (const writer_t&);
|
|
|
|
void operator = (const writer_t&);
|
|
|
|
};
|
|
|
|
|
2009-08-06 12:51:32 +02:00
|
|
|
// Message pipe.
|
2009-08-21 14:29:22 +02:00
|
|
|
class pipe_t : public ypipe_t <zmq_msg_t, false, message_pipe_granularity>
|
2009-07-29 12:07:54 +02:00
|
|
|
{
|
2009-08-27 10:54:28 +02:00
|
|
|
public:
|
|
|
|
|
|
|
|
pipe_t (object_t *reader_parent_, object_t *writer_parent_,
|
|
|
|
uint64_t hwm_, uint64_t lwm_);
|
|
|
|
~pipe_t ();
|
|
|
|
|
|
|
|
reader_t reader;
|
|
|
|
writer_t writer;
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
pipe_t (const pipe_t&);
|
|
|
|
void operator = (const pipe_t&);
|
2009-08-06 12:51:32 +02:00
|
|
|
};
|
2009-07-29 12:07:54 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|