Skip to content

Commit c51930a

Browse files
authored
Merge pull request #25 from zaeleus/serde-0.9
Update to serde 0.9
2 parents 555962c + a834115 commit c51930a

File tree

2 files changed

+54
-45
lines changed

2 files changed

+54
-45
lines changed

Cargo.toml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@ expose-test-schema = []
2323
[dependencies]
2424
rustc-serialize = { version = "^0.3.19", optional = true }
2525
iron = { version = "^0.4.0", optional = true }
26-
serde = { version = "^0.8.21", optional = true }
26+
serde = { version = "^0.9.1", optional = true }
2727

2828
[dev-dependencies]
2929
iron = "^0.4.0"

src/integrations/serde.rs

Lines changed: 53 additions & 44 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
use serde::{de, ser};
2+
use serde::ser::SerializeMap;
23
use std::collections::HashMap;
4+
use std::fmt;
35

46
use ::{GraphQLError, Value};
57
use ast::InputValue;
@@ -8,26 +10,27 @@ use parser::{ParseError, Spanning, SourcePosition};
810
use validation::RuleError;
911

1012
impl ser::Serialize for ExecutionError {
11-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
13+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1214
where S: ser::Serializer,
1315
{
14-
let mut state = try!(serializer.serialize_map(Some(3)));
16+
let mut map = try!(serializer.serialize_map(Some(3)));
1517

16-
try!(serializer.serialize_map_key(&mut state, "message"));
17-
try!(serializer.serialize_map_value(&mut state, self.message()));
18+
try!(map.serialize_key("message"));
19+
try!(map.serialize_value(self.message()));
1820

19-
try!(serializer.serialize_map_key(&mut state, "locations"));
20-
try!(serializer.serialize_map_value(&mut state, vec![self.location()]));
21+
let locations = vec![self.location()];
22+
try!(map.serialize_key("locations"));
23+
try!(map.serialize_value(&locations));
2124

22-
try!(serializer.serialize_map_key(&mut state, "path"));
23-
try!(serializer.serialize_map_value(&mut state, self.path()));
25+
try!(map.serialize_key("path"));
26+
try!(map.serialize_value(self.path()));
2427

25-
serializer.serialize_map_end(state)
28+
map.end()
2629
}
2730
}
2831

