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.
13 14 15 16
#![feature(struct_variant)]
#![feature(globs)]
#![deny(missing_doc)]
#![allow(dead_code)]
17

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

21 22
struct Foo {
    a: int,
23
    b: int,
24 25 26
}

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

#[allow(missing_doc)]
pub struct PubFoo2 {
33 34
    pub a: int,
    pub c: int,
35 36
}

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

40 41 42 43 44 45 46
/// dox
pub fn foo() {}
pub fn foo2() {} //~ ERROR: missing documentation
fn foo3() {}
#[allow(missing_doc)] pub fn foo4() {}

/// dox
47 48
pub trait A {
    /// dox
49
    fn foo();
50 51
    /// dox
    fn foo_with_impl() {}
52
}
53
#[allow(missing_doc)]
54 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
}
#[allow(missing_doc)] pub trait D {}
63 64

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

impl PubFoo {
70 71 72 73 74 75 76 77 78
    pub fn foo() {} //~ ERROR: missing documentation
    /// dox
    pub fn foo1() {}
    fn foo2() {}
    #[allow(missing_doc)] pub fn foo3() {}
}

#[allow(missing_doc)]
trait F {
79
    fn a();
80 81 82 83 84
    fn b(&self);
}

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

89 90 91 92 93 94 95 96 97 98
// It sure is nice if doc(hidden) implies allow(missing_doc), and that it
// applies recursively
#[doc(hidden)]
mod a {
    pub fn baz() {}
    pub mod b {
        pub fn baz() {}
    }
}

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

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

/// dox
pub enum PubBaz2 {
    /// dox
    PubBaz2A {
        /// dox
119 120
        pub a: int,
        b: int
S
Steven Fackler 已提交
121 122 123 124 125 126
    },
}

#[allow(missing_doc)]
pub enum PubBaz3 {
    PubBaz3A {
127 128
        pub a: int,
        b: int
S
Steven Fackler 已提交
129 130 131
    },
}

132 133 134
#[doc(hidden)]
pub fn baz() {}

135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
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 {
151 152
    pub use internal_impl::documented as foo;
    pub use internal_impl::undocumented1 as bar;
153 154 155 156
    pub use internal_impl::{documented, undocumented2};
    pub use internal_impl::globbed::*;
}

157
fn main() {}