mirror of
https://github.com/pocoproject/poco.git
synced 2025-04-23 16:52:44 +02:00
60 lines
1.6 KiB
C++
60 lines
1.6 KiB
C++
//
|
|
// Stringifier.h
|
|
//
|
|
// $Id$
|
|
//
|
|
// Library: JSON
|
|
// Package: JSON
|
|
// Module: Stringifier
|
|
//
|
|
// Definition of the Stringifier class.
|
|
//
|
|
// Copyright (c) 2012, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
//
|
|
|
|
|
|
#ifndef JSON_JSONStringifier_INCLUDED
|
|
#define JSON_JSONStringifier_INCLUDED
|
|
|
|
|
|
#include "Poco/Dynamic/Var.h"
|
|
#include "Poco/JSON/JSON.h"
|
|
#include <ostream>
|
|
|
|
|
|
namespace Poco {
|
|
namespace JSON {
|
|
|
|
|
|
class JSON_API Stringifier
|
|
/// Helper class for creating a String from a JSON object or array
|
|
{
|
|
public:
|
|
static void condense(const Dynamic::Var& any, std::ostream& out);
|
|
/// Writes a condensed string representation of the value to the output stream while preserving the insertion order.
|
|
/// This is just a "shortcut" to stringify(any, out) with name indicating the function effect.
|
|
|
|
static void stringify(const Dynamic::Var& any, std::ostream& out, unsigned int indent = 0, int step = -1);
|
|
/// Writes a string representation of the value to the output stream.
|
|
/// When indent is 0, the string will be created as small as possible.
|
|
/// When preserveInsertionOrder is true, the original string object members order will be preserved;
|
|
/// otherwise, object members are sorted by their names.
|
|
|
|
static void formatString(const std::string& value, std::ostream& out);
|
|
/// Formats the JSON string and streams it into ostream.
|
|
};
|
|
|
|
|
|
inline void Stringifier::condense(const Dynamic::Var& any, std::ostream& out)
|
|
{
|
|
stringify(any, out, 0, -1);
|
|
}
|
|
|
|
}} // namespace Poco::JSON
|
|
|
|
|
|
#endif // JSON_JSONStringifier_INCLUDED
|