poller_base.hpp 2.49 KB
Newer Older
1
/*
2 3
    Copyright (c) 2010-2011 250bpm s.r.o.
    Copyright (c) 2010-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_POLLER_BASE_HPP_INCLUDED__
#define __ZMQ_POLLER_BASE_HPP_INCLUDED__

24 25 26
#include <map>

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

namespace zmq
{

32 33
    struct i_poll_events;

34 35 36 37 38
    class poller_base_t
    {
    public:

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

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

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

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

53 54 55 56 57
    protected:

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

58 59 60 61
        //  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 ();

62 63
    private:

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

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

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

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

}

#endif