Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rollup of 16 pull requests #52735

Merged
merged 59 commits into from
Jul 26, 2018
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
38abca8
Point at internal span in format string
Jul 23, 2018
87f0c1f
Suggest to take and ignore args while closure args count mismatching
csmoe Jul 23, 2018
4230659
Point at incorrect named arg in format string
Jul 23, 2018
338d545
Don't match on region kinds when reporting NLL errors
matthewjasper Jul 22, 2018
6bcf877
Point only at invalid positional arguments
estebank Jul 23, 2018
c55a698
Only point at inside of string literals if they're actually string li…
estebank Jul 23, 2018
bde2be0
Add test for raw string
estebank Jul 23, 2018
22d0ab0
Pass multiple linker arguments rather than concatenate with commas; -…
alecmocatta Jul 23, 2018
5363911
Add tests for #34784
wesleywiser Jul 20, 2018
296a179
break --subsystem=x into 2 args; closer to former presumably known-go…
alecmocatta Jul 24, 2018
63ed6a1
Add test for #33264
wesleywiser Jul 24, 2018
bbbbf2d
Add run-pass test for #44005
wesleywiser Jul 20, 2018
8c5ef0a
Add compile-fail test for #42060
wesleywiser Jul 20, 2018
3290774
Add compile-fail test for #43196
wesleywiser Jul 20, 2018
715005c
Update compile-fail tests to be ui tests
wesleywiser Jul 20, 2018
27c0d56
Mark the suggestion applicable
csmoe Jul 23, 2018
a71deb2
Fix ui test
csmoe Jul 24, 2018
9808f7c
update the stdsimd submodule
japaric Jul 24, 2018
f487e39
Add documentation for `Parser::arg_places`
estebank Jul 24, 2018
f9e3762
Reword missing formatting arguments label
estebank Jul 24, 2018
75d2226
Impl Executor for Box<E: Executor>
tinaun Jul 24, 2018
4d8aa59
Use suggestions for `printf` format
estebank Jul 24, 2018
9492176
Suggest in separate line
csmoe Jul 25, 2018
e8bc064
Add regression test for issue #18804
yodaldevoid Jul 23, 2018
a20262c
Properly set the linkage type on non-local statics
yodaldevoid Jul 22, 2018
0bcbe91
Deduplicate linkage checking code for statics
yodaldevoid Jul 23, 2018
e58e7b0
Disable regression test for issue #18804 on Emscripten and Asmjs
yodaldevoid Jul 24, 2018
40c0339
Fix test
csmoe Jul 25, 2018
d5256b7
Update comment and do suggest
csmoe Jul 25, 2018
1d79588
Update ui test
csmoe Jul 25, 2018
3298b9f
Fix unittest
estebank Jul 25, 2018
7bd94e0
Rename method and remove commented out code
estebank Jul 25, 2018
9a893cc
Add span label for format str missing specifier
estebank Jul 25, 2018
580f437
ARM: expose `rclass` and `dsp` target features
paoloteti Jul 25, 2018
f653bf4
Improve readability in a few sorts
ljedrz Jul 25, 2018
ef5fba0
Hide some lints which are not quite right the way they are reported t…
oli-obk Jul 25, 2018
eacfd72
Clarify what a task is
MajorBreakfast Jul 22, 2018
be5b668
Place the ignore comments in the correct file for test issue-18804
yodaldevoid Jul 25, 2018
abb704e
State default capacity for BufReader/BufWriter
fintelia Jul 25, 2018
bce8a91
std::ops::Try impl for std::task::Poll
cramertj Jul 26, 2018
f069a57
rustc: Register crates under their real names
alexcrichton Jul 26, 2018
051eddd
sparc ABI issue - structure returning from function is returned
psumbera Jul 26, 2018
cc2bd71
Add a test for sparc64 ABI issue
nagisa Jul 26, 2018
e29f15b
Rollup merge of #52558 - wesleywiser:ice_melting, r=estebank
Mark-Simulacrum Jul 26, 2018
0127704
Rollup merge of #52610 - MajorBreakfast:task-terminology, r=cramertj
Mark-Simulacrum Jul 26, 2018
2aeb765
Rollup merge of #52617 - matthewjasper:remove-unused-code, r=nikomats…
Mark-Simulacrum Jul 26, 2018
c7555ce
Rollup merge of #52635 - yodaldevoid:issue_18804, r=oli-obk
Mark-Simulacrum Jul 26, 2018
662fb06
Rollup merge of #52647 - csmoe:closure_arg_ignore, r=estebank
Mark-Simulacrum Jul 26, 2018
2aec4e8
Rollup merge of #52649 - estebank:fmt-span, r=oli-obk
Mark-Simulacrum Jul 26, 2018
9f91195
Rollup merge of #52654 - alecmocatta:master, r=alexcrichton
Mark-Simulacrum Jul 26, 2018
007177c
Rollup merge of #52667 - japaric:stdsimd-up, r=alexcrichton
Mark-Simulacrum Jul 26, 2018
7c09bab
Rollup merge of #52674 - tinaun:patch-2, r=cramertj
Mark-Simulacrum Jul 26, 2018
37835be
Rollup merge of #52690 - paoloteti:rclass-dsp, r=alexcrichton
Mark-Simulacrum Jul 26, 2018
55fa4c7
Rollup merge of #52692 - ljedrz:sort_improvements, r=petrochenkov
Mark-Simulacrum Jul 26, 2018
cc7a826
Rollup merge of #52695 - oli-obk:const_err_panic, r=petrochenkov
Mark-Simulacrum Jul 26, 2018
091a10e
Rollup merge of #52718 - fintelia:patch-2, r=cramertj
Mark-Simulacrum Jul 26, 2018
858adfe
Rollup merge of #52721 - cramertj:try-poll, r=aturon
Mark-Simulacrum Jul 26, 2018
d1e549c
Rollup merge of #52723 - alexcrichton:fix-extern-rename-ice, r=estebank
Mark-Simulacrum Jul 26, 2018
995d719
Rollup merge of #52734 - nagisa:sparcfix, r=oli-obk
Mark-Simulacrum Jul 26, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Point only at invalid positional arguments
  • Loading branch information
