You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.0 KiB
69 lines
2.0 KiB
7 months ago
|
// Copyright 2019 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 "util/json/json_serialization.h"
|
||
|
|
||
|
#include <memory>
|
||
|
#include <sstream>
|
||
|
#include <string>
|
||
|
#include <utility>
|
||
|
|
||
|
#include "json/reader.h"
|
||
|
#include "json/writer.h"
|
||
|
#include "platform/base/error.h"
|
||
|
#include "util/osp_logging.h"
|
||
|
|
||
|
namespace openscreen {
|
||
|
namespace json {
|
||
|
|
||
|
ErrorOr<Json::Value> Parse(absl::string_view document) {
|
||
|
Json::CharReaderBuilder builder;
|
||
|
Json::CharReaderBuilder::strictMode(&builder.settings_);
|
||
|
if (document.empty()) {
|
||
|
return ErrorOr<Json::Value>(Error::Code::kJsonParseError, "empty document");
|
||
|
}
|
||
|
|
||
|
Json::Value root_node;
|
||
|
std::string error_msg;
|
||
|
std::unique_ptr<Json::CharReader> reader(builder.newCharReader());
|
||
|
const bool succeeded =
|
||
|
reader->parse(document.begin(), document.end(), &root_node, &error_msg);
|
||
|
if (!succeeded) {
|
||
|
return ErrorOr<Json::Value>(Error::Code::kJsonParseError, error_msg);
|
||
|
}
|
||
|
|
||
|
return root_node;
|
||
|
}
|
||
|
|
||
|
ErrorOr<std::string> Stringify(const Json::Value& value) {
|
||
|
if (value.empty()) {
|
||
|
return ErrorOr<std::string>(Error::Code::kJsonWriteError, "Empty value");
|
||
|
}
|
||
|
|
||
|
Json::StreamWriterBuilder factory;
|
||
|
#ifndef _DEBUG
|
||
|
// Default is to "pretty print" the output JSON in a human readable
|
||
|
// format. On non-debug builds, we can remove pretty printing by simply
|
||
|
// getting rid of all indentation.
|
||
|
factory["indentation"] = "";
|
||
|
#endif
|
||
|
|
||
|
std::unique_ptr<Json::StreamWriter> const writer(factory.newStreamWriter());
|
||
|
std::ostringstream stream;
|
||
|
writer->write(value, &stream);
|
||
|
|
||
|
if (!stream) {
|
||
|
// Note: jsoncpp doesn't give us more information about what actually
|
||
|
// went wrong, just says to "check the stream". However, failures on
|
||
|
// the stream should be rare, as we do not throw any errors in the jsoncpp
|
||
|
// library.
|
||
|
return ErrorOr<std::string>(Error::Code::kJsonWriteError, "Invalid stream");
|
||
|
}
|
||
|
|
||
|
return stream.str();
|
||
|
}
|
||
|
|
||
|
} // namespace json
|
||
|
} // namespace openscreen
|