Merge pull request #1872 from sinkuu/remove_newline

Remove blank lines at start or end of block
This commit is contained in:
Seiichi Uchida 2017-08-15 00:28:31 +09:00 committed by GitHub
commit a1d28bf41c
23 changed files with 105 additions and 27 deletions

View File

@ -271,7 +271,6 @@ fn get_targets(workspace_hitlist: WorkspaceHitlist) -> Result<Vec<Target>, std::
std::io::ErrorKind::NotFound,
str::from_utf8(&output.stderr).unwrap(),
))
}
fn target_from_json(jtarget: &Value) -> Target {

View File

@ -102,7 +102,6 @@ fn match_cli_path_or_file(
config_path: Option<PathBuf>,
input_file: &Path,
) -> FmtResult<(Config, Option<PathBuf>)> {
if let Some(config_file) = config_path {
let toml = Config::from_toml_path(config_file.as_ref())?;
return Ok((toml, Some(config_file)));

View File

@ -606,7 +606,9 @@ create_config! {
tuple patterns";
combine_control_expr: bool, true, "Combine control expressions with funciton calls.";
struct_field_align_threshold: usize, 0, "Align struct fields if their diffs fits within \
threshold."
threshold.";
remove_blank_lines_at_start_or_end_of_block: bool, true,
"Remove blank lines at start or end of a block";
}
#[cfg(test)]

View File

@ -2937,7 +2937,6 @@ fn choose_rhs(
}
fn prefer_next_line(orig_rhs: &str, next_line_rhs: &str) -> bool {
fn count_line_breaks(src: &str) -> usize {
src.chars().filter(|&x| x == '\n').count()
}

View File

@ -90,7 +90,6 @@ pub fn write_file<T>(
where
T: Write,
{
fn source_and_formatted_text(
text: &StringBuffer,
filename: &str,

View File

@ -404,7 +404,6 @@ where
} else {
Some(format!("{}{}", args, output))
}
}
fn type_bound_colon(context: &RewriteContext) -> &'static str {
@ -601,7 +600,6 @@ impl Rewrite for ast::TyParam {
result.push_str(&join_bounds(context, shape, &strs));
}
if let Some(ref def) = self.default {
let eq_str = match context.config.type_punctuation_density() {
TypeDensity::Compressed => "=",
TypeDensity::Wide => " = ",

View File

@ -12,12 +12,13 @@ use std::cmp;
use strings::string_buffer::StringBuffer;
use syntax::{ast, ptr, visit};
use syntax::codemap::{self, BytePos, CodeMap, Span};
use syntax::attr::HasAttrs;
use syntax::codemap::{self, BytePos, CodeMap, Pos, Span};
use syntax::parse::ParseSess;
use {Indent, Shape, Spanned};
use codemap::{LineRangeUtils, SpanUtils};
use comment::{contains_comment, FindUncommented};
use comment::{contains_comment, CodeCharKind, CommentCodeSlices, FindUncommented};
use comment::rewrite_comment;
use config::{BraceStyle, Config};
use expr::{format_expr, ExprType};
@ -131,6 +132,48 @@ impl<'a> FmtVisitor<'a> {
self.block_indent = self.block_indent.block_indent(self.config);
self.buffer.push_str("{");
if self.config.remove_blank_lines_at_start_or_end_of_block() {
if let Some(first_stmt) = b.stmts.first() {
let attr_lo = inner_attrs
.and_then(|attrs| {
utils::inner_attributes(attrs)
.first()
.map(|attr| attr.span.lo)
})
.or_else(|| {
// Attributes for an item in a statement position
// do not belong to the statement. (rust-lang/rust#34459)
if let ast::StmtKind::Item(ref item) = first_stmt.node {
item.attrs.first()
} else {
first_stmt.attrs().first()
}.and_then(|attr| {
// Some stmts can have embedded attributes.
// e.g. `match { #![attr] ... }`
let attr_lo = attr.span.lo;
if attr_lo < first_stmt.span.lo {
Some(attr_lo)
} else {
None
}
})
});
let snippet =
self.snippet(mk_sp(self.last_pos, attr_lo.unwrap_or(first_stmt.span.lo)));
let len = CommentCodeSlices::new(&snippet).nth(0).and_then(
|(kind, _, s)| if kind == CodeCharKind::Normal {
s.rfind('\n')
} else {
None
},
);
if let Some(len) = len {
self.last_pos = self.last_pos + BytePos::from_usize(len);
}
}
}
// Format inner attributes if available.
if let Some(attrs) = inner_attrs {
self.visit_attrs(attrs, ast::AttrStyle::Inner);
@ -148,9 +191,31 @@ impl<'a> FmtVisitor<'a> {
}
}
let mut remove_len = BytePos(0);
if self.config.remove_blank_lines_at_start_or_end_of_block() {
if let Some(stmt) = b.stmts.last() {
let snippet = self.snippet(mk_sp(
stmt.span.hi,
source!(self, b.span).hi - brace_compensation,
));
let len = CommentCodeSlices::new(&snippet)
.last()
.and_then(|(kind, _, s)| {
if kind == CodeCharKind::Normal && s.trim().is_empty() {
Some(s.len())
} else {
None
}
});
if let Some(len) = len {
remove_len = BytePos::from_usize(len);
}
}
}
let mut unindent_comment = self.is_if_else_block && !b.stmts.is_empty();
if unindent_comment {
let end_pos = source!(self, b.span).hi - brace_compensation;
let end_pos = source!(self, b.span).hi - brace_compensation - remove_len;
let snippet = self.get_context().snippet(mk_sp(self.last_pos, end_pos));
unindent_comment = snippet.contains("//") || snippet.contains("/*");
}
@ -158,7 +223,7 @@ impl<'a> FmtVisitor<'a> {
if unindent_comment {
self.block_indent = self.block_indent.block_unindent(self.config);
}
self.format_missing_with_indent(source!(self, b.span).hi - brace_compensation);
self.format_missing_with_indent(source!(self, b.span).hi - brace_compensation - remove_len);
if unindent_comment {
self.block_indent = self.block_indent.block_indent(self.config);
}

View File

@ -51,5 +51,4 @@ pub fn waltz(cwd: &Path) -> CliAssert {
formatted_comment = rewrite_comment(comment, block_style, width, offset, formatting_fig);
}
}
}

View File

@ -23,5 +23,4 @@ fn main() {
},
_ => "something else",
}
}

View File

@ -3,7 +3,6 @@ fn solve_inline_size_constraints(&self,
block: &mut BlockFlow,
input: &ISizeConstraintInput)
-> ISizeConstraintSolution {
let (inline_start,inline_size,margin_inline_start,margin_inline_end) =
match (inline_startssssssxxxxxxsssssxxxxxxxxxssssssxxx,inline_startssssssxxxxxxsssssxxxxxxxxxssssssxxx) {
(MaybeAuto::Auto, MaybeAuto::Auto, MaybeAuto::Auto) => {

View File

@ -0,0 +1,22 @@
fn main() {
let x = 1;
}
fn foo() {
#![attribute]
let x = 1;
// comment
}

View File

@ -31,7 +31,6 @@ fn foo<T, E>(a: T, b: E) {
}
fn foo<T: Send, E: Send>(a: T, b: E) {
foo::<u32, str>(10, "bar");
let opt: Option<u32>;

View File

@ -14,7 +14,6 @@ struct TupleStruct2(u32, u32);
fn fooEmpty() {}
fn foo(e: E, _: u32) -> (u32, u32) {
// Tuples
let t1 = ();
let t2 = (1,);

View File

@ -1,7 +1,6 @@
// rustfmt-spaces_within_square_brackets: true
fn main() {
let arr: [i32; 5] = [1, 2, 3, 4, 5];
let arr: [i32; 500] = [0; 500];

View File

@ -3,7 +3,6 @@
// rustfmt-error_on_line_overflow: false
// rustfmt-struct_lit_style: Visual
fn foo() {
Fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo(f(), b());
Foooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo(// Comment
@ -35,5 +34,4 @@ fn foo() {
// /|\ \
// o o o o
G)
}

View File

@ -96,5 +96,4 @@ pub fn waltz(cwd: &Path) -> CliAssert {
rewrite_comment(comment, block_style, width, offset, formatting_fig);
}
}
}

View File

@ -23,5 +23,4 @@ fn main() {
},
_ => "something else",
}
}

View File

@ -4,7 +4,6 @@ impl ISizeAndMarginsComputer for AbsoluteNonReplaced {
block: &mut BlockFlow,
input: &ISizeConstraintInput,
) -> ISizeConstraintSolution {
let (inline_start, inline_size, margin_inline_start, margin_inline_end) = match (
inline_startssssssxxxxxxsssssxxxxxxxxxssssssxxx,
inline_startssssssxxxxxxsssssxxxxxxxxxssssssxxx,

View File

@ -0,0 +1,11 @@
fn main() {
let x = 1;
}
fn foo() {
#![attribute]
let x = 1;
// comment
}

View File

@ -31,7 +31,6 @@ fn foo< T, E >(a: T, b: E) {
}
fn foo< T: Send, E: Send >(a: T, b: E) {
foo::< u32, str >(10, "bar");
let opt: Option< u32 >;

View File

@ -14,7 +14,6 @@ struct TupleStruct2( u32, u32 );
fn fooEmpty() {}
fn foo( e: E, _: u32 ) -> ( u32, u32 ) {
// Tuples
let t1 = ();
let t2 = ( 1, );

View File

@ -1,7 +1,6 @@
// rustfmt-spaces_within_square_brackets: true
fn main() {
let arr: [ i32; 5 ] = [ 1, 2, 3, 4, 5 ];
let arr: [ i32; 500 ] = [ 0; 500 ];

View File

@ -3,7 +3,6 @@
// rustfmt-error_on_line_overflow: false
// rustfmt-struct_lit_style: Visual
fn foo() {
Fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo(f(), b());
Foooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo(
@ -45,5 +44,4 @@ fn foo() {
// o o o o
G,
)
}