123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- // ----------------------------------------------------------------------------
- // Copyright (C) 2002-2006 Marcin Kalicinski
- // Copyright (C) 2015 Sebastian Redl
- //
- // Distributed under the Boost Software License, Version 1.0.
- // (See accompanying file LICENSE_1_0.txt or copy at
- // http://www.boost.org/LICENSE_1_0.txt)
- //
- // For more information, see www.boost.org
- // ----------------------------------------------------------------------------
- #ifndef BOOST_PROPERTY_TREE_JSON_PARSER_HPP_INCLUDED
- #define BOOST_PROPERTY_TREE_JSON_PARSER_HPP_INCLUDED
- #include <boost/property_tree/ptree.hpp>
- #include <boost/property_tree/json_parser/error.hpp>
- #include <boost/property_tree/json_parser/detail/read.hpp>
- #include <boost/property_tree/json_parser/detail/write.hpp>
- #include <fstream>
- #include <string>
- #include <locale>
- namespace boost { namespace property_tree { namespace json_parser
- {
- /**
- * Read JSON from a the given stream and translate it to a property tree.
- * @note Clears existing contents of property tree. In case of error the
- * property tree unmodified.
- * @note Items of JSON arrays are translated into ptree keys with empty
- * names. Members of objects are translated into named keys.
- * @note JSON data can be a string, a numeric value, or one of literals
- * "null", "true" and "false". During parse, any of the above is
- * copied verbatim into ptree data string.
- * @throw json_parser_error In case of error deserializing the property
- * tree.
- * @param stream Stream from which to read in the property tree.
- * @param[out] pt The property tree to populate.
- */
- template<class Ptree>
- void read_json(std::basic_istream<
- typename Ptree::key_type::value_type
- > &stream,
- Ptree &pt)
- {
- detail::read_json_internal(stream, pt, std::string());
- }
- /**
- * Read JSON from a the given file and translate it to a property tree.
- * @note Clears existing contents of property tree. In case of error the
- * property tree unmodified.
- * @note Items of JSON arrays are translated into ptree keys with empty
- * names. Members of objects are translated into named keys.
- * @note JSON data can be a string, a numeric value, or one of literals
- * "null", "true" and "false". During parse, any of the above is
- * copied verbatim into ptree data string.
- * @throw json_parser_error In case of error deserializing the property
- * tree.
- * @param filename Name of file from which to read in the property tree.
- * @param[out] pt The property tree to populate.
- * @param loc The locale to use when reading in the file contents.
- */
- template<class Ptree>
- void read_json(const std::string &filename,
- Ptree &pt,
- const std::locale &loc = std::locale())
- {
- std::basic_ifstream<typename Ptree::key_type::value_type>
- stream(filename.c_str());
- if (!stream)
- BOOST_PROPERTY_TREE_THROW(json_parser_error(
- "cannot open file", filename, 0));
- stream.imbue(loc);
- detail::read_json_internal(stream, pt, filename);
- }
- /**
- * Translates the property tree to JSON and writes it the given output
- * stream.
- * @note Any property tree key containing only unnamed subkeys will be
- * rendered as JSON arrays.
- * @pre @e pt cannot contain keys that have both subkeys and non-empty data.
- * @throw json_parser_error In case of error translating the property tree
- * to JSON or writing to the output stream.
- * @param stream The stream to which to write the JSON representation of the
- * property tree.
- * @param pt The property tree to tranlsate to JSON and output.
- * @param pretty Whether to pretty-print. Defaults to true for backward
- * compatibility.
- */
- template<class Ptree>
- void write_json(std::basic_ostream<
- typename Ptree::key_type::value_type
- > &stream,
- const Ptree &pt,
- bool pretty = true)
- {
- write_json_internal(stream, pt, std::string(), pretty);
- }
- /**
- * Translates the property tree to JSON and writes it the given file.
- * @note Any property tree key containing only unnamed subkeys will be
- * rendered as JSON arrays.
- * @pre @e pt cannot contain keys that have both subkeys and non-empty data.
- * @throw json_parser_error In case of error translating the property tree
- * to JSON or writing to the file.
- * @param filename The name of the file to which to write the JSON
- * representation of the property tree.
- * @param pt The property tree to translate to JSON and output.
- * @param loc The locale to use when writing out to the output file.
- * @param pretty Whether to pretty-print. Defaults to true and last place
- * for backward compatibility.
- */
- template<class Ptree>
- void write_json(const std::string &filename,
- const Ptree &pt,
- const std::locale &loc = std::locale(),
- bool pretty = true)
- {
- std::basic_ofstream<typename Ptree::key_type::value_type>
- stream(filename.c_str());
- if (!stream)
- BOOST_PROPERTY_TREE_THROW(json_parser_error(
- "cannot open file", filename, 0));
- stream.imbue(loc);
- write_json_internal(stream, pt, filename, pretty);
- }
- } } }
- namespace boost { namespace property_tree
- {
- using json_parser::read_json;
- using json_parser::write_json;
- using json_parser::json_parser_error;
- } }
- #endif
|