]> git.cworth.org Git - apitrace/blob - thirdparty/qjson/serializer.h
fd301b21c052a4df8c8eaa4b7d97a8d3b3097aad
[apitrace] / thirdparty / qjson / serializer.h
1 /* This file is part of qjson
2   *
3   * Copyright (C) 2009 Till Adam <adam@kde.org>
4   *
5   * This library is free software; you can redistribute it and/or
6   * modify it under the terms of the GNU Library General Public
7   * License as published by the Free Software Foundation; either
8   * version 2 of the License, or (at your option) any later version.
9   *
10   * This library is distributed in the hope that it will be useful,
11   * but WITHOUT ANY WARRANTY; without even the implied warranty of
12   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13   * Library General Public License for more details.
14   *
15   * You should have received a copy of the GNU Library General Public License
16   * along with this library; see the file COPYING.LIB.  If not, write to
17   * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18   * Boston, MA 02110-1301, USA.
19   */
20
21 #ifndef QJSON_SERIALIZER_H
22 #define QJSON_SERIALIZER_H
23
24 #include "qjson_export.h"
25
26 class QIODevice;
27 class QString;
28 class QVariant;
29
30 namespace QJson {
31   /**
32   * @brief Main class used to convert QVariant objects to JSON data.
33   *
34   * QVariant objects are converted to a string containing the JSON data.
35   * If QVariant object is empty or not valid a <em>null</em> json object is returned.
36   */
37   class QJSON_EXPORT Serializer {
38   public:
39     Serializer();
40     ~Serializer();
41
42      /**
43       * This method generates a textual JSON representation and outputs it to the
44       * passed in I/O Device.
45       * @param variant The JSON document in its in-memory representation as generated by the
46       * parser.
47       * @param out Input output device
48       * @param ok if a conversion error occurs, *ok is set to false; otherwise *ok is set to true
49       */
50     void serialize( const QVariant& variant, QIODevice* out, bool* ok = 0 );
51
52     /**
53       * This is a method provided for convenience. It turns the passed in in-memory
54       * representation of the JSON document into a textual one, which is returned.
55       * If the returned string is empty, the document was empty. If it was null, there
56       * was a parsing error.
57       *
58       * @param variant The JSON document in its in-memory representation as generated by the
59       * parser.
60       */
61
62     QByteArray serialize( const QVariant& variant );
63
64   private:
65     Q_DISABLE_COPY(Serializer)
66     class SerializerPrivate;
67     SerializerPrivate* const d;
68   };
69 }
70
71 #endif // QJSON_SERIALIZER_H