|
22 | 22 | namespace Json {
|
23 | 23 |
|
24 | 24 | class Value;
|
| 25 | +class StreamWriterBuilder; |
| 26 | + |
| 27 | +/** |
| 28 | +
|
| 29 | +Usage: |
| 30 | +
|
| 31 | + using namespace Json; |
| 32 | + Value value; |
| 33 | + StreamWriterBuilderFactory f; |
| 34 | + StreamWriter::Builder builder(&f); |
| 35 | + builder.setCommentStyle(StreamWriter::CommentStyle::None); |
| 36 | + std::shared_ptr<StreamWriter> writer(builder.newStreamWriter(&std::cout)); |
| 37 | + writer.write(value); |
| 38 | +*/ |
| 39 | +class JSON_API StreamWriterBuilderFactory { |
| 40 | +public: |
| 41 | + virtual ~StreamWriterBuilderFactory(); |
| 42 | + virtual StreamWriterBuilder* newStreamWriterBuilder() const; |
| 43 | +}; |
25 | 44 |
|
26 | 45 | class JSON_API StreamWriter {
|
27 | 46 | protected:
|
28 | 47 | std::ostream& sout_; // not owned; will not delete
|
29 | 48 | public:
|
| 49 | + enum class CommentStyle {None, Some, All}; |
| 50 | + |
30 | 51 | StreamWriter(std::ostream* sout);
|
31 | 52 | virtual ~StreamWriter();
|
32 | 53 | /// Write Value into document as configured in sub-class.
|
33 | 54 | /// \return zero on success
|
34 | 55 | /// \throw std::exception possibly, depending on configuration
|
35 | 56 | virtual int write(Value const& root) const = 0;
|
36 |
| -}; |
37 | 57 |
|
38 |
| -class JSON_API StreamWriterBuilder { |
39 |
| -public: |
40 |
| - virtual ~StreamWriterBuilder(); |
41 |
| - /// Do not delete stream (i.e. not owned), but keep a reference. |
42 |
| - virtual StreamWriter* newStreamWriter(std::ostream* stream) const; |
43 |
| -}; |
| 58 | + /// Because this Builder is non-virtual, we can safely add |
| 59 | + /// methods without a major version bump. |
| 60 | + /// \see http://stackoverflow.com/questions/14875052/pure-virtual-functions-and-binary-compatibility |
| 61 | + class Builder { |
| 62 | + StreamWriterBuilder* own_; |
| 63 | + public: |
| 64 | + Builder(StreamWriterBuilderFactory const*); |
| 65 | + ~Builder(); // delete underlying StreamWriterBuilder |
44 | 66 |
|
45 |
| -class JSON_API StreamWriterBuilderFactory { |
46 |
| -public: |
47 |
| - virtual ~StreamWriterBuilderFactory(); |
48 |
| - virtual StreamWriterBuilder* newStreamWriterBuilder(); |
| 67 | + void setCommentStyle(CommentStyle cs); /// default: All |
| 68 | + |
| 69 | + /// Do not take ownership of sout, but maintain a reference. |
| 70 | + StreamWriter* newStreamWriter(std::ostream* sout); |
| 71 | + }; |
49 | 72 | };
|
50 | 73 |
|
51 | 74 | /// \brief Write into stringstream, then return string, for convenience.
|
|
0 commit comments