blob: 19bdf9d2464409600d139744fe6d3b5bc7336797 (
plain)
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
|
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/invalidation/invalidation_logger.h"
#include "base/memory/scoped_ptr.h"
#include "base/values.h"
#include "chrome/browser/invalidation/invalidation_logger_observer.h"
namespace syncer {
class ObjectIdInvalidationMap;
}
namespace invalidation {
class InvalidationLoggerObserver;
InvalidationLogger::InvalidationLogger()
: last_invalidator_state_(syncer::TRANSIENT_INVALIDATION_ERROR) {}
InvalidationLogger::~InvalidationLogger() {}
void InvalidationLogger::OnRegistration(const base::DictionaryValue& details) {
FOR_EACH_OBSERVER(
InvalidationLoggerObserver, observer_list_, OnRegistration(details));
}
void InvalidationLogger::OnUnregistration(
const base::DictionaryValue& details) {
FOR_EACH_OBSERVER(
InvalidationLoggerObserver, observer_list_, OnUnregistration(details));
}
void InvalidationLogger::OnStateChange(
const syncer::InvalidatorState& newState) {
last_invalidator_state_ = newState;
EmitState();
}
void InvalidationLogger::EmitState() {
FOR_EACH_OBSERVER(InvalidationLoggerObserver,
observer_list_,
OnStateChange(last_invalidator_state_));
}
void InvalidationLogger::OnUpdateIds(const base::DictionaryValue& details) {
FOR_EACH_OBSERVER(
InvalidationLoggerObserver, observer_list_, OnUpdateIds(details));
}
void InvalidationLogger::OnDebugMessage(const base::DictionaryValue& details) {
FOR_EACH_OBSERVER(
InvalidationLoggerObserver, observer_list_, OnDebugMessage(details));
}
void InvalidationLogger::OnInvalidation(
const syncer::ObjectIdInvalidationMap& details) {
FOR_EACH_OBSERVER(
InvalidationLoggerObserver, observer_list_, OnInvalidation(details));
}
void InvalidationLogger::EmitContent() {
// Here we add content to send to the observers not via real time push
// but on explicit request.
EmitState();
}
// Obtain a target object to call whenever we have
// debug messages to display
void InvalidationLogger::RegisterForDebug(
InvalidationLoggerObserver* debug_observer) {
observer_list_.AddObserver(debug_observer);
}
// Removes the target object to call whenever we have
// debug messages to display
void InvalidationLogger::UnregisterForDebug(
InvalidationLoggerObserver* debug_observer) {
observer_list_.RemoveObserver(debug_observer);
}
} // namespace invalidation
|