mtrie.hpp 2.75 KB
Newer Older
1
/*
2
    Copyright (c) 2007-2014 Contributors as noted in the AUTHORS file
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30

    This file is part of 0MQ.

    0MQ is free software; you can redistribute it and/or modify it under
    the terms of the GNU Lesser 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
    GNU Lesser General Public License for more details.

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

#ifndef __ZMQ_MTRIE_HPP_INCLUDED__
#define __ZMQ_MTRIE_HPP_INCLUDED__

#include <stddef.h>
#include <set>

#include "stdint.hpp"

namespace zmq
{

31 32
    class pipe_t;

33 34 35 36 37 38 39 40 41 42 43
    //  Multi-trie. Each node in the trie is a set of pointers to pipes.

    class mtrie_t
    {
    public:

        mtrie_t ();
        ~mtrie_t ();

        //  Add key to the trie. Returns true if it's a new subscription
        //  rather than a duplicate.
44
        bool add (unsigned char *prefix_, size_t size_, zmq::pipe_t *pipe_);
45 46 47 48

        //  Remove all subscriptions for a specific peer from the trie.
        //  If there are no subscriptions left on some topics, invoke the
        //  supplied callback function.
49
        void rm (zmq::pipe_t *pipe_,
50 51 52 53 54
            void (*func_) (unsigned char *data_, size_t size_, void *arg_),
            void *arg_);

        //  Remove specific subscription from the trie. Return true is it was
        //  actually removed rather than de-duplicated.
55
        bool rm (unsigned char *prefix_, size_t size_, zmq::pipe_t *pipe_);
56

57 58
        //  Signal all the matching pipes.
        void match (unsigned char *data_, size_t size_,
59
            void (*func_) (zmq::pipe_t *pipe_, void *arg_), void *arg_);
60 61 62

    private:

63
        bool add_helper (unsigned char *prefix_, size_t size_,
64 65
            zmq::pipe_t *pipe_);
        void rm_helper (zmq::pipe_t *pipe_, unsigned char **buff_,
66 67 68
            size_t buffsize_, size_t maxbuffsize_,
            void (*func_) (unsigned char *data_, size_t size_, void *arg_),
            void *arg_);
69
        bool rm_helper (unsigned char *prefix_, size_t size_,
70
            zmq::pipe_t *pipe_);
71
        bool is_redundant () const;
72

73
        typedef std::set <zmq::pipe_t*> pipes_t;
74
        pipes_t *pipes;
75

76 77
        unsigned char min;
        unsigned short count;
78
        unsigned short live_nodes;
79 80 81 82 83 84 85 86 87 88 89 90 91
        union {
            class mtrie_t *node;
            class mtrie_t **table;
        } next;

        mtrie_t (const mtrie_t&);
        const mtrie_t &operator = (const mtrie_t&);
    };

}

#endif