Replace try! with ?

This commit is contained in:
Atul Bhosale 2018-01-23 01:08:48 +05:30 committed by theduke
parent 05c1011d83
commit ea3c425f04
14 changed files with 260 additions and 213 deletions

View file

@ -432,25 +432,25 @@ impl fmt::Display for InputValue {
InputValue::Enum(ref v) => write!(f, "{}", v),
InputValue::Variable(ref v) => write!(f, "${}", v),
InputValue::List(ref v) => {
try!(write!(f, "["));
write!(f, "[")?;
for (i, spanning) in v.iter().enumerate() {
try!(spanning.item.fmt(f));
spanning.item.fmt(f)?;
if i < v.len() - 1 {
try!(write!(f, ", "));
write!(f, ", ")?;
}
}
write!(f, "]")
}
InputValue::Object(ref o) => {
try!(write!(f, "{{"));
write!(f, "{{")?;
for (i, &(ref k, ref v)) in o.iter().enumerate() {
try!(write!(f, "{}: ", k.item));
try!(v.item.fmt(f));
write!(f, "{}: ", k.item)?;
v.item.fmt(f)?;
if i < o.len() - 1 {
try!(write!(f, ", "));
write!(f, ", ")?;
}
}

View file

@ -220,7 +220,8 @@ impl<'a, T: GraphQLType, C> IntoResolvable<'a, T, C> for FieldResult<(&'a T::Con
}
impl<'a, T: GraphQLType, C> IntoResolvable<'a, Option<T>, C>
for FieldResult<Option<(&'a T::Context, T)>> {
for FieldResult<Option<(&'a T::Context, T)>>
{
fn into(self, _: &'a C) -> FieldResult<Option<(&'a T::Context, Option<T>)>> {
self.map(|o| o.map(|(ctx, v)| (ctx, Some(v))))
}

View file

@ -68,15 +68,19 @@ pub struct NamedPublic {
#[derive(GraphQLInputObject, Debug)]
#[graphql(_internal)]
struct FieldDescription {
#[graphql(description = "The first field")] field_one: String,
#[graphql(description = "The second field")] field_two: String,
#[graphql(description = "The first field")]
field_one: String,
#[graphql(description = "The second field")]
field_two: String,
}
#[derive(GraphQLInputObject, Debug)]
#[graphql(_internal)]
struct FieldWithDefaults {
#[graphql(default = "123")] field_one: i32,
#[graphql(default = "456", description = "The second field")] field_two: i32,
#[graphql(default = "123")]
field_one: i32,
#[graphql(default = "456", description = "The second field")]
field_two: i32,
}
graphql_object!(Root: () |&self| {

View file

@ -56,7 +56,8 @@ struct ExampleInputObject {
#[derive(GraphQLInputObject, Debug)]
#[graphql(_internal)]
struct InputWithDefaults {
#[graphql(default = "123")] a: i32,
#[graphql(default = "123")]
a: i32,
}
graphql_object!(TestType: () |&self| {

View file

@ -19,7 +19,8 @@ use executor::ExecutionError;
#[derive(Deserialize, Clone, Serialize, PartialEq, Debug)]
pub struct GraphQLRequest {
query: String,
#[serde(rename = "operationName")] operation_name: Option<String>,
#[serde(rename = "operationName")]
operation_name: Option<String>,
variables: Option<InputValue>,
}
@ -101,22 +102,22 @@ impl<'a> ser::Serialize for GraphQLResponse<'a> {
{
match self.0 {
Ok((ref res, ref err)) => {
let mut map = try!(serializer.serialize_map(None));
let mut map = serializer.serialize_map(None)?;
try!(map.serialize_key("data"));
try!(map.serialize_value(res));
map.serialize_key("data")?;
map.serialize_value(res)?;
if !err.is_empty() {
try!(map.serialize_key("errors"));
try!(map.serialize_value(err));
map.serialize_key("errors")?;
map.serialize_value(err)?;
}
map.end()
}
Err(ref err) => {
let mut map = try!(serializer.serialize_map(Some(1)));
try!(map.serialize_key("errors"));
try!(map.serialize_value(err));
let mut map = serializer.serialize_map(Some(1))?;
map.serialize_key("errors")?;
map.serialize_value(err)?;
map.end()
}
}

View file

@ -15,21 +15,21 @@ impl ser::Serialize for ExecutionError {
where
S: ser::Serializer,
{
let mut map = try!(serializer.serialize_map(Some(4)));
let mut map = serializer.serialize_map(Some(4))?;
try!(map.serialize_key("message"));
try!(map.serialize_value(self.error().message()));
map.serialize_key("message")?;
map.serialize_value(self.error().message())?;
let locations = vec![self.location()];
try!(map.serialize_key("locations"));
try!(map.serialize_value(&locations));
map.serialize_key("locations")?;
map.serialize_value(&locations)?;
try!(map.serialize_key("path"));
try!(map.serialize_value(self.path()));
map.serialize_key("path")?;
map.serialize_value(self.path())?;
if !self.error().data().is_null() {
try!(map.serialize_key("data"));
try!(map.serialize_value(self.error().data()));
map.serialize_key("data")?;
map.serialize_value(self.error().data())?;
}
map.end()
@ -123,7 +123,7 @@ impl<'de> de::Deserialize<'de> for InputValue {
{
let mut values = Vec::new();
while let Some(el) = try!(visitor.next_element()) {
while let Some(el) = visitor.next_element()? {
values.push(el);
}
@ -136,7 +136,7 @@ impl<'de> de::Deserialize<'de> for InputValue {
{
let mut values: IndexMap<String, InputValue> = IndexMap::new();
while let Some((key, value)) = try!(visitor.next_entry()) {
while let Some((key, value)) = visitor.next_entry()? {
values.insert(key, value);
}
@ -176,13 +176,13 @@ impl ser::Serialize for RuleError {
where
S: ser::Serializer,
{
let mut map = try!(serializer.serialize_map(Some(2)));
let mut map = serializer.serialize_map(Some(2))?;
try!(map.serialize_key("message"));
try!(map.serialize_value(self.message()));
map.serialize_key("message")?;
map.serialize_value(self.message())?;
try!(map.serialize_key("locations"));
try!(map.serialize_value(self.locations()));
map.serialize_key("locations")?;
map.serialize_value(self.locations())?;
map.end()
}
@ -193,15 +193,15 @@ impl ser::Serialize for SourcePosition {
where
S: ser::Serializer,
{
let mut map = try!(serializer.serialize_map(Some(2)));
let mut map = serializer.serialize_map(Some(2))?;
let line = self.line() + 1;
try!(map.serialize_key("line"));
try!(map.serialize_value(&line));
map.serialize_key("line")?;
map.serialize_value(&line)?;
let column = self.column() + 1;
try!(map.serialize_key("column"));
try!(map.serialize_value(&column));
map.serialize_key("column")?;
map.serialize_value(&column)?;
map.end()
}
@ -212,11 +212,11 @@ impl<'a> ser::Serialize for Spanning<ParseError<'a>> {
where
S: ser::Serializer,
{
let mut map = try!(serializer.serialize_map(Some(2)));
let mut map = serializer.serialize_map(Some(2))?;
let message = format!("{}", self.item);
try!(map.serialize_key("message"));
try!(map.serialize_value(&message));
map.serialize_key("message")?;
map.serialize_value(&message)?;
let mut location = IndexMap::new();
location.insert("line".to_owned(), self.start.line() + 1);
@ -224,8 +224,8 @@ impl<'a> ser::Serialize for Spanning<ParseError<'a>> {
let locations = vec![location];
try!(map.serialize_key("locations"));
try!(map.serialize_value(&locations));
map.serialize_key("locations")?;
map.serialize_value(&locations)?;
map.end()
}

View file

@ -184,7 +184,7 @@ where
QueryT: GraphQLType<Context = CtxT>,
MutationT: GraphQLType<Context = CtxT>,
{
let document = try!(parse_document_source(document_source));
let document = parse_document_source(document_source)?;
{
let errors = validate_input_values(variables, &document, &root_node.schema);

View file

@ -11,7 +11,7 @@ use parser::value::parse_value_literal;
#[doc(hidden)]
pub fn parse_document_source(s: &str) -> UnlocatedParseResult<Document> {
let mut lexer = Lexer::new(s);
let mut parser = try!(Parser::new(&mut lexer).map_err(|s| s.map(ParseError::LexerError)));
let mut parser = Parser::new(&mut lexer).map_err(|s| s.map(ParseError::LexerError))?;
parse_document(&mut parser)
}
@ -19,7 +19,7 @@ fn parse_document<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Docum
let mut defs = Vec::new();
loop {
defs.push(try!(parse_definition(parser)));
defs.push(parse_definition(parser)?);
if parser.peek().item == Token::EndOfFile {
return Ok(defs);
@ -29,19 +29,17 @@ fn parse_document<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Docum
fn parse_definition<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Definition<'a>> {
match parser.peek().item {
Token::CurlyOpen | Token::Name("query") | Token::Name("mutation") => Ok(
Definition::Operation(try!(parse_operation_definition(parser))),
),
Token::Name("fragment") => Ok(Definition::Fragment(try!(parse_fragment_definition(
parser
)))),
Token::CurlyOpen | Token::Name("query") | Token::Name("mutation") => {
Ok(Definition::Operation(parse_operation_definition(parser)?))
}
Token::Name("fragment") => Ok(Definition::Fragment(parse_fragment_definition(parser)?)),
_ => Err(parser.next()?.map(ParseError::UnexpectedToken)),
}
}
fn parse_operation_definition<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Operation<'a>> {
if parser.peek().item == Token::CurlyOpen {
let selection_set = try!(parse_selection_set(parser));
let selection_set = parse_selection_set(parser)?;
Ok(Spanning::start_end(
&selection_set.start,
@ -56,14 +54,14 @@ fn parse_operation_definition<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Op
))
} else {
let start_pos = parser.peek().start.clone();
let operation_type = try!(parse_operation_type(parser));
let operation_type = parse_operation_type(parser)?;
let name = match parser.peek().item {
Token::Name(_) => Some(try!(parser.expect_name())),
Token::Name(_) => Some(parser.expect_name()?),
_ => None,
};
let variable_definitions = try!(parse_variable_definitions(parser));
let directives = try!(parse_directives(parser));
let selection_set = try!(parse_selection_set(parser));
let variable_definitions = parse_variable_definitions(parser)?;
let directives = parse_directives(parser)?;
let selection_set = parse_selection_set(parser)?;
Ok(Spanning::start_end(
&start_pos,
@ -82,7 +80,7 @@ fn parse_operation_definition<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Op
fn parse_fragment_definition<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Fragment<'a>> {
let Spanning {
start: start_pos, ..
} = try!(parser.expect(&Token::Name("fragment")));
} = parser.expect(&Token::Name("fragment"))?;
let name = match parser.expect_name() {
Ok(n) => if n.item == "on" {
return Err(n.map(|_| ParseError::UnexpectedToken(Token::Name("on"))));
@ -92,10 +90,10 @@ fn parse_fragment_definition<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Fra
Err(e) => return Err(e),
};
try!(parser.expect(&Token::Name("on")));
let type_cond = try!(parser.expect_name());
let directives = try!(parse_directives(parser));
let selection_set = try!(parse_selection_set(parser));
parser.expect(&Token::Name("on"))?;
let type_cond = parser.expect_name()?;
let directives = parse_directives(parser)?;
let selection_set = parse_selection_set(parser)?;
Ok(Spanning::start_end(
&start_pos,
@ -113,7 +111,7 @@ fn parse_optional_selection_set<'a>(
parser: &mut Parser<'a>,
) -> OptionParseResult<'a, Vec<Selection<'a>>> {
if parser.peek().item == Token::CurlyOpen {
Ok(Some(try!(parse_selection_set(parser))))
Ok(Some(parse_selection_set(parser)?))
} else {
Ok(None)
}
@ -134,14 +132,14 @@ fn parse_fragment<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Selec
let Spanning {
start: ref start_pos,
..
} = try!(parser.expect(&Token::Ellipsis));
} = parser.expect(&Token::Ellipsis)?;
match parser.peek().item {
Token::Name("on") => {
parser.next()?;
let name = try!(parser.expect_name());
let directives = try!(parse_directives(parser));
let selection_set = try!(parse_selection_set(parser));
let name = parser.expect_name()?;
let directives = parse_directives(parser)?;
let selection_set = parse_selection_set(parser)?;
Ok(Selection::InlineFragment(Spanning::start_end(
&start_pos.clone(),
@ -154,7 +152,7 @@ fn parse_fragment<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Selec
)))
}
Token::CurlyOpen => {
let selection_set = try!(parse_selection_set(parser));
let selection_set = parse_selection_set(parser)?;
Ok(Selection::InlineFragment(Spanning::start_end(
&start_pos.clone(),
@ -167,8 +165,8 @@ fn parse_fragment<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Selec
)))
}
Token::Name(_) => {
let frag_name = try!(parser.expect_name());
let directives = try!(parse_directives(parser));
let frag_name = parser.expect_name()?;
let directives = parse_directives(parser)?;
Ok(Selection::FragmentSpread(Spanning::start_end(
&start_pos.clone(),
@ -183,8 +181,8 @@ fn parse_fragment<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Selec
)))
}
Token::At => {
let directives = try!(parse_directives(parser));
let selection_set = try!(parse_selection_set(parser));
let directives = parse_directives(parser)?;
let selection_set = parse_selection_set(parser)?;
Ok(Selection::InlineFragment(Spanning::start_end(
&start_pos.clone(),
@ -201,17 +199,17 @@ fn parse_fragment<'a>(parser: &mut Parser<'a>) -> UnlocatedParseResult<'a, Selec
}
fn parse_field<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Field<'a>> {
let mut alias = Some(try!(parser.expect_name()));
let mut alias = Some(parser.expect_name()?);
let name = if try!(parser.skip(&Token::Colon)).is_some() {
try!(parser.expect_name())
let name = if parser.skip(&Token::Colon)?.is_some() {
parser.expect_name()?
} else {
alias.take().unwrap()
};
let arguments = try!(parse_arguments(parser));
let directives = try!(parse_directives(parser));
let selection_set = try!(parse_optional_selection_set(parser));
let arguments = parse_arguments(parser)?;
let directives = parse_directives(parser)?;
let selection_set = parse_optional_selection_set(parser)?;
Ok(Spanning::start_end(
&alias.as_ref().unwrap_or(&name).start.clone(),
@ -237,13 +235,11 @@ fn parse_arguments<'a>(parser: &mut Parser<'a>) -> OptionParseResult<'a, Argumen
Ok(None)
} else {
Ok(Some(
try!(parser.delimited_nonempty_list(
&Token::ParenOpen,
parse_argument,
&Token::ParenClose
)).map(|args| Arguments {
items: args.into_iter().map(|s| s.item).collect(),
}),
parser
.delimited_nonempty_list(&Token::ParenOpen, parse_argument, &Token::ParenClose)?
.map(|args| Arguments {
items: args.into_iter().map(|s| s.item).collect(),
}),
))
}
}
@ -251,9 +247,9 @@ fn parse_arguments<'a>(parser: &mut Parser<'a>) -> OptionParseResult<'a, Argumen
fn parse_argument<'a>(
parser: &mut Parser<'a>,
) -> ParseResult<'a, (Spanning<&'a str>, Spanning<InputValue>)> {
let name = try!(parser.expect_name());
try!(parser.expect(&Token::Colon));
let value = try!(parse_value_literal(parser, false));
let name = parser.expect_name()?;
parser.expect(&Token::Colon)?;
let value = parse_value_literal(parser, false)?;
Ok(Spanning::start_end(
&name.start.clone(),
@ -277,13 +273,15 @@ fn parse_variable_definitions<'a>(
Ok(None)
} else {
Ok(Some(
try!(parser.delimited_nonempty_list(
&Token::ParenOpen,
parse_variable_definition,
&Token::ParenClose
)).map(|defs| VariableDefinitions {
items: defs.into_iter().map(|s| s.item).collect(),
}),
parser
.delimited_nonempty_list(
&Token::ParenOpen,
parse_variable_definition,
&Token::ParenClose,
)?
.map(|defs| VariableDefinitions {
items: defs.into_iter().map(|s| s.item).collect(),
}),
))
}
}
@ -293,13 +291,13 @@ fn parse_variable_definition<'a>(
) -> ParseResult<'a, (Spanning<&'a str>, VariableDefinition<'a>)> {
let Spanning {
start: start_pos, ..
} = try!(parser.expect(&Token::Dollar));
let var_name = try!(parser.expect_name());
try!(parser.expect(&Token::Colon));
let var_type = try!(parse_type(parser));
} = parser.expect(&Token::Dollar)?;
let var_name = parser.expect_name()?;
parser.expect(&Token::Colon)?;
let var_type = parse_type(parser)?;
let default_value = if try!(parser.skip(&Token::Equals)).is_some() {
Some(try!(parse_value_literal(parser, true)))
let default_value = if parser.skip(&Token::Equals)?.is_some() {
Some(parse_value_literal(parser, true)?)
} else {
None
};
@ -328,7 +326,7 @@ fn parse_directives<'a>(
} else {
let mut items = Vec::new();
while parser.peek().item == Token::At {
items.push(try!(parse_directive(parser)));
items.push(parse_directive(parser)?);
}
Ok(Spanning::spanning(items))
@ -338,9 +336,9 @@ fn parse_directives<'a>(
fn parse_directive<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Directive<'a>> {
let Spanning {
start: start_pos, ..
} = try!(parser.expect(&Token::At));
let name = try!(parser.expect_name());
let arguments = try!(parse_arguments(parser));
} = parser.expect(&Token::At)?;
let name = parser.expect_name()?;
let arguments = parse_arguments(parser)?;
Ok(Spanning::start_end(
&start_pos,
@ -355,20 +353,20 @@ fn parse_directive<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Directive<'a>
pub fn parse_type<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, Type<'a>> {
let parsed_type = if let Some(Spanning {
start: start_pos, ..
}) = try!(parser.skip(&Token::BracketOpen))
}) = parser.skip(&Token::BracketOpen)?
{
let inner_type = try!(parse_type(parser));
let Spanning { end: end_pos, .. } = try!(parser.expect(&Token::BracketClose));
let inner_type = parse_type(parser)?;
let Spanning { end: end_pos, .. } = parser.expect(&Token::BracketClose)?;
Spanning::start_end(&start_pos, &end_pos, Type::List(Box::new(inner_type.item)))
} else {
try!(parser.expect_name()).map(|s| Type::Named(Cow::Borrowed(s)))
parser.expect_name()?.map(|s| Type::Named(Cow::Borrowed(s)))
};
Ok(match *parser.peek() {
Spanning {
item: Token::ExclamationMark,
..
} => try!(wrap_non_null(parser, parsed_type)),
} => wrap_non_null(parser, parsed_type)?,
_ => parsed_type,
})
}
@ -377,7 +375,7 @@ fn wrap_non_null<'a>(
parser: &mut Parser<'a>,
inner: Spanning<Type<'a>>,
) -> ParseResult<'a, Type<'a>> {
let Spanning { end: end_pos, .. } = try!(parser.expect(&Token::ExclamationMark));
let Spanning { end: end_pos, .. } = parser.expect(&Token::ExclamationMark)?;
let wrapped = match inner.item {
Type::Named(name) => Type::NonNullNamed(name),

View file

@ -160,10 +160,10 @@ impl<'a> Lexer<'a> {
let start_pos = self.position.clone();
for _ in 0..3 {
let (_, ch) = try!(self.next_char().ok_or(Spanning::zero_width(
let (_, ch) = self.next_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnexpectedEndOfFile
)));
LexerError::UnexpectedEndOfFile,
))?;
if ch != '.' {
return Err(Spanning::zero_width(
&start_pos,
@ -181,10 +181,10 @@ impl<'a> Lexer<'a> {
fn scan_name(&mut self) -> LexerResult<'a> {
let start_pos = self.position.clone();
let (start_idx, start_ch) = try!(self.next_char().ok_or(Spanning::zero_width(
let (start_idx, start_ch) = self.next_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnexpectedEndOfFile
)));
LexerError::UnexpectedEndOfFile,
))?;
assert!(is_name_start(start_ch));
let mut end_idx = start_idx;
@ -207,10 +207,10 @@ impl<'a> Lexer<'a> {
fn scan_string(&mut self) -> LexerResult<'a> {
let start_pos = self.position.clone();
let (_, start_ch) = try!(self.next_char().ok_or(Spanning::zero_width(
let (_, start_ch) = self.next_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnexpectedEndOfFile
)));
LexerError::UnexpectedEndOfFile,
))?;
assert!(start_ch == '"');
let mut acc = String::new();
@ -262,7 +262,7 @@ impl<'a> Lexer<'a> {
Some((_, 'u')) => {
let start_pos = self.position.clone();
self.next_char();
acc.push(try!(self.scan_escaped_unicode(&start_pos)));
acc.push(self.scan_escaped_unicode(&start_pos)?);
}
Some((_, ch)) => {
let mut s = String::from("\\");
@ -314,18 +314,18 @@ impl<'a> Lexer<'a> {
&mut self,
start_pos: &SourcePosition,
) -> Result<char, Spanning<LexerError>> {
let (start_idx, _) = try!(self.peek_char().ok_or(Spanning::zero_width(
let (start_idx, _) = self.peek_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnterminatedString
)));
LexerError::UnterminatedString,
))?;
let mut end_idx = start_idx;
let mut len = 0;
for _ in 0..4 {
let (idx, ch) = try!(self.next_char().ok_or(Spanning::zero_width(
let (idx, ch) = self.next_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnterminatedString
)));
LexerError::UnterminatedString,
))?;
if !ch.is_alphanumeric() {
break;
@ -344,12 +344,12 @@ impl<'a> Lexer<'a> {
));
}
let code_point = try!(
u32::from_str_radix(escape, 16).map_err(|_| Spanning::zero_width(
let code_point = u32::from_str_radix(escape, 16).map_err(|_| {
Spanning::zero_width(
start_pos,
LexerError::UnknownEscapeSequence("\\u".to_owned() + escape),
))
);
)
})?;
char::from_u32(code_point).ok_or_else(|| {
Spanning::zero_width(
@ -361,14 +361,14 @@ impl<'a> Lexer<'a> {
fn scan_number(&mut self) -> LexerResult<'a> {
let start_pos = self.position.clone();
let int_part = try!(self.scan_integer_part());
let int_part = self.scan_integer_part()?;
let mut frac_part = None;
let mut exp_part = None;
if let Some((_, '.')) = self.peek_char() {
self.next_char();
frac_part = Some(try!(self.scan_digits()));
frac_part = Some(self.scan_digits()?);
}
if let Some((_, ch)) = self.peek_char() {
@ -385,7 +385,7 @@ impl<'a> Lexer<'a> {
self.next_char();
}
}
exp_part = Some(if is_negative { -1 } else { 1 } * try!(self.scan_digits()));
exp_part = Some(if is_negative { -1 } else { 1 } * self.scan_digits()?);
}
}
@ -416,10 +416,10 @@ impl<'a> Lexer<'a> {
fn scan_integer_part(&mut self) -> Result<i32, Spanning<LexerError>> {
let is_negative = {
let (_, init_ch) = try!(self.peek_char().ok_or(Spanning::zero_width(
let (_, init_ch) = self.peek_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnexpectedEndOfFile
)));
LexerError::UnexpectedEndOfFile,
))?;
if init_ch == '-' {
self.next_char();
@ -429,10 +429,10 @@ impl<'a> Lexer<'a> {
}
};
let (_, ch) = try!(self.peek_char().ok_or(Spanning::zero_width(
let (_, ch) = self.peek_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnexpectedEndOfFile
)));
LexerError::UnexpectedEndOfFile,
))?;
if ch == '0' {
self.next_char();
@ -445,16 +445,16 @@ impl<'a> Lexer<'a> {
_ => Ok(0),
}
} else {
Ok(try!(self.scan_digits()) * if is_negative { -1 } else { 1 })
Ok(self.scan_digits()? * if is_negative { -1 } else { 1 })
}
}
fn scan_digits(&mut self) -> Result<i32, Spanning<LexerError>> {
let start_pos = self.position.clone();
let (start_idx, ch) = try!(self.peek_char().ok_or(Spanning::zero_width(
let (start_idx, ch) = self.peek_char().ok_or(Spanning::zero_width(
&self.position,
LexerError::UnexpectedEndOfFile
)));
LexerError::UnexpectedEndOfFile,
))?;
let mut end_idx = start_idx;
if !ch.is_digit(10) {

View file

@ -103,15 +103,15 @@ impl<'a> Parser<'a> {
{
let Spanning {
start: start_pos, ..
} = try!(self.expect(opening));
} = self.expect(opening)?;
let mut items = Vec::new();
loop {
if let Some(Spanning { end: end_pos, .. }) = try!(self.skip(closing)) {
if let Some(Spanning { end: end_pos, .. }) = self.skip(closing)? {
return Ok(Spanning::start_end(&start_pos, &end_pos, items));
}
items.push(try!(parser(self)));
items.push(parser(self)?);
}
}
@ -128,13 +128,13 @@ impl<'a> Parser<'a> {
{
let Spanning {
start: start_pos, ..
} = try!(self.expect(opening));
} = self.expect(opening)?;
let mut items = Vec::new();
loop {
items.push(try!(parser(self)));
items.push(parser(self)?);
if let Some(Spanning { end: end_pos, .. }) = try!(self.skip(closing)) {
if let Some(Spanning { end: end_pos, .. }) = self.skip(closing)? {
return Ok(Spanning::start_end(&start_pos, &end_pos, items));
}
}
@ -153,13 +153,13 @@ impl<'a> Parser<'a> {
{
let Spanning {
start: start_pos, ..
} = try!(self.expect(opening));
} = self.expect(opening)?;
let mut items = Vec::new();
loop {
items.push(try!(parser(self)));
items.push(parser(self)?);
if let Some(Spanning { end: end_pos, .. }) = try!(self.skip(closing)) {
if let Some(Spanning { end: end_pos, .. }) = self.skip(closing)? {
return Ok(Spanning::start_end(&start_pos, &end_pos, items));
}
}

View file

@ -63,33 +63,37 @@ pub fn parse_value_literal<'a>(
}
fn parse_list_literal<'a>(parser: &mut Parser<'a>, is_const: bool) -> ParseResult<'a, InputValue> {
Ok(try!(parser.delimited_list(
&Token::BracketOpen,
|p| parse_value_literal(p, is_const),
&Token::BracketClose
)).map(InputValue::parsed_list))
Ok(parser
.delimited_list(
&Token::BracketOpen,
|p| parse_value_literal(p, is_const),
&Token::BracketClose,
)?
.map(InputValue::parsed_list))
}
fn parse_object_literal<'a>(
parser: &mut Parser<'a>,
is_const: bool,
) -> ParseResult<'a, InputValue> {
Ok(try!(parser.delimited_list(
&Token::CurlyOpen,
|p| parse_object_field(p, is_const),
&Token::CurlyClose
)).map(|items| InputValue::parsed_object(items.into_iter().map(|s| s.item).collect())))
Ok(parser
.delimited_list(
&Token::CurlyOpen,
|p| parse_object_field(p, is_const),
&Token::CurlyClose,
)?
.map(|items| InputValue::parsed_object(items.into_iter().map(|s| s.item).collect())))
}
fn parse_object_field<'a>(
parser: &mut Parser<'a>,
is_const: bool,
) -> ParseResult<'a, (Spanning<String>, Spanning<InputValue>)> {
let key = try!(parser.expect_name());
let key = parser.expect_name()?;
try!(parser.expect(&Token::Colon));
parser.expect(&Token::Colon)?;
let value = try!(parse_value_literal(parser, is_const));
let value = parse_value_literal(parser, is_const)?;
Ok(Spanning::start_end(
&key.start.clone(),
@ -101,12 +105,12 @@ fn parse_object_field<'a>(
fn parse_variable_literal<'a>(parser: &mut Parser<'a>) -> ParseResult<'a, InputValue> {
let Spanning {
start: start_pos, ..
} = try!(parser.expect(&Token::Dollar));
} = parser.expect(&Token::Dollar)?;
let Spanning {
item: name,
end: end_pos,
..
} = try!(parser.expect_name());
} = parser.expect_name()?;
Ok(Spanning::start_end(
&start_pos,

View file

@ -8,62 +8,85 @@ use types::base::TypeKind;
/// Scalar type metadata
pub struct ScalarMeta<'a> {
#[doc(hidden)] pub name: Cow<'a, str>,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub try_parse_fn: Box<Fn(&InputValue) -> bool + Send + Sync>,
#[doc(hidden)]
pub name: Cow<'a, str>,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub try_parse_fn: Box<Fn(&InputValue) -> bool + Send + Sync>,
}
/// List type metadata
#[derive(Debug)]
pub struct ListMeta<'a> {
#[doc(hidden)] pub of_type: Type<'a>,
#[doc(hidden)]
pub of_type: Type<'a>,
}
/// Nullable type metadata
#[derive(Debug)]
pub struct NullableMeta<'a> {
#[doc(hidden)] pub of_type: Type<'a>,
#[doc(hidden)]
pub of_type: Type<'a>,
}
/// Object type metadata
#[derive(Debug)]
pub struct ObjectMeta<'a> {
#[doc(hidden)] pub name: Cow<'a, str>,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub fields: Vec<Field<'a>>,
#[doc(hidden)] pub interface_names: Vec<String>,
#[doc(hidden)]
pub name: Cow<'a, str>,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub fields: Vec<Field<'a>>,
#[doc(hidden)]
pub interface_names: Vec<String>,
}
/// Enum type metadata
pub struct EnumMeta<'a> {
#[doc(hidden)] pub name: Cow<'a, str>,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub values: Vec<EnumValue>,
#[doc(hidden)] pub try_parse_fn: Box<Fn(&InputValue) -> bool + Send + Sync>,
#[doc(hidden)]
pub name: Cow<'a, str>,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub values: Vec<EnumValue>,
#[doc(hidden)]
pub try_parse_fn: Box<Fn(&InputValue) -> bool + Send + Sync>,
}
/// Interface type metadata
#[derive(Debug)]
pub struct InterfaceMeta<'a> {
#[doc(hidden)] pub name: Cow<'a, str>,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub fields: Vec<Field<'a>>,
#[doc(hidden)]
pub name: Cow<'a, str>,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub fields: Vec<Field<'a>>,
}
/// Union type metadata
#[derive(Debug)]
pub struct UnionMeta<'a> {
#[doc(hidden)] pub name: Cow<'a, str>,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub of_type_names: Vec<String>,
#[doc(hidden)]
pub name: Cow<'a, str>,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub of_type_names: Vec<String>,
}
/// Input object metadata
pub struct InputObjectMeta<'a> {
#[doc(hidden)] pub name: Cow<'a, str>,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub input_fields: Vec<Argument<'a>>,
#[doc(hidden)] pub try_parse_fn: Box<Fn(&InputValue) -> bool + Send + Sync>,
#[doc(hidden)]
pub name: Cow<'a, str>,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub input_fields: Vec<Argument<'a>>,
#[doc(hidden)]
pub try_parse_fn: Box<Fn(&InputValue) -> bool + Send + Sync>,
}
/// A placeholder for not-yet-registered types
@ -72,7 +95,8 @@ pub struct InputObjectMeta<'a> {
/// is inserted into a registry to indicate existence.
#[derive(Debug)]
pub struct PlaceholderMeta<'a> {
#[doc(hidden)] pub of_type: Type<'a>,
#[doc(hidden)]
pub of_type: Type<'a>,
}
/// Generic type metadata
@ -92,20 +116,29 @@ pub enum MetaType<'a> {
/// Metadata for a field
#[derive(Debug, Clone)]
pub struct Field<'a> {
#[doc(hidden)] pub name: String,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub arguments: Option<Vec<Argument<'a>>>,
#[doc(hidden)] pub field_type: Type<'a>,
#[doc(hidden)] pub deprecation_reason: Option<String>,
#[doc(hidden)]
pub name: String,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub arguments: Option<Vec<Argument<'a>>>,
#[doc(hidden)]
pub field_type: Type<'a>,
#[doc(hidden)]
pub deprecation_reason: Option<String>,
}
/// Metadata for an argument to a field
#[derive(Debug, Clone)]
pub struct Argument<'a> {
#[doc(hidden)] pub name: String,
#[doc(hidden)] pub description: Option<String>,
#[doc(hidden)] pub arg_type: Type<'a>,
#[doc(hidden)] pub default_value: Option<InputValue>,
#[doc(hidden)]
pub name: String,
#[doc(hidden)]
pub description: Option<String>,
#[doc(hidden)]
pub arg_type: Type<'a>,
#[doc(hidden)]
pub default_value: Option<InputValue>,
}
/// Metadata for a single value in an enum

View file

@ -13,11 +13,16 @@ use schema::meta::{Argument, InterfaceMeta, MetaType, ObjectMeta, PlaceholderMet
/// This brings the mutation and query types together, and provides the
/// predefined metadata fields.
pub struct RootNode<'a, QueryT: GraphQLType, MutationT: GraphQLType> {
#[doc(hidden)] pub query_type: QueryT,
#[doc(hidden)] pub query_info: QueryT::TypeInfo,
#[doc(hidden)] pub mutation_type: MutationT,
#[doc(hidden)] pub mutation_info: MutationT::TypeInfo,
#[doc(hidden)] pub schema: SchemaType<'a>,
#[doc(hidden)]
pub query_type: QueryT,
#[doc(hidden)]
pub query_info: QueryT::TypeInfo,
#[doc(hidden)]
pub mutation_type: MutationT,
#[doc(hidden)]
pub mutation_info: MutationT::TypeInfo,
#[doc(hidden)]
pub schema: SchemaType<'a>,
}
/// Metadata for a schema

View file

@ -30,7 +30,7 @@ impl Name {
}
}
}
return input.len() > 0;
return !input.is_empty();
}
}