estebank committed Jul 23, 2018
commit 6bcf8777fe632fb2c506e31d12fbfe20712ecfe6
138 changes: 76 additions & 62 deletions src/libsyntax_ext/format.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,18 +14,18 @@ use self::Position::*;
use fmt_macros as parse;

use syntax::ast;
use syntax::ext::base::*;
use syntax::ext::base;
use syntax::ext::base::*;
use syntax::ext::build::AstBuilder;
use syntax::feature_gate;
use syntax::parse::token;
use syntax::ptr::P;
use syntax::symbol::Symbol;
use syntax_pos::{Span, MultiSpan, DUMMY_SP};
use syntax::tokenstream;
use syntax_pos::{MultiSpan, Span, DUMMY_SP};

use std::collections::{HashMap, HashSet};
use std::collections::hash_map::Entry;
use std::collections::{HashMap, HashSet};

#[derive(PartialEq)]
enum ArgumentType {
Expand Down Expand Up @@ -111,9 +111,11 @@ struct Context<'a, 'b: 'a> {
/// still existed in this phase of processing.
/// Used only for `all_pieces_simple` tracking in `build_piece`.
curarg: usize,
/// Current piece being evaluated, used for error reporting.
curpiece: usize,
/// Keep track of invalid references to positional arguments
invalid_refs: Vec<usize>,
/// Keep track of invalid references to positional arguments.
invalid_refs: Vec<(usize, usize)>,
/// Spans of all the formatting arguments, in order.
arg_spans: Vec<Span>,
}

