Merge pull request #25 from zaeleus/serde-0.9

Update to serde 0.9
This commit is contained in:
Magnus Hallin 2017-02-04 10:16:26 +01:00 committed by GitHub
commit c51930aae5
2 changed files with 54 additions and 45 deletions

View file

@ -23,7 +23,7 @@ expose-test-schema = []
[dependencies] [dependencies]
rustc-serialize = { version = "^0.3.19", optional = true } rustc-serialize = { version = "^0.3.19", optional = true }
iron = { version = "^0.4.0", optional = true } iron = { version = "^0.4.0", optional = true }
serde = { version = "^0.8.21", optional = true } serde = { version = "^0.9.1", optional = true }
[dev-dependencies] [dev-dependencies]
iron = "^0.4.0" iron = "^0.4.0"

View file

@ -1,5 +1,7 @@
use serde::{de, ser}; use serde::{de, ser};
use serde::ser::SerializeMap;
use std::collections::HashMap; use std::collections::HashMap;
use std::fmt;
use ::{GraphQLError, Value}; use ::{GraphQLError, Value};
use ast::InputValue; use ast::InputValue;
@ -8,26 +10,27 @@ use parser::{ParseError, Spanning, SourcePosition};
use validation::RuleError; use validation::RuleError;
impl ser::Serialize for ExecutionError { impl ser::Serialize for ExecutionError {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
let mut state = try!(serializer.serialize_map(Some(3))); let mut map = try!(serializer.serialize_map(Some(3)));
try!(serializer.serialize_map_key(&mut state, "message")); try!(map.serialize_key("message"));
try!(serializer.serialize_map_value(&mut state, self.message())); try!(map.serialize_value(self.message()));
try!(serializer.serialize_map_key(&mut state, "locations")); let locations = vec![self.location()];
try!(serializer.serialize_map_value(&mut state, vec![self.location()])); try!(map.serialize_key("locations"));
try!(map.serialize_value(&locations));
try!(serializer.serialize_map_key(&mut state, "path")); try!(map.serialize_key("path"));
try!(serializer.serialize_map_value(&mut state, self.path())); try!(map.serialize_value(self.path()));
serializer.serialize_map_end(state) map.end()
} }
} }
impl<'a> ser::Serialize for GraphQLError<'a> { impl<'a> ser::Serialize for GraphQLError<'a> {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
match *self { match *self {
@ -47,7 +50,7 @@ impl<'a> ser::Serialize for GraphQLError<'a> {
} }
impl de::Deserialize for InputValue { impl de::Deserialize for InputValue {
fn deserialize<D>(deserializer: &mut D) -> Result<InputValue, D::Error> fn deserialize<D>(deserializer: D) -> Result<InputValue, D::Error>
where D: de::Deserializer, where D: de::Deserializer,
{ {
struct InputValueVisitor; struct InputValueVisitor;
@ -55,50 +58,54 @@ impl de::Deserialize for InputValue {
impl de::Visitor for InputValueVisitor { impl de::Visitor for InputValueVisitor {
type Value = InputValue; type Value = InputValue;
fn visit_bool<E>(&mut self, value: bool) -> Result<InputValue, E> { fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
formatter.write_str("a valid input value")
}
fn visit_bool<E>(self, value: bool) -> Result<InputValue, E> {
Ok(InputValue::boolean(value)) Ok(InputValue::boolean(value))
} }
fn visit_i64<E>(&mut self, value: i64) -> Result<InputValue, E> { fn visit_i64<E>(self, value: i64) -> Result<InputValue, E> {
Ok(InputValue::int(value)) Ok(InputValue::int(value))
} }
fn visit_u64<E>(&mut self, value: u64) -> Result<InputValue, E> fn visit_u64<E>(self, value: u64) -> Result<InputValue, E>
where E: de::Error, where E: de::Error,
{ {
self.visit_f64(value as f64) self.visit_f64(value as f64)
} }
fn visit_f64<E>(&mut self, value: f64) -> Result<InputValue, E> { fn visit_f64<E>(self, value: f64) -> Result<InputValue, E> {
Ok(InputValue::float(value)) Ok(InputValue::float(value))
} }
fn visit_str<E>(&mut self, value: &str) -> Result<InputValue, E> fn visit_str<E>(self, value: &str) -> Result<InputValue, E>
where E: de::Error, where E: de::Error,
{ {
self.visit_string(value.into()) self.visit_string(value.into())
} }
fn visit_string<E>(&mut self, value: String) -> Result<InputValue, E> { fn visit_string<E>(self, value: String) -> Result<InputValue, E> {
Ok(InputValue::string(value)) Ok(InputValue::string(value))
} }
fn visit_none<E>(&mut self) -> Result<InputValue, E> { fn visit_none<E>(self) -> Result<InputValue, E> {
Ok(InputValue::null()) Ok(InputValue::null())
} }
fn visit_unit<E>(&mut self) -> Result<InputValue, E> { fn visit_unit<E>(self) -> Result<InputValue, E> {
Ok(InputValue::null()) Ok(InputValue::null())
} }
fn visit_seq<V>(&mut self, visitor: V) -> Result<InputValue, V::Error> fn visit_seq<V>(self, visitor: V) -> Result<InputValue, V::Error>
where V: de::SeqVisitor, where V: de::SeqVisitor,
{ {
let values = try!(de::impls::VecVisitor::new().visit_seq(visitor)); let values = try!(de::impls::VecVisitor::new().visit_seq(visitor));
Ok(InputValue::list(values)) Ok(InputValue::list(values))
} }
fn visit_map<V>(&mut self, visitor: V) -> Result<InputValue, V::Error> fn visit_map<V>(self, visitor: V) -> Result<InputValue, V::Error>
where V: de::MapVisitor, where V: de::MapVisitor,
{ {
let values = try!(de::impls::HashMapVisitor::<String, InputValue, _>::new() let values = try!(de::impls::HashMapVisitor::<String, InputValue, _>::new()
@ -112,7 +119,7 @@ impl de::Deserialize for InputValue {
} }
impl ser::Serialize for InputValue { impl ser::Serialize for InputValue {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
match *self { match *self {
@ -135,46 +142,48 @@ impl ser::Serialize for InputValue {
} }
impl ser::Serialize for RuleError { impl ser::Serialize for RuleError {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
let mut state = try!(serializer.serialize_map(Some(2))); let mut map = try!(serializer.serialize_map(Some(2)));
try!(serializer.serialize_map_key(&mut state, "message")); try!(map.serialize_key("message"));
try!(serializer.serialize_map_value(&mut state, self.message())); try!(map.serialize_value(self.message()));
try!(serializer.serialize_map_key(&mut state, "locations")); try!(map.serialize_key("locations"));
try!(serializer.serialize_map_value(&mut state, self.locations())); try!(map.serialize_value(self.locations()));
serializer.serialize_map_end(state) map.end()
} }
} }
impl ser::Serialize for SourcePosition { impl ser::Serialize for SourcePosition {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
let mut state = try!(serializer.serialize_map(Some(2))); let mut map = try!(serializer.serialize_map(Some(2)));
try!(serializer.serialize_map_key(&mut state, "line")); let line = self.line() + 1;
try!(serializer.serialize_map_value(&mut state, self.line() + 1)); try!(map.serialize_key("line"));
try!(map.serialize_value(&line));
try!(serializer.serialize_map_key(&mut state, "column")); let column = self.column() + 1;
try!(serializer.serialize_map_value(&mut state, self.column() + 1)); try!(map.serialize_key("column"));
try!(map.serialize_value(&column));
serializer.serialize_map_end(state) map.end()
} }
} }
impl<'a> ser::Serialize for Spanning<ParseError<'a>> { impl<'a> ser::Serialize for Spanning<ParseError<'a>> {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
let mut state = try!(serializer.serialize_map(Some(2))); let mut map = try!(serializer.serialize_map(Some(2)));
let message = format!("{}", self.item); let message = format!("{}", self.item);
try!(serializer.serialize_map_key(&mut state, "message")); try!(map.serialize_key("message"));
try!(serializer.serialize_map_value(&mut state, message)); try!(map.serialize_value(&message));
let mut location = HashMap::new(); let mut location = HashMap::new();
location.insert("line".to_owned(), self.start.line() + 1); location.insert("line".to_owned(), self.start.line() + 1);
@ -182,15 +191,15 @@ impl<'a> ser::Serialize for Spanning<ParseError<'a>> {
let locations = vec![location]; let locations = vec![location];
try!(serializer.serialize_map_key(&mut state, "locations")); try!(map.serialize_key("locations"));
try!(serializer.serialize_map_value(&mut state, locations)); try!(map.serialize_value(&locations));
serializer.serialize_map_end(state) map.end()
} }
} }
impl ser::Serialize for Value { impl ser::Serialize for Value {
fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: ser::Serializer, where S: ser::Serializer,
{ {
match *self { match *self {