blob: a5e6bf5b8185cf57f6a3d3e509cadfd2de999f30 (
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
|
// 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.
#ifndef EXTENSIONS_BROWSER_VALUE_STORE_VALUE_STORE_CHANGE_H_
#define EXTENSIONS_BROWSER_VALUE_STORE_VALUE_STORE_CHANGE_H_
#include <string>
#include <vector>
#include "base/memory/ref_counted.h"
#include "base/memory/scoped_ptr.h"
#include "base/values.h"
class ValueStoreChange;
typedef std::vector<ValueStoreChange> ValueStoreChangeList;
// A change to a setting. Safe/efficient to copy.
class ValueStoreChange {
public:
// Converts an ValueStoreChangeList into JSON of the form:
// { "foo": { "key": "foo", "oldValue": "bar", "newValue": "baz" } }
static std::string ToJson(const ValueStoreChangeList& changes);
// Ownership of |old_value| and |new_value| taken.
ValueStoreChange(
const std::string& key, base::Value* old_value, base::Value* new_value);
ValueStoreChange(const ValueStoreChange& other);
~ValueStoreChange();
// Gets the key of the setting which changed.
const std::string& key() const;
// Gets the value of the setting before the change, or NULL if there was no
// old value.
const base::Value* old_value() const;
// Gets the value of the setting after the change, or NULL if there is no new
// value.
const base::Value* new_value() const;
private:
class Inner : public base::RefCountedThreadSafe<Inner> {
public:
Inner(
const std::string& key, base::Value* old_value, base::Value* new_value);
const std::string key_;
const scoped_ptr<base::Value> old_value_;
const scoped_ptr<base::Value> new_value_;
private:
friend class base::RefCountedThreadSafe<Inner>;
virtual ~Inner();
};
scoped_refptr<Inner> inner_;
};
#endif // EXTENSIONS_BROWSER_VALUE_STORE_VALUE_STORE_CHANGE_H_
|