Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(73)

Side by Side Diff: remoting/host/json_host_config.cc

Issue 7661009: base: Add Is* functions to Value class. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: tony review Created 9 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "remoting/host/json_host_config.h" 5 #include "remoting/host/json_host_config.h"
6 6
7 #include "base/file_util.h" 7 #include "base/file_util.h"
8 #include "base/json/json_reader.h" 8 #include "base/json/json_reader.h"
9 #include "base/json/json_writer.h" 9 #include "base/json/json_writer.h"
10 #include "base/message_loop_proxy.h" 10 #include "base/message_loop_proxy.h"
11 #include "base/synchronization/lock.h" 11 #include "base/synchronization/lock.h"
(...skipping 12 matching lines...) Expand all
24 JsonHostConfig::~JsonHostConfig() {} 24 JsonHostConfig::~JsonHostConfig() {}
25 25
26 bool JsonHostConfig::Read() { 26 bool JsonHostConfig::Read() {
27 // TODO(sergeyu): Implement better error handling here. 27 // TODO(sergeyu): Implement better error handling here.
28 std::string file_content; 28 std::string file_content;
29 if (!file_util::ReadFileToString(filename_, &file_content)) { 29 if (!file_util::ReadFileToString(filename_, &file_content)) {
30 return false; 30 return false;
31 } 31 }
32 32
33 scoped_ptr<Value> value(base::JSONReader::Read(file_content, true)); 33 scoped_ptr<Value> value(base::JSONReader::Read(file_content, true));
34 if (value.get() == NULL || !value->IsType(Value::TYPE_DICTIONARY)) { 34 if (value.get() == NULL || !value->IsDictionary()) {
35 return false; 35 return false;
36 } 36 }
37 37
38 DictionaryValue* dictionary = static_cast<DictionaryValue*>(value.release()); 38 DictionaryValue* dictionary = static_cast<DictionaryValue*>(value.release());
39 base::AutoLock auto_lock(lock_); 39 base::AutoLock auto_lock(lock_);
40 values_.reset(dictionary); 40 values_.reset(dictionary);
41 return true; 41 return true;
42 } 42 }
43 43
44 void JsonHostConfig::Save() { 44 void JsonHostConfig::Save() {
45 message_loop_proxy_->PostTask( 45 message_loop_proxy_->PostTask(
46 FROM_HERE, NewRunnableMethod(this, &JsonHostConfig::DoWrite)); 46 FROM_HERE, NewRunnableMethod(this, &JsonHostConfig::DoWrite));
47 } 47 }
48 48
49 void JsonHostConfig::DoWrite() { 49 void JsonHostConfig::DoWrite() {
50 std::string file_content; 50 std::string file_content;
51 base::AutoLock auto_lock(lock_); 51 base::AutoLock auto_lock(lock_);
52 base::JSONWriter::Write(values_.get(), true, &file_content); 52 base::JSONWriter::Write(values_.get(), true, &file_content);
53 // TODO(sergeyu): Move ImportantFileWriter to base and use it here. 53 // TODO(sergeyu): Move ImportantFileWriter to base and use it here.
54 file_util::WriteFile(filename_, file_content.c_str(), file_content.size()); 54 file_util::WriteFile(filename_, file_content.c_str(), file_content.size());
55 } 55 }
56 56
57 } // namespace remoting 57 } // namespace remoting
OLDNEW
« no previous file with comments | « remoting/client/plugin/chromoting_instance.cc ('k') | remoting/host/plugin/policy_hack/nat_policy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698