Skip to content

Commit 9c84982

Browse files
committed
Change default lint output format.
Since lint check attributes are the preferred way of selectively enabling/disabling lint checks, the output format of a failed default check has been changed to reflect that. When lint checks are being explicitly set by a command-line flag or an attribute, the behavior is unchanged, so that the user can quickly pinpoint the source. Closes #6580
1 parent 3a70df1 commit 9c84982

File tree

2 files changed

+41
-5
lines changed

2 files changed

+41
-5
lines changed

src/librustc/middle/lint.rs

Lines changed: 9 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
1+
// Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
22
// file at the top-level directory of this distribution and at
33
// http://rust-lang.org/COPYRIGHT.
44
//
@@ -372,12 +372,16 @@ impl Context {
372372

373373
let mut note = None;
374374
let msg = match src {
375-
Default | CommandLine => {
376-
format!("{} [-{} {}{}]", msg, match level {
375+
Default => {
376+
format!("{}, \\#[{}({})] on by default", msg,
377+
level_to_str(level), self.lint_to_str(lint))
378+
},
379+
CommandLine => {
380+
format!("{} [-{} {}]", msg,
381+
match level {
377382
warn => 'W', deny => 'D', forbid => 'F',
378383
allow => fail2!()
379-
}, self.lint_to_str(lint).replace("_", "-"),
380-
if src == Default { " (default)" } else { "" })
384+
}, self.lint_to_str(lint).replace("_", "-"))
381385
},
382386
Node(src) => {
383387
note = Some(src);
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
// compile-flags:-F experimental -D unstable
12+
13+
#[deprecated]
14+
fn foo() -> uint {
15+
20
16+
}
17+
18+
#[experimental]
19+
fn bar() -> uint {
20+
40
21+
}
22+
23+
#[unstable]
24+
fn baz() -> uint {
25+
30
26+
}
27+
28+
fn main() {
29+
let _x = foo(); //~ WARNING #[warn(deprecated)] on by default
30+
let _y = bar(); //~ ERROR [-F experimental]
31+
let _z = baz(); //~ ERROR [-D unstable]
32+
}

0 commit comments

Comments
 (0)