jsonformatter.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2011 Tommi Maekitalo
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * As a special exception, you may use this file as part of a free
10  * software library without restriction. Specifically, if other files
11  * instantiate templates or use macros or inline functions from this
12  * file, or you compile this file and link it with other files to
13  * produce an executable, this file does not by itself cause the
14  * resulting executable to be covered by the GNU General Public
15  * License. This exception does not however invalidate any other
16  * reasons why the executable file might be covered by the GNU Library
17  * General Public License.
18  *
19  * This library is distributed in the hope that it will be useful,
20  * but WITHOUT ANY WARRANTY; without even the implied warranty of
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
22  * Lesser General Public License for more details.
23  *
24  * You should have received a copy of the GNU Lesser General Public
25  * License along with this library; if not, write to the Free Software
26  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
27  */
28 
29 #ifndef CXXTOOLS_JSONFORMATTER_H
30 #define CXXTOOLS_JSONFORMATTER_H
31 
32 #include <cxxtools/formatter.h>
33 #include <cxxtools/textstream.h>
34 
35 namespace cxxtools
36 {
37  class JsonFormatter : public Formatter
38  {
39  public:
41  : _ts(0),
42  _level(1),
43  _lastLevel(0),
44  _beautify(false),
45  _plainkey(false)
46  {
47  }
48 
49  explicit JsonFormatter(std::basic_ostream<cxxtools::Char>& ts)
50  : _ts(0),
51  _level(1),
52  _lastLevel(0),
53  _beautify(false),
54  _plainkey(false)
55  {
56  begin(ts);
57  }
58 
59  void begin(std::basic_ostream<cxxtools::Char>& ts);
60 
61  void finish();
62 
63  virtual void addValueString(const std::string& name, const std::string& type,
64  const String& value);
65 
66  virtual void addValueStdString(const std::string& name, const std::string& type,
67  const std::string& value);
68 
69  virtual void addValueBool(const std::string& name, const std::string& type,
70  bool value);
71 
72  virtual void addValueInt(const std::string& name, const std::string& type,
73  int_type value);
74 
75  virtual void addValueUnsigned(const std::string& name, const std::string& type,
76  unsigned_type value);
77 
78  virtual void addValueFloat(const std::string& name, const std::string& type,
79  long double value);
80 
81  virtual void addNull(const std::string& name, const std::string& type);
82 
83  virtual void beginArray(const std::string& name, const std::string& type);
84 
85  virtual void finishArray();
86 
87  virtual void beginObject(const std::string& name, const std::string& type);
88 
89  virtual void beginMember(const std::string& name);
90 
91  virtual void finishMember();
92 
93  virtual void finishObject();
94 
95  bool beautify() const { return _beautify; }
96 
97  void beautify(bool sw) { _beautify = sw; }
98 
99  bool plainkey() const { return _plainkey; }
100 
101  void plainkey(bool sw) { _plainkey = sw; }
102 
103  void beginValue(const std::string& name);
104 
105  void finishValue();
106 
107  private:
108  void indent();
109  void stringOut(const std::string& str);
110  void stringOut(const cxxtools::String& str);
111 
112  std::basic_ostream<cxxtools::Char>* _ts;
113  unsigned _level;
114  unsigned _lastLevel;
115  bool _beautify;
116  bool _plainkey;
117  };
118 
119 }
120 
121 #endif // CXXTOOLS_JSONFORMATTER_H
122