blob: c8446c5623cc33d3eb04aa0035461f19d02eea0c [file] [log] [blame]
[email protected]73bd67b2010-07-16 16:00:091// Copyright (c) 2010 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#ifndef CHROME_BROWSER_CHROMEOS_CROS_SETTINGS_H_
6#define CHROME_BROWSER_CHROMEOS_CROS_SETTINGS_H_
[email protected]32b76ef2010-07-26 23:08:247#pragma once
[email protected]73bd67b2010-07-16 16:00:098
9#include <string>
[email protected]93a49ae2010-08-03 23:50:4710#include <vector>
[email protected]73bd67b2010-07-16 16:00:0911
[email protected]7096f562010-08-16 21:59:0412#include "base/hash_tables.h"
[email protected]7096f562010-08-16 21:59:0413#include "base/observer_list.h"
14#include "base/singleton.h"
[email protected]c9177502011-01-01 04:48:4915#include "base/threading/non_thread_safe.h"
[email protected]73bd67b2010-07-16 16:00:0916#include "chrome/browser/chromeos/cros_settings_names.h"
[email protected]7096f562010-08-16 21:59:0417#include "chrome/common/notification_observer.h"
[email protected]73bd67b2010-07-16 16:00:0918
[email protected]dc8caba2010-12-13 16:52:3519namespace base {
20template <typename T> struct DefaultLazyInstanceTraits;
21}
22
[email protected]c02c853d72010-08-07 06:23:2423class Value;
24
[email protected]73bd67b2010-07-16 16:00:0925namespace chromeos {
26
[email protected]93a49ae2010-08-03 23:50:4727class CrosSettingsProvider;
28
[email protected]73bd67b2010-07-16 16:00:0929// A class manages per-device/global settings.
[email protected]c9177502011-01-01 04:48:4930class CrosSettings : public base::NonThreadSafe {
[email protected]73bd67b2010-07-16 16:00:0931 public:
32 // Class factory.
33 static CrosSettings* Get();
34
35 // Helper function to test if given path is a value cros settings name.
[email protected]57ecc4b2010-08-11 03:02:5136 static bool IsCrosSettings(const std::string& path);
[email protected]73bd67b2010-07-16 16:00:0937
38 // Sets |in_value| to given |path| in cros settings.
39 // Note that this takes ownership of |in_value|.
[email protected]57ecc4b2010-08-11 03:02:5140 void Set(const std::string& path, Value* in_value);
[email protected]73bd67b2010-07-16 16:00:0941
[email protected]7096f562010-08-16 21:59:0442 // Fires system setting change notification.
43 void FireObservers(const char* path);
44
[email protected]73bd67b2010-07-16 16:00:0945 // Gets settings value of given |path| to |out_value|.
[email protected]5bc6e9852010-09-16 16:36:1646 // Note that the caller owns |out_value| returned.
[email protected]57ecc4b2010-08-11 03:02:5147 bool Get(const std::string& path, Value** out_value) const;
[email protected]73bd67b2010-07-16 16:00:0948
49 // Convenience forms of Set(). These methods will replace any existing
50 // value at that path, even if it has a different type.
[email protected]57ecc4b2010-08-11 03:02:5151 void SetBoolean(const std::string& path, bool in_value);
52 void SetInteger(const std::string& path, int in_value);
53 void SetReal(const std::string& path, double in_value);
54 void SetString(const std::string& path, const std::string& in_value);
[email protected]73bd67b2010-07-16 16:00:0955
56 // These are convenience forms of Get(). The value will be retrieved
57 // and the return value will be true if the path is valid and the value at
58 // the end of the path can be returned in the form specified.
[email protected]57ecc4b2010-08-11 03:02:5159 bool GetBoolean(const std::string& path, bool* out_value) const;
60 bool GetInteger(const std::string& path, int* out_value) const;
61 bool GetReal(const std::string& path, double* out_value) const;
62 bool GetString(const std::string& path, std::string* out_value) const;
[email protected]46ebf0642010-07-24 02:47:4063
[email protected]93a49ae2010-08-03 23:50:4764 // adding/removing of providers
[email protected]7096f562010-08-16 21:59:0465 bool AddSettingsProvider(CrosSettingsProvider* provider);
66 bool RemoveSettingsProvider(CrosSettingsProvider* provider);
[email protected]93a49ae2010-08-03 23:50:4767
[email protected]7096f562010-08-16 21:59:0468 // If the pref at the given path changes, we call the observer's Observe
[email protected]10abd192010-09-30 02:03:4969 // method with PREF_CHANGED.
[email protected]7096f562010-08-16 21:59:0470 void AddSettingsObserver(const char* path, NotificationObserver* obs);
71 void RemoveSettingsObserver(const char* path, NotificationObserver* obs);
72
73 private:
74 // List of ChromeOS system settings providers.
[email protected]93a49ae2010-08-03 23:50:4775 std::vector<CrosSettingsProvider*> providers_;
76
[email protected]7096f562010-08-16 21:59:0477 // A map from settings names to a list of observers. Observers get fired in
78 // the order they are added.
79 typedef ObserverList<NotificationObserver> NotificationObserverList;
80 typedef base::hash_map<std::string, NotificationObserverList*>
81 SettingsObserverMap;
82 SettingsObserverMap settings_observers_;
83
[email protected]93a49ae2010-08-03 23:50:4784 CrosSettings();
85 ~CrosSettings();
[email protected]57ecc4b2010-08-11 03:02:5186 CrosSettingsProvider* GetProvider(const std::string& path) const;
[email protected]dc8caba2010-12-13 16:52:3587 friend struct base::DefaultLazyInstanceTraits<CrosSettings>;
[email protected]7096f562010-08-16 21:59:0488
[email protected]93a49ae2010-08-03 23:50:4789 DISALLOW_COPY_AND_ASSIGN(CrosSettings);
[email protected]73bd67b2010-07-16 16:00:0990};
91
92} // namespace chromeos
93
94#endif // CHROME_BROWSER_CHROMEOS_CROS_SETTINGS_H_