mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-02 15:32:06 +00:00
rustdoc: Fix missing type parameters on impls
This commit is contained in:
parent
e88defe718
commit
538de73f5b
@ -1534,13 +1534,6 @@ impl Type {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trait_name(&self) -> Option<String> {
|
|
||||||
match *self {
|
|
||||||
ResolvedPath { ref path, .. } => Some(path.last_name()),
|
|
||||||
_ => None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn is_generic(&self) -> bool {
|
pub fn is_generic(&self) -> bool {
|
||||||
match *self {
|
match *self {
|
||||||
ResolvedPath { is_generic, .. } => is_generic,
|
ResolvedPath { is_generic, .. } => is_generic,
|
||||||
|
@ -587,7 +587,13 @@ fn fmt_impl(i: &clean::Impl, f: &mut fmt::Formatter, link_trait: bool) -> fmt::R
|
|||||||
if link_trait {
|
if link_trait {
|
||||||
write!(f, "{}", *ty)?;
|
write!(f, "{}", *ty)?;
|
||||||
} else {
|
} else {
|
||||||
write!(f, "{}", ty.trait_name().unwrap())?;
|
match *ty {
|
||||||
|
clean::ResolvedPath{ typarams: None, ref path, is_generic: false, .. } => {
|
||||||
|
let last = path.segments.last().unwrap();
|
||||||
|
write!(f, "{}{}", last.name, last.params)?;
|
||||||
|
}
|
||||||
|
_ => unreachable!(),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
write!(f, " for ")?;
|
write!(f, " for ")?;
|
||||||
}
|
}
|
||||||
|
23
src/test/rustdoc/issue-33592.rs
Normal file
23
src/test/rustdoc/issue-33592.rs
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
#![crate_name = "foo"]
|
||||||
|
|
||||||
|
pub trait Foo<T> {}
|
||||||
|
|
||||||
|
pub struct Bar;
|
||||||
|
|
||||||
|
pub struct Baz;
|
||||||
|
|
||||||
|
// @has foo/trait.Foo.html '//code' 'impl Foo<i32> for Bar'
|
||||||
|
impl Foo<i32> for Bar {}
|
||||||
|
|
||||||
|
// @has foo/trait.Foo.html '//code' 'impl<T> Foo<T> for Baz'
|
||||||
|
impl<T> Foo<T> for Baz {}
|
Loading…
Reference in New Issue
Block a user