lint-missing-doc.rs 3.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
// Copyright 2013 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.

// When denying at the crate level, be sure to not get random warnings from the
// injected intrinsics by the compiler.
A
Aaron Turon 已提交
13
#![deny(missing_docs)]
14
#![allow(dead_code)]
15

16
//! Some garbage docs for the crate here
17
#![doc="More garbage"]
18

19 20 21
type Typedef = String;
pub type PubTypedef = String; //~ ERROR: missing documentation

22
struct Foo {
23 24
    a: isize,
    b: isize,
25 26 27
}

pub struct PubFoo { //~ ERROR: missing documentation
28 29
    pub a: isize,      //~ ERROR: missing documentation
    b: isize,
30 31
}

A
Aaron Turon 已提交
32
#[allow(missing_docs)]
33
pub struct PubFoo2 {
34 35
    pub a: isize,
    pub c: isize,
36 37
}

38 39 40
mod module_no_dox {}
pub mod pub_module_no_dox {} //~ ERROR: missing documentation

41 42 43 44
/// dox
pub fn foo() {}
pub fn foo2() {} //~ ERROR: missing documentation
fn foo3() {}
A
Aaron Turon 已提交
45
#[allow(missing_docs)] pub fn foo4() {}
46 47

/// dox
48 49
pub trait A {
    /// dox
50
    fn foo();
51 52
    /// dox
    fn foo_with_impl() {}
53
}
A
Aaron Turon 已提交
54
#[allow(missing_docs)]
55 56 57 58 59 60 61 62
trait B {
    fn foo();
    fn foo_with_impl() {}
}
pub trait C { //~ ERROR: missing documentation
    fn foo(); //~ ERROR: missing documentation
    fn foo_with_impl() {} //~ ERROR: missing documentation
}
A
Aaron Turon 已提交
63
#[allow(missing_docs)] pub trait D {}
64 65

impl Foo {
66 67 68 69 70
    pub fn foo() {}
    fn bar() {}
}

impl PubFoo {
71 72 73 74
    pub fn foo() {} //~ ERROR: missing documentation
    /// dox
    pub fn foo1() {}
    fn foo2() {}
A
Aaron Turon 已提交
75
    #[allow(missing_docs)] pub fn foo3() {}
76 77
}

A
Aaron Turon 已提交
78
#[allow(missing_docs)]
79
trait F {
80
    fn a();
81 82 83 84 85
    fn b(&self);
}

// should need to redefine documentation for implementations of traits
impl F for Foo {
86
    fn a() {}
87 88 89
    fn b(&self) {}
}

A
Aaron Turon 已提交
90
// It sure is nice if doc(hidden) implies allow(missing_docs), and that it
91 92 93 94 95 96 97 98 99
// applies recursively
#[doc(hidden)]
mod a {
    pub fn baz() {}
    pub mod b {
        pub fn baz() {}
    }
}

S
Steven Fackler 已提交
100 101
enum Baz {
    BazA {
102 103
        a: isize,
        b: isize
S
Steven Fackler 已提交
104 105 106 107 108 109
    },
    BarB
}

pub enum PubBaz { //~ ERROR: missing documentation
    PubBazA { //~ ERROR: missing documentation
110
        a: isize, //~ ERROR: missing documentation
S
Steven Fackler 已提交
111 112 113 114 115 116 117 118
    },
}

/// dox
pub enum PubBaz2 {
    /// dox
    PubBaz2A {
        /// dox
119
        a: isize,
S
Steven Fackler 已提交
120 121 122
    },
}

A
Aaron Turon 已提交
123
#[allow(missing_docs)]
S
Steven Fackler 已提交
124 125
pub enum PubBaz3 {
    PubBaz3A {
126
        b: isize
S
Steven Fackler 已提交
127 128 129
    },
}

130 131 132
#[doc(hidden)]
pub fn baz() {}

133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148
mod internal_impl {
    /// dox
    pub fn documented() {}
    pub fn undocumented1() {} //~ ERROR: missing documentation
    pub fn undocumented2() {} //~ ERROR: missing documentation
    fn undocumented3() {}
    /// dox
    pub mod globbed {
        /// dox
        pub fn also_documented() {}
        pub fn also_undocumented1() {} //~ ERROR: missing documentation
        fn also_undocumented2() {}
    }
}
/// dox
pub mod public_interface {
149 150
    pub use internal_impl::documented as foo;
    pub use internal_impl::undocumented1 as bar;
151 152 153 154
    pub use internal_impl::{documented, undocumented2};
    pub use internal_impl::globbed::*;
}

155
fn main() {}