OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "blimp/net/blimp_message_dispatcher.h" | |
6 | |
7 #include <string> | |
8 | |
9 #include "base/strings/stringprintf.h" | |
10 | |
11 namespace blimp { | |
12 namespace { | |
13 | |
14 std::string BlimpMessageToDebugString(const BlimpMessage& message) { | |
15 return base::StringPrintf("<message type=%d>", message.type()); | |
16 } | |
17 | |
18 } // namespace | |
19 | |
20 BlimpMessageDispatcher::BlimpMessageDispatcher() {} | |
21 | |
22 BlimpMessageDispatcher::~BlimpMessageDispatcher() {} | |
23 | |
24 void BlimpMessageDispatcher::AddReceiver(BlimpMessage::Type type, | |
25 BlimpMessageReceiver* receiver) { | |
26 DCHECK(thread_checker_.CalledOnValidThread()); | |
27 DCHECK(receiver); | |
28 if (feature_receiver_map_.find(type) == feature_receiver_map_.end()) { | |
29 feature_receiver_map_.insert(std::make_pair(type, receiver)); | |
30 } else { | |
31 DCHECK(false) << "Handler already registered for type=" << type << "."; | |
Wez
2015/10/09 23:15:34
DLOG(FATAL)
Kevin M
2015/10/10 00:42:34
Done.
| |
32 } | |
33 } | |
34 | |
35 bool BlimpMessageDispatcher::OnMessage(const BlimpMessage& message) { | |
36 DCHECK(thread_checker_.CalledOnValidThread()); | |
37 | |
38 auto receiver_iter = feature_receiver_map_.find(message.type()); | |
39 if (receiver_iter == feature_receiver_map_.end()) { | |
40 VLOG(0) << "No registered receiver for " | |
41 << BlimpMessageToDebugString(message) << "."; | |
Wez
2015/10/09 23:15:34
As previously noted, this indicates a coding error
Kevin M
2015/10/10 00:42:34
Done.
| |
42 return false; | |
43 } | |
44 | |
45 return receiver_iter->second->OnMessage(message); | |
46 } | |
47 | |
48 } // namespace blimp | |
OLD | NEW |