Argo  1.0
A C++ library for handling JSON.
reader.hpp
Go to the documentation of this file.
1 #ifndef _json_reader_hpp_
2 #define _json_reader_hpp_
3 
4 /*
5  * Copyright (c) 2017 Andrew Haisley
6  *
7  * Permission is hereby granted, free of charge, to any person obtaining a copy
8  * of this software and associated documentation files (the "Software"), to deal
9  * in the Software without restriction, including without limitation the rights
10  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11  * copies of the Software, and to permit persons to whom the Software is
12  * furnished to do so, subject to the following conditions:
13  *
14  * The above copyright notice and this permission notice shall be included in all
15  * copies or substantial portions of the Software.
16  *
17  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23  * SOFTWARE.
24  */
25 
27 
28 #include <string>
29 
30 #include "common.hpp"
31 
32 namespace NAMESPACE
33 {
42  class reader
43  {
44  public:
45 
47  static const int block_size = 8192;
48 
55  reader(size_t max_message_length, bool block_read);
56 
63  virtual int next();
64 
66  virtual void put_back(int c);
67 
69  size_t get_byte_index() const;
70 
72  void reset_byte_index();
73 
74  protected:
75 
77  int read_next_char_from_block();
78 
80  static const int no_put_back = 1000;
81 
83  virtual int read_next_char() = 0;
84 
91  virtual bool read_next_block() = 0;
92 
95 
97  size_t m_byte_index;
98 
101 
104 
106  unsigned char m_block[block_size];
107 
110 
113  };
114 }
115 
116 #endif
size_t m_byte_index
Total number of characters read.
Definition: reader.hpp:97
A class to read JSON messages from various types of input stream.
Definition: reader.hpp:42
#define NAMESPACE
You can change the namespace of the whole library by changing this value.
Definition: common.hpp:29
int m_put_back
Character last put back. If equal to no_put_back then none was.
Definition: reader.hpp:94
Common defs needed everywhere and, as far as is possible, platform specific changes.
size_t m_max_message_length
Maximum length of a message.
Definition: reader.hpp:100
int m_block_index
If we&#39;re reading blocks, the index into the current block.
Definition: reader.hpp:112
int m_block_num_bytes
If we&#39;re reading blocks, the number of bytes in the current block.
Definition: reader.hpp:109
bool m_block_read
Whether to read in blocks or one byte at a time.
Definition: reader.hpp:103