poller_base.hpp 2.44 KB
Newer Older
1
/*
2
    Copyright (c) 2007-2014 Contributors as noted in the AUTHORS file
3 4 5 6

    This file is part of 0MQ.

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

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

#ifndef __ZMQ_POLLER_BASE_HPP_INCLUDED__
#define __ZMQ_POLLER_BASE_HPP_INCLUDED__

23 24 25
#include <map>

#include "clock.hpp"
26 27 28 29 30
#include "atomic_counter.hpp"

namespace zmq
{

31 32
    struct i_poll_events;

33 34 35 36 37
    class poller_base_t
    {
    public:

        poller_base_t ();
38
        virtual ~poller_base_t ();
39 40 41 42 43

        //  Returns load of the poller. Note that this function can be
        //  invoked from a different thread!
        int get_load ();

44 45 46
        //  Add a timeout to expire in timeout_ milliseconds. After the
        //  expiration timer_event on sink_ object will be called with
        //  argument set to id_.
47
        void add_timer (int timeout_, zmq::i_poll_events *sink_, int id_);
48 49

        //  Cancel the timer created by sink_ object with ID equal to id_.
50
        void cancel_timer (zmq::i_poll_events *sink_, int id_);
51

52 53 54 55 56
    protected:

        //  Called by individual poller implementations to manage the load.
        void adjust_load (int amount_);

57 58 59 60
        //  Executes any timers that are due. Returns number of milliseconds
        //  to wait to match the next timer or 0 meaning "no timers".
        uint64_t execute_timers ();

61 62
    private:

63 64 65 66 67 68
        //  Clock instance private to this I/O thread.
        clock_t clock;

        //  List of active timers.
        struct timer_info_t
        {
69
            zmq::i_poll_events *sink;
70 71 72 73 74
            int id;
        };
        typedef std::multimap <uint64_t, timer_info_t> timers_t;
        timers_t timers;

75 76 77 78 79
        //  Load of the poller. Currently the number of file descriptors
        //  registered.
        atomic_counter_t load;

        poller_base_t (const poller_base_t&);
80
        const poller_base_t &operator = (const poller_base_t&);
81 82 83 84 85
    };

}

#endif