-
Notifications
You must be signed in to change notification settings - Fork 18
/
main.cpp
144 lines (123 loc) · 2.75 KB
/
main.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
/*
A sample using json_dto
*/
#include <iostream>
#include <string>
#include <ctime>
#include <algorithm>
#include <json_dto/pub.hpp>
#include <json_dto/validators.hpp>
void
check_all_7bit(
const std::string & text )
{
auto it =
std::find_if(
std::begin( text ),
std::end( text ),
[]( char c ){ return c & 0x80; } );
if( std::end( text ) != it )
{
throw std::runtime_error{
"non 7bit char at pos " +
std::to_string( std::distance( std::begin( text ), it ) ) };
}
}
struct message_t
{
message_t() {}
message_t(
std::string from,
std::int64_t when,
std::string text )
: m_from{ std::move( from ) }
, m_when{ when }
, m_text{ std::move( text ) }
{}
// Who sent a message.
std::string m_from;
// When the message was sent (unixtime).
std::int64_t m_when;
// Message text. Must be 7bit ascii.
std::string m_text;
// Log level.
// By default is constructed with null value.
json_dto::nullable_t< std::string > m_log_level{};
template< typename Json_Io >
void json_io( Json_Io & io )
{
io & json_dto::mandatory( "from", m_from )
& json_dto::mandatory(
"when",
m_when,
json_dto::min_max_constraint( 1000000000LL , 3000000000LL ) )
& json_dto::mandatory( "text", m_text, check_all_7bit )
& json_dto::optional(
"log_level",
m_log_level,
"info",
json_dto::one_of_constraint( {
std::string{ "trace" },
std::string{ "info" },
std::string{ "error" } } ) );
}
};
std::string json_data{
R"JSON({
"from" : "json_dto",
"when" : 1474884330,
"text" : "Hello world!",
"log_level" : "trace"
})JSON" };
int
main( int , char *[] )
{
try
{
try
{
auto msg = json_dto::from_json< message_t >( json_data );
const auto t = static_cast< std::time_t >( msg.m_when );
std::cout
<< "Deserialized from JSON:\n"
<< "\tfrom: " << msg.m_from << "\n"
<< "\twhen: " << std::ctime( &t )
<< "\ttext: " << msg.m_text << "\n"
<< "\tlog_level: " << *msg.m_log_level << std::endl;
// Make data invalid:
json_data[ json_data.find( *msg.m_log_level ) ] = 'T';
// This must throw:
(void) json_dto::from_json< message_t >( json_data );
}
catch( const std::exception & ex )
{
std::cerr << "Error: " << ex.what() << std::endl;
}
try
{
const message_t msg{
"json_dto",
std::time( nullptr ),
"Hello once again!" };
std::cout
<< "\nSerialized to JSON:\n"
<< json_dto::to_json( msg ) << std::endl;
// This must throw:
(void) json_dto::to_json(
message_t{
"json_dto",
0,
"Hello once again!" } );
}
catch( const std::exception & ex )
{
std::cerr << "Error: " << ex.what() << std::endl;
}
}
catch( const std::exception & ex )
{
std::cerr << "Error: " << ex.what() << "." << std::endl;
return 1;
}
return 0;
}