Expand Down Expand Up @@ -157,15 +159,20 @@ fn parse_args(ecx: &mut ExtCtxt,
i
}
_ if named => {
ecx.span_err(p.span,
"expected ident, positional arguments \
cannot follow named arguments");
ecx.span_err(
p.span,
"expected ident, positional arguments cannot follow named arguments",
);
return None;
}
_ => {
ecx.span_err(p.span,
&format!("expected ident for named argument, found `{}`",
p.this_token_to_string()));
ecx.span_err(
p.span,
&format!(
"expected ident for named argument, found `{}`",
p.this_token_to_string()
),
);
return None;
}
};
Expand Down Expand Up @@ -267,34 +274,47 @@ impl<'a, 'b> Context<'a, 'b> {
/// errors for the case where all arguments are positional and for when
/// there are named arguments or numbered positional arguments in the
/// format string.
fn report_invalid_references(&self, numbered_position_args: bool, arg_places: &[(usize, usize)]) {
fn report_invalid_references(&self, numbered_position_args: bool) {
let mut e;
let sps = arg_places.iter()
.map(|&(start, end)| self.fmtsp.from_inner_byte_pos(start, end))
.collect::<Vec<_>>();
let sp = MultiSpan::from_spans(sps);
let mut refs: Vec<_> = self.invalid_refs
let sp = MultiSpan::from_spans(self.arg_spans.clone());
let mut refs: Vec<_> = self
.invalid_refs
.iter()
.map(|r| r.to_string())
.map(|(r, pos)| (r.to_string(), self.arg_spans.get(*pos)))
.collect();

if self.names.is_empty() && !numbered_position_args {
e = self.ecx.mut_span_err(sp,
&format!("{} positional argument{} in format string, but {}",
e = self.ecx.mut_span_err(
sp,
&format!(
"{} positional argument{} in format string, but {}",
self.pieces.len(),
if self.pieces.len() > 1 { "s" } else { "" },
self.describe_num_args()));
self.describe_num_args()
),
);
} else {
let arg_list = match refs.len() {
let (arg_list, sp) = match refs.len() {
1 => {
let reg = refs.pop().unwrap();
format!("argument {}", reg)
},
let (reg, pos) = refs.pop().unwrap();
(
format!("argument {}", reg),
MultiSpan::from_span(*pos.unwrap_or(&self.fmtsp)),
)
}
_ => {
let pos =
MultiSpan::from_spans(refs.iter().map(|(_, p)| *p.unwrap()).collect());
let mut refs: Vec<String> = refs.iter().map(|(s, _)| s.to_owned()).collect();
let reg = refs.pop().unwrap();
format!("arguments {head} and {tail}",
tail=reg,
head=refs.join(", "))
(
format!(
"arguments {head} and {tail}",
tail = reg,
head = refs.join(", ")
),
pos,
)
}
};

Expand All @@ -314,7 +334,7 @@ impl<'a, 'b> Context<'a, 'b> {
match arg {
Exact(arg) => {
if self.args.len() <= arg {
self.invalid_refs.push(arg);
self.invalid_refs.push((arg, self.curpiece));
return;
}
match ty {
Expand Down Expand Up @@ -520,33 +540,27 @@ impl<'a, 'b> Context<'a, 'b> {
let prec = self.build_count(arg.format.precision);
let width = self.build_count(arg.format.width);
let path = self.ecx.path_global(sp, Context::rtpath(self.ecx, "FormatSpec"));
let fmt =
self.ecx.expr_struct(sp,
let fmt = self.ecx.expr_struct(
sp,
path,
vec![self.ecx
.field_imm(sp, self.ecx.ident_of("fill"), fill),
self.ecx.field_imm(sp,
self.ecx.ident_of("align"),
align),
self.ecx.field_imm(sp,
self.ecx.ident_of("flags"),
flags),
self.ecx.field_imm(sp,
self.ecx.ident_of("precision"),
prec),
self.ecx.field_imm(sp,
self.ecx.ident_of("width"),
width)]);
vec![
self.ecx.field_imm(sp, self.ecx.ident_of("fill"), fill),
self.ecx.field_imm(sp, self.ecx.ident_of("align"), align),
self.ecx.field_imm(sp, self.ecx.ident_of("flags"), flags),
self.ecx.field_imm(sp, self.ecx.ident_of("precision"), prec),
self.ecx.field_imm(sp, self.ecx.ident_of("width"), width),
],
);

let path = self.ecx.path_global(sp, Context::rtpath(self.ecx, "Argument"));
Some(self.ecx.expr_struct(sp,
Some(self.ecx.expr_struct(
sp,
path,
vec![self.ecx.field_imm(sp,
self.ecx.ident_of("position"),
pos),
self.ecx.field_imm(sp,
self.ecx.ident_of("format"),
fmt)]))
vec![
self.ecx.field_imm(sp, self.ecx.ident_of("position"), pos),
self.ecx.field_imm(sp, self.ecx.ident_of("format"), fmt),
],
))
}
}
}
Expand All @@ -559,9 +573,9 @@ impl<'a, 'b> Context<'a, 'b> {
let mut pats = Vec::new();
let mut heads = Vec::new();

let names_pos: Vec<_> = (0..self.args.len()).map(|i| {
self.ecx.ident_of(&format!("arg{}", i)).gensym()
}).collect();
let names_pos: Vec<_> = (0..self.args.len())
.map(|i| self.ecx.ident_of(&format!("arg{}", i)).gensym())
.collect();

// First, build up the static array which will become our precompiled
// format "string"
Expand Down Expand Up @@ -705,10 +719,11 @@ pub fn expand_format_args<'cx>(ecx: &'cx mut ExtCtxt,
}
}

pub fn expand_format_args_nl<'cx>(ecx: &'cx mut ExtCtxt,
pub fn expand_format_args_nl<'cx>(
ecx: &'cx mut ExtCtxt,
mut sp: Span,
tts: &[tokenstream::TokenTree])
-> Box<dyn base::MacResult + 'cx> {
tts: &[tokenstream::TokenTree],
) -> Box<dyn base::MacResult + 'cx> {
//if !ecx.ecfg.enable_allow_internal_unstable() {

// For some reason, the only one that actually works for `println` is the first check
Expand Down Expand Up @@ -759,7 +774,6 @@ pub fn expand_preparsed_format_args(ecx: &mut ExtCtxt,
let sugg_fmt = match args.len() {
0 => "{}".to_string(),
_ => format!("{}{{}}", "{} ".repeat(args.len())),

};
err.span_suggestion(
fmt_sp.shrink_to_lo(),
Expand All @@ -768,7 +782,7 @@ pub fn expand_preparsed_format_args(ecx: &mut ExtCtxt,
);
err.emit();
return DummyResult::raw_expr(sp);
},
}
};

let mut cx = Context {
Expand Down Expand Up @@ -862,7 +876,7 @@ pub fn expand_preparsed_format_args(ecx: &mut ExtCtxt,
}

if cx.invalid_refs.len() >= 1 {
cx.report_invalid_references(numbered_position_args, &parser.arg_places);
cx.report_invalid_references(numbered_position_args);
}

// Make sure that all arguments were used and all arguments have types.
Expand Down Expand Up @@ -894,7 +908,7 @@ pub fn expand_preparsed_format_args(ecx: &mut ExtCtxt,
} else {
let mut diag = cx.ecx.struct_span_err(
errs.iter().map(|&(sp, _)| sp).collect::<Vec<Span>>(),
"multiple unused formatting arguments"
"multiple unused formatting arguments",
);
diag.span_label(cx.fmtsp, "multiple missing formatting arguments");
diag
Expand Down
16 changes: 8 additions & 8 deletions src/test/ui/ifmt-bad-arg.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -25,34 +25,34 @@ LL | format!("{} {}");
| ^^ ^^

error: invalid reference to positional argument 1 (there is 1 argument)
--> $DIR/ifmt-bad-arg.rs:26:14
--> $DIR/ifmt-bad-arg.rs:26:18
|
LL | format!("{0} {1}", 1);
| ^^^ ^^^
| ^^^
|
= note: positional arguments are zero-based

error: invalid reference to positional argument 2 (there are 2 arguments)
--> $DIR/ifmt-bad-arg.rs:29:14
--> $DIR/ifmt-bad-arg.rs:29:22
|
LL | format!("{0} {1} {2}", 1, 2);
| ^^^ ^^^ ^^^
| ^^^
|
= note: positional arguments are zero-based

error: invalid reference to positional argument 2 (there are 2 arguments)
--> $DIR/ifmt-bad-arg.rs:32:14
--> $DIR/ifmt-bad-arg.rs:32:28
|
LL | format!("{} {value} {} {}", 1, value=2);
| ^^ ^^^^^^^ ^^ ^^
| ^^
|
= note: positional arguments are zero-based

error: invalid reference to positional arguments 3, 4 and 5 (there are 3 arguments)
--> $DIR/ifmt-bad-arg.rs:34:14
--> $DIR/ifmt-bad-arg.rs:34:38
|
LL | format!("{name} {value} {} {} {} {} {} {}", 0, name=1, value=2);
| ^^^^^^ ^^^^^^^ ^^ ^^ ^^ ^^ ^^ ^^
| ^^ ^^ ^^
|
= note: positional arguments are zero-based

Expand Down