Chromium Code Reviews| Index: components/safe_json/safe_json_parser_mojo_impl.cc |
| diff --git a/components/safe_json/safe_json_parser_mojo_impl.cc b/components/safe_json/safe_json_parser_mojo_impl.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..931c5d07066f3a5e94965eb0d53ab6d200c843a7 |
| --- /dev/null |
| +++ b/components/safe_json/safe_json_parser_mojo_impl.cc |
| @@ -0,0 +1,43 @@ |
| +// Copyright 2016 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 "components/safe_json/safe_json_parser_mojo_impl.h" |
|
Bernhard Bauer
2016/04/13 15:49:08
Technically, we should split this up into a browse
Anand Mistry (off Chromium)
2016/04/14 00:59:49
Well, the utility-side message filter was still in
Bernhard Bauer
2016/04/14 14:11:38
Sure, they get built as different targets, but the
Anand Mistry (off Chromium)
2016/04/18 05:06:45
I've made the change for this latest patchset. How
Bernhard Bauer
2016/04/20 16:43:15
OK, fair enough. It is a rather big change, and in
|
| + |
| +#include <utility> |
| + |
| +#include "base/json/json_reader.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "base/values.h" |
| + |
| +namespace safe_json { |
| + |
| +// static |
| +void SafeJsonParserMojoImpl::Create( |
| + mojo::InterfaceRequest<mojom::SafeJsonParser> request) { |
| + new SafeJsonParserMojoImpl(std::move(request)); |
| +} |
| + |
| +SafeJsonParserMojoImpl::SafeJsonParserMojoImpl( |
| + mojo::InterfaceRequest<mojom::SafeJsonParser> request) |
| + : binding_(this, std::move(request)) {} |
| + |
| +SafeJsonParserMojoImpl::~SafeJsonParserMojoImpl() { |
| +} |
| + |
| +void SafeJsonParserMojoImpl::Parse(const mojo::String& json, |
| + const ParseCallback& callback) { |
| + int error_code; |
| + std::string error; |
| + scoped_ptr<base::Value> value = base::JSONReader::ReadAndReturnError( |
| + json.get(), base::JSON_PARSE_RFC, &error_code, &error); |
| + base::ListValue wrapper; |
| + if (value) { |
| + wrapper.Append(std::move(value)); |
| + callback.Run(wrapper, nullptr); |
| + } else { |
| + callback.Run(wrapper, error); |
| + } |
| +} |
| + |
| +} // namespace safe_json |