2932
impl<'a> ser::Serialize for GraphQLError<'a> {
30-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
33+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
3134
where S: ser::Serializer,
3235
{
3336
match *self {
@@ -47,58 +50,62 @@ impl<'a> ser::Serialize for GraphQLError<'a> {
4750
}
4851

4952
impl de::Deserialize for InputValue {
50-
fn deserialize<D>(deserializer: &mut D) -> Result<InputValue, D::Error>
53+
fn deserialize<D>(deserializer: D) -> Result<InputValue, D::Error>
5154
where D: de::Deserializer,
5255
{
5356
struct InputValueVisitor;
5457

5558
impl de::Visitor for InputValueVisitor {
5659
type Value = InputValue;
5760

58-
fn visit_bool<E>(&mut self, value: bool) -> Result<InputValue, E> {
61+
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
62+
formatter.write_str("a valid input value")
63+
}
64+
65+
fn visit_bool<E>(self, value: bool) -> Result<InputValue, E> {
5966
Ok(InputValue::boolean(value))
6067
}
6168

62-
fn visit_i64<E>(&mut self, value: i64) -> Result<InputValue, E> {
69+
fn visit_i64<E>(self, value: i64) -> Result<InputValue, E> {
6370
Ok(InputValue::int(value))
6471
}
6572

66-
fn visit_u64<E>(&mut self, value: u64) -> Result<InputValue, E>
73+
fn visit_u64<E>(self, value: u64) -> Result<InputValue, E>
6774
where E: de::Error,
6875
{
6976
self.visit_f64(value as f64)
7077
}
7178

72-
fn visit_f64<E>(&mut self, value: f64) -> Result<InputValue, E> {
79+
fn visit_f64<E>(self, value: f64) -> Result<InputValue, E> {
7380
Ok(InputValue::float(value))
7481
}
7582

76-
fn visit_str<E>(&mut self, value: &str) -> Result<InputValue, E>
83+
fn visit_str<E>(self, value: &str) -> Result<InputValue, E>
7784
where E: de::Error,
7885
{
7986
self.visit_string(value.into())
8087
}
8188

82-
fn visit_string<E>(&mut self, value: String) -> Result<InputValue, E> {
89+
fn visit_string<E>(self, value: String) -> Result<InputValue, E> {
8390
Ok(InputValue::string(value))
8491
}
8592

86-
fn visit_none<E>(&mut self) -> Result<InputValue, E> {
93+
fn visit_none<E>(self) -> Result<InputValue, E> {
8794
Ok(InputValue::null())
8895
}
8996

90-
fn visit_unit<E>(&mut self) -> Result<InputValue, E> {
97+
fn visit_unit<E>(self) -> Result<InputValue, E> {
9198
Ok(InputValue::null())
9299
}
93100

94-
fn visit_seq<V>(&mut self, visitor: V) -> Result<InputValue, V::Error>
101+
fn visit_seq<V>(self, visitor: V) -> Result<InputValue, V::Error>
95102
where V: de::SeqVisitor,
96103
{
97104
let values = try!(de::impls::VecVisitor::new().visit_seq(visitor));
98105
Ok(InputValue::list(values))
99106
}
100107

101-
fn visit_map<V>(&mut self, visitor: V) -> Result<InputValue, V::Error>
108+
fn visit_map<V>(self, visitor: V) -> Result<InputValue, V::Error>
102109
where V: de::MapVisitor,
103110
{
104111
let values = try!(de::impls::HashMapVisitor::<String, InputValue, _>::new()
@@ -112,7 +119,7 @@ impl de::Deserialize for InputValue {
112119
}
113120

114121
impl ser::Serialize for InputValue {
115-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
122+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
116123
where S: ser::Serializer,
117124
{
118125
match *self {
@@ -135,62 +142,64 @@ impl ser::Serialize for InputValue {
135142
}
136143

137144
impl ser::Serialize for RuleError {
138-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
145+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
139146
where S: ser::Serializer,
140147
{
141-
let mut state = try!(serializer.serialize_map(Some(2)));
148+
let mut map = try!(serializer.serialize_map(Some(2)));
142149

143-
try!(serializer.serialize_map_key(&mut state, "message"));
144-
try!(serializer.serialize_map_value(&mut state, self.message()));
150+
try!(map.serialize_key("message"));
151+
try!(map.serialize_value(self.message()));
145152

146-
try!(serializer.serialize_map_key(&mut state, "locations"));
147-
try!(serializer.serialize_map_value(&mut state, self.locations()));
153+
try!(map.serialize_key("locations"));
154+
try!(map.serialize_value(self.locations()));
148155

149-
serializer.serialize_map_end(state)
156+
map.end()
150157
}
151158
}
152159

153160
impl ser::Serialize for SourcePosition {
154-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
161+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
155162
where S: ser::Serializer,
156163
{
157-
let mut state = try!(serializer.serialize_map(Some(2)));
164+
let mut map = try!(serializer.serialize_map(Some(2)));
158165

159-
try!(serializer.serialize_map_key(&mut state, "line"));
160-
try!(serializer.serialize_map_value(&mut state, self.line() + 1));
166+
let line = self.line() + 1;
167+
try!(map.serialize_key("line"));
168+
try!(map.serialize_value(&line));
161169

162-
try!(serializer.serialize_map_key(&mut state, "column"));
163-
try!(serializer.serialize_map_value(&mut state, self.column() + 1));
170+
let column = self.column() + 1;
171+
try!(map.serialize_key("column"));
172+
try!(map.serialize_value(&column));
164173

165-
serializer.serialize_map_end(state)
174+
map.end()
166175
}
167176
}
168177

169178
impl<'a> ser::Serialize for Spanning<ParseError<'a>> {
170-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
179+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
171180
where S: ser::Serializer,
172181
{
173-
let mut state = try!(serializer.serialize_map(Some(2)));
182+
let mut map = try!(serializer.serialize_map(Some(2)));
174183

175184
let message = format!("{}", self.item);
176-
try!(serializer.serialize_map_key(&mut state, "message"));
177-
try!(serializer.serialize_map_value(&mut state, message));
185+
try!(map.serialize_key("message"));
186+
try!(map.serialize_value(&message));
178187

179188
let mut location = HashMap::new();
180189
location.insert("line".to_owned(), self.start.line() + 1);
181190
location.insert("column".to_owned(), self.start.column() + 1);
182191

183192
let locations = vec![location];
184193

185-
try!(serializer.serialize_map_key(&mut state, "locations"));
186-
try!(serializer.serialize_map_value(&mut state, locations));
194+
try!(map.serialize_key("locations"));
195+
try!(map.serialize_value(&locations));
187196

188-
serializer.serialize_map_end(state)
197+
map.end()
189198
}
190199
}
191200

192201
impl ser::Serialize for Value {
193-
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error>
202+
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
194203
where S: ser::Serializer,
195204
{
196205
match *self {

0 commit comments

Comments
 (0)