mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-24 15:54:15 +00:00
Use an empty Vec instead of Option<Vec>
This commit is contained in:
parent
e90c5fbbc5
commit
688ed0a019
@ -204,7 +204,6 @@ crate fn get_index_search_type<'tcx>(
|
||||
|
||||
inputs.retain(|a| a.ty.name.is_some());
|
||||
output.retain(|a| a.ty.name.is_some());
|
||||
let output = if output.is_empty() { None } else { Some(output) };
|
||||
|
||||
Some(IndexItemFunctionType { inputs, output })
|
||||
}
|
||||
|
@ -117,7 +117,7 @@ crate struct RenderType {
|
||||
#[derive(Debug)]
|
||||
crate struct IndexItemFunctionType {
|
||||
inputs: Vec<TypeWithKind>,
|
||||
output: Option<Vec<TypeWithKind>>,
|
||||
output: Vec<TypeWithKind>,
|
||||
}
|
||||
|
||||
impl Serialize for IndexItemFunctionType {
|
||||
@ -126,21 +126,16 @@ impl Serialize for IndexItemFunctionType {
|
||||
S: Serializer,
|
||||
{
|
||||
// If we couldn't figure out a type, just write `null`.
|
||||
let mut iter = self.inputs.iter();
|
||||
if match self.output {
|
||||
Some(ref output) => iter.chain(output.iter()).any(|i| i.ty.name.is_none()),
|
||||
None => iter.any(|i| i.ty.name.is_none()),
|
||||
} {
|
||||
let has_missing = self.inputs.iter().chain(self.output.iter()).any(|i| i.ty.name.is_none());
|
||||
if has_missing {
|
||||
serializer.serialize_none()
|
||||
} else {
|
||||
let mut seq = serializer.serialize_seq(None)?;
|
||||
seq.serialize_element(&self.inputs)?;
|
||||
if let Some(output) = &self.output {
|
||||
if output.len() > 1 {
|
||||
seq.serialize_element(&output)?;
|
||||
} else {
|
||||
seq.serialize_element(&output[0])?;
|
||||
}
|
||||
match self.output.as_slice() {
|
||||
[] => {}
|
||||
[one] => seq.serialize_element(one)?,
|
||||
all => seq.serialize_element(all)?,
|
||||
}
|
||||
seq.end()
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user