Auto merge of #16413 - Urhengulas:clippy-ci, r=Veykril

internal: Add `clippy` to CI

Follow-up to #16401
This commit is contained in:
bors 2024-01-30 14:41:43 +00:00
commit da4d5f8f29
7 changed files with 15 additions and 11 deletions

View file

@ -90,7 +90,7 @@ jobs:
- name: Switch to stable toolchain - name: Switch to stable toolchain
run: | run: |
rustup update --no-self-update stable rustup update --no-self-update stable
rustup component add --toolchain stable rust-src rustup component add --toolchain stable rust-src clippy
rustup default stable rustup default stable
- name: Run analysis-stats on rust-analyzer - name: Run analysis-stats on rust-analyzer
@ -103,6 +103,10 @@ jobs:
RUSTC_BOOTSTRAP: 1 RUSTC_BOOTSTRAP: 1
run: target/${{ matrix.target }}/debug/rust-analyzer analysis-stats --with-deps $(rustc --print sysroot)/lib/rustlib/src/rust/library/std run: target/${{ matrix.target }}/debug/rust-analyzer analysis-stats --with-deps $(rustc --print sysroot)/lib/rustlib/src/rust/library/std
- name: clippy
if: matrix.os == 'ubuntu-latest'
run: cargo clippy --all-targets
# Weird targets to catch non-portable code # Weird targets to catch non-portable code
rust-cross: rust-cross:
if: github.repository == 'rust-lang/rust-analyzer' if: github.repository == 'rust-lang/rust-analyzer'

View file

@ -235,7 +235,7 @@ impl Attr {
let (path, input) = tt.split_at(path_end); let (path, input) = tt.split_at(path_end);
let path = Interned::new(ModPath::from_tt(db, path)?); let path = Interned::new(ModPath::from_tt(db, path)?);
let input = match input.get(0) { let input = match input.first() {
Some(tt::TokenTree::Subtree(tree)) => { Some(tt::TokenTree::Subtree(tree)) => {
Some(Interned::new(AttrInput::TokenTree(Box::new(tree.clone())))) Some(Interned::new(AttrInput::TokenTree(Box::new(tree.clone()))))
} }

View file

@ -232,7 +232,7 @@ fn convert_path(
ast::PathSegmentKind::SuperKw => { ast::PathSegmentKind::SuperKw => {
let mut deg = 1; let mut deg = 1;
let mut next_segment = None; let mut next_segment = None;
while let Some(segment) = segments.next() { for segment in segments.by_ref() {
match segment.kind()? { match segment.kind()? {
ast::PathSegmentKind::SuperKw => deg += 1, ast::PathSegmentKind::SuperKw => deg += 1,
ast::PathSegmentKind::Name(name) => { ast::PathSegmentKind::Name(name) => {

View file

@ -237,7 +237,7 @@ impl<'p> MatchCheckCtx<'p> {
ctor = Or; ctor = Or;
// Collect here because `Arena::alloc_extend` panics on reentrancy. // Collect here because `Arena::alloc_extend` panics on reentrancy.
let subpats: SmallVec<[_; 2]> = let subpats: SmallVec<[_; 2]> =
pats.into_iter().map(|pat| self.lower_pat(pat)).collect(); pats.iter().map(|pat| self.lower_pat(pat)).collect();
fields = self.pattern_arena.alloc_extend(subpats); fields = self.pattern_arena.alloc_extend(subpats);
} }
} }

View file

@ -1715,7 +1715,7 @@ impl Evaluator<'_> {
let v: Cow<'_, [u8]> = if size != v.len() { let v: Cow<'_, [u8]> = if size != v.len() {
// Handle self enum // Handle self enum
if size == 16 && v.len() < 16 { if size == 16 && v.len() < 16 {
Cow::Owned(pad16(&v, false).to_vec()) Cow::Owned(pad16(v, false).to_vec())
} else if size < 16 && v.len() == 16 { } else if size < 16 && v.len() == 16 {
Cow::Borrowed(&v[0..size]) Cow::Borrowed(&v[0..size])
} else { } else {

View file

@ -311,7 +311,7 @@ fn modpath_from_str(link: &str) -> Option<ModPath> {
"self" => PathKind::Super(0), "self" => PathKind::Super(0),
"super" => { "super" => {
let mut deg = 1; let mut deg = 1;
while let Some(segment) = parts.next() { for segment in parts.by_ref() {
if segment == "super" { if segment == "super" {
deg += 1; deg += 1;
} else { } else {

View file

@ -109,14 +109,14 @@ fn main() {
let mut artifact_path = None; let mut artifact_path = None;
for message in Message::parse_stream(output.stdout.as_slice()) { for message in Message::parse_stream(output.stdout.as_slice()) {
if let Message::CompilerArtifact(artifact) = message.unwrap() { if let Message::CompilerArtifact(artifact) = message.unwrap() {
if artifact.target.kind.contains(&"proc-macro".to_string()) { if artifact.target.kind.contains(&"proc-macro".to_string())
if artifact.package_id.repr.starts_with(&repr) || artifact.package_id.repr == pkgid && (artifact.package_id.repr.starts_with(&repr)
|| artifact.package_id.repr == pkgid)
{ {
artifact_path = Some(PathBuf::from(&artifact.filenames[0])); artifact_path = Some(PathBuf::from(&artifact.filenames[0]));
} }
} }
} }
}
// This file is under `target_dir` and is already under `OUT_DIR`. // This file is under `target_dir` and is already under `OUT_DIR`.
let artifact_path = artifact_path.expect("no dylib for proc-macro-test-impl found"); let artifact_path = artifact_path.expect("no dylib for proc-macro-test-impl found");