Skip to content

Commit 2e528d1

Browse files
committed
Move line_span to source.rs
1 parent e144c7d commit 2e528d1

File tree

2 files changed

+20
-22
lines changed

2 files changed

+20
-22
lines changed

clippy_utils/src/lib.rs

+1-19
Original file line numberDiff line numberDiff line change
@@ -109,11 +109,10 @@ use rustc_middle::ty::{FloatTy, IntTy, UintTy};
109109
use rustc_semver::RustcVersion;
110110
use rustc_session::Session;
111111
use rustc_span::hygiene::{ExpnKind, MacroKind};
112-
use rustc_span::source_map::original_sp;
113112
use rustc_span::source_map::SourceMap;
114113
use rustc_span::sym;
115114
use rustc_span::symbol::{kw, Symbol};
116-
use rustc_span::{Span, DUMMY_SP};
115+
use rustc_span::Span;
117116
use rustc_target::abi::Integer;
118117

119118
use crate::consts::{constant, Constant};
@@ -1291,23 +1290,6 @@ pub fn contains_return(expr: &hir::Expr<'_>) -> bool {
12911290
.is_some()
12921291
}
12931292

1294-
/// Extends the span to the beginning of the spans line, incl. whitespaces.
1295-
///
1296-
/// ```rust
1297-
/// let x = ();
1298-
/// // ^^
1299-
/// // will be converted to
1300-
/// let x = ();
1301-
/// // ^^^^^^^^^^^^^^
1302-
/// ```
1303-
fn line_span<T: LintContext>(cx: &T, span: Span) -> Span {
1304-
let span = original_sp(span, DUMMY_SP);
1305-
let source_map_and_line = cx.sess().source_map().lookup_line(span.lo()).unwrap();
1306-
let line_no = source_map_and_line.line;
1307-
let line_start = source_map_and_line.sf.lines(|lines| lines[line_no]);
1308-
span.with_lo(line_start)
1309-
}
1310-
13111293
/// Gets the parent node, if any.
13121294
pub fn get_parent_node(tcx: TyCtxt<'_>, id: HirId) -> Option<Node<'_>> {
13131295
tcx.hir().parent_iter(id).next().map(|(_, node)| node)

clippy_utils/src/source.rs

+19-3
Original file line numberDiff line numberDiff line change
@@ -2,13 +2,12 @@
22
33
#![allow(clippy::module_name_repetitions)]
44

5-
use crate::line_span;
65
use rustc_errors::Applicability;
76
use rustc_hir::{Expr, ExprKind};
87
use rustc_lint::{LateContext, LintContext};
98
use rustc_span::hygiene;
10-
use rustc_span::source_map::SourceMap;
11-
use rustc_span::{BytePos, Pos, Span, SpanData, SyntaxContext};
9+
use rustc_span::source_map::{original_sp, SourceMap};
10+
use rustc_span::{BytePos, Pos, Span, SpanData, SyntaxContext, DUMMY_SP};
1211
use std::borrow::Cow;
1312

1413
/// Like `snippet_block`, but add braces if the expr is not an `ExprKind::Block`.
@@ -55,6 +54,23 @@ fn first_char_in_first_line<T: LintContext>(cx: &T, span: Span) -> Option<BytePo
5554
})
5655
}
5756

57+
/// Extends the span to the beginning of the spans line, incl. whitespaces.
58+
///
59+
/// ```rust
60+
/// let x = ();
61+
/// // ^^
62+
/// // will be converted to
63+
/// let x = ();
64+
/// // ^^^^^^^^^^^^^^
65+
/// ```
66+
fn line_span<T: LintContext>(cx: &T, span: Span) -> Span {
67+
let span = original_sp(span, DUMMY_SP);
68+
let source_map_and_line = cx.sess().source_map().lookup_line(span.lo()).unwrap();
69+
let line_no = source_map_and_line.line;
70+
let line_start = source_map_and_line.sf.lines(|lines| lines[line_no]);
71+
span.with_lo(line_start)
72+
}
73+
5874
/// Returns the indentation of the line of a span
5975
///
6076
/// ```rust,ignore

0 commit comments

Comments
 (0)