~ubuntu-branches/ubuntu/utopic/mir/utopic-proposed

« back to all changes in this revision

Viewing changes to src/server/report/logging/message_processor_report.h

  • Committer: Package Import Robot
  • Author(s): Ubuntu daily release
  • Date: 2014-03-10 19:28:46 UTC
  • mto: This revision was merged to the branch mainline in revision 63.
  • Revision ID: package-import@ubuntu.com-20140310192846-rq9qm3ec26yrelo2
Tags: upstream-0.1.6+14.04.20140310
Import upstream version 0.1.6+14.04.20140310

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright © 2013 Canonical Ltd.
 
3
 *
 
4
 * This program is free software: you can redistribute it and/or modify it
 
5
 * under the terms of the GNU General Public License version 3,
 
6
 * as published by the Free Software Foundation.
 
7
 *
 
8
 * This program is distributed in the hope that it will be useful,
 
9
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
 * GNU General Public License for more details.
 
12
 *
 
13
 * You should have received a copy of the GNU General Public License
 
14
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
15
 *
 
16
 * Authored by: Alan Griffiths <alan@octopull.co.uk>
 
17
 */
 
18
 
 
19
#ifndef MIR_REPORT_LOGGING_MESSAGE_PROCESSOR_REPORT_H_
 
20
#define MIR_REPORT_LOGGING_MESSAGE_PROCESSOR_REPORT_H_
 
21
 
 
22
#include "mir/frontend/message_processor_report.h"
 
23
#include "mir/time/clock.h"
 
24
 
 
25
#include <memory>
 
26
#include <mutex>
 
27
#include <unordered_map>
 
28
 
 
29
namespace mir
 
30
{
 
31
namespace logging
 
32
{
 
33
class Logger;
 
34
}
 
35
namespace report
 
36
{
 
37
namespace logging
 
38
{
 
39
namespace detail
 
40
{
 
41
struct InvocationDetails
 
42
{
 
43
    time::Timestamp start;
 
44
    std::string method;
 
45
    std::string exception;
 
46
};
 
47
 
 
48
typedef std::unordered_map<int, InvocationDetails> Invocations;
 
49
 
 
50
struct MediatorDetails
 
51
{
 
52
    Invocations current_invocations;
 
53
};
 
54
 
 
55
typedef std::unordered_map<void const*, MediatorDetails> Mediators;
 
56
}
 
57
 
 
58
class MessageProcessorReport : public mir::frontend::MessageProcessorReport
 
59
{
 
60
public:
 
61
    MessageProcessorReport(
 
62
        std::shared_ptr<mir::logging::Logger> const& log,
 
63
        std::shared_ptr<time::Clock> const& clock);
 
64
 
 
65
    void received_invocation(void const* mediator, int id, std::string const& method);
 
66
 
 
67
    void completed_invocation(void const* mediator, int id, bool result);
 
68
 
 
69
    void unknown_method(void const* mediator, int id, std::string const& method);
 
70
 
 
71
    void exception_handled(void const* mediator, int id, std::exception const& error);
 
72
 
 
73
    void exception_handled(void const* mediator, std::exception const& error);
 
74
 
 
75
    void sent_event(void const* mediator, MirSurfaceEvent const& event);
 
76
 
 
77
    ~MessageProcessorReport() noexcept(true);
 
78
 
 
79
private:
 
80
    std::shared_ptr<mir::logging::Logger> const log;
 
81
    std::shared_ptr<time::Clock> const clock;
 
82
    std::mutex mutex;
 
83
    detail::Mediators mediators;
 
84
};
 
85
}
 
86
}
 
87
}
 
88
 
 
89
#endif /* MIR_REPORT_LOGGING_MESSAGE_PROCESSOR_REPORT_H_ */