io_object.hpp 2.28 KB
Newer Older
1
/*
2 3
    Copyright (c) 2007-2011 iMatix Corporation
    Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
4 5 6 7

    This file is part of 0MQ.

    0MQ is free software; you can redistribute it and/or modify it under
8
    the terms of the GNU Lesser General Public License as published by
9 10 11 12 13 14
    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
15
    GNU Lesser General Public License for more details.
16

17
    You should have received a copy of the GNU Lesser General Public License
18 19 20 21 22 23
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

#ifndef __ZMQ_IO_OBJECT_HPP_INCLUDED__
#define __ZMQ_IO_OBJECT_HPP_INCLUDED__

24 25
#include <stddef.h>

26
#include "stdint.hpp"
27
#include "poller.hpp"
28
#include "i_poll_events.hpp"
29 30 31 32

namespace zmq
{

33 34 35 36 37
    //  Simple base class for objects that live in I/O threads.
    //  It makes communication with the poller object easier and
    //  makes defining unneeded event handlers unnecessary.

    class io_object_t : public i_poll_events
38 39 40
    {
    public:

41 42
        io_object_t (class io_thread_t *io_thread_ = NULL);
        ~io_object_t ();
43

44 45 46 47 48
        //  When migrating an object from one I/O thread to another, first
        //  unplug it, then migrate it, then plug it to the new thread.
        void plug (class io_thread_t *io_thread_);
        void unplug ();

49 50
    protected:

51 52
        typedef poller_t::handle_t handle_t;

53
        //  Methods to access underlying poller object.
54
        handle_t add_fd (fd_t fd_);
55 56 57 58 59
        void rm_fd (handle_t handle_);
        void set_pollin (handle_t handle_);
        void reset_pollin (handle_t handle_);
        void set_pollout (handle_t handle_);
        void reset_pollout (handle_t handle_);
60 61
        void add_timer (int timout_, int id_);
        void cancel_timer (int id_);
62

63 64 65
        //  i_poll_events interface implementation.
        void in_event ();
        void out_event ();
66
        void timer_event (int id_);
67

68 69
    private:

70
        poller_t *poller;
71

72
        io_object_t (const io_object_t&);
73
        const io_object_t &operator = (const io_object_t&);
74 75 76 77 78
    };

}

#endif