File: eventdispatcher.h

package info (click to toggle)
gloox 1.0.18-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 6,732 kB
  • ctags: 6,556
  • sloc: cpp: 45,479; sh: 11,344; makefile: 1,018
file content (88 lines) | stat: -rw-r--r-- 2,486 bytes parent folder | download | duplicates (2)
1
2
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*
  Copyright (c) 2008-2016 by Jakob Schröter <js@camaya.net>
  This file is part of the gloox library. http://camaya.net/gloox

  This software is distributed under a license. The full license
  agreement can be found in the file LICENSE in this distribution.
  This software may not be copied, modified, sold or distributed
  other than expressed in the named license agreement.

  This software is distributed without any warranty.
*/


#ifndef EVENTDISPATCHER_H__
#define EVENTDISPATCHER_H__

#include "event.h"

#include <map>
#include <string>

namespace gloox
{

  class EventHandler;

  /**
   * @brief An Event dispatcher.
   *
   * @author Jakob Schröter <js@camaya.net>
   * @since 1.0
   */
  class EventDispatcher
  {

    public:
      /**
       * Creates a new EventDispatcher object. You should not need to use this class directly.
       */
      EventDispatcher();

      /**
       * Virtual Destructor.
       */
      virtual ~EventDispatcher();

      /**
       * Looks for handlers for the given Event, and removes the handlers if requested.
       * @param event The Event to dispatch.
       * @param context An identifier that limits the EventHandlers that will get notified to
       * those that are specifically interested in this context.
       * @param remove Whether or not to remove the context from the list of known contexts. Useful for
       * IQ IDs.
       */
      void dispatch( const Event& event, const std::string& context, bool remove );

      /**
       * Looks for handlers for the given Event, identified by its type.
       * @param event The event to dispatch.
       */
      void dispatch( const Event& event );

      /**
       * Registers the given EventHandler to be notified about Events with the given context.
       * The context will usually be an IQ ID.
       * @param eh The EventHandler to register.
       * @param context The context to register the EventHandler for.
       */
      void registerEventHandler( EventHandler* eh, const std::string& context );

      /**
       * Removes the given EventHandler.
       * @param eh The EventHandler to remove.
       */
      void removeEventHandler( EventHandler* eh );

    private:
      typedef std::multimap<const std::string, EventHandler*> ContextHandlerMap;
      typedef std::multimap<Event::EventType, EventHandler*> TypeHandlerMap;

      ContextHandlerMap m_contextHandlers;
      TypeHandlerMap m_typeHandlers;

  };

}

#endif // EVENTDISPATCHER_H__