Skip to content

Commit e691474

Browse files
committed
cargo clippy dev: fix extraction of downloaded crates
1 parent 6317683 commit e691474

File tree

1 file changed

+19
-15
lines changed

1 file changed

+19
-15
lines changed

clippy_dev/src/crater.rs

Lines changed: 19 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -34,28 +34,30 @@ impl KrateSource {
3434
self.name, self.version
3535
);
3636
println!("Downloading {}, {} / {}", self.name, self.version, url);
37-
std::fs::create_dir("target/crater/").unwrap();
37+
let _ = std::fs::create_dir("target/crater/");
3838

39-
std::fs::create_dir(&krate_download_dir).unwrap();
40-
std::fs::create_dir(&extract_dir).unwrap();
39+
let _ = std::fs::create_dir(&krate_download_dir);
40+
let _ = std::fs::create_dir(&extract_dir);
4141

4242
let krate_name = format!("{}-{}.crate.tar.gz", &self.name, &self.version);
43-
let mut krate_dest = std::fs::File::create(krate_download_dir.join(krate_name)).unwrap();
43+
let krate_file_path = krate_download_dir.join(krate_name);
44+
let mut krate_dest = std::fs::File::create(&krate_file_path).unwrap();
4445
let mut krate_req = ureq::get(&url).call().unwrap().into_reader();
4546
std::io::copy(&mut krate_req, &mut krate_dest).unwrap();
46-
let krate = krate_dest;
47-
dbg!(&krate);
48-
let tar = flate2::read::GzDecoder::new(&krate);
49-
let mut archiv = tar::Archive::new(tar);
50-
let extracted_path = extract_dir.join(format!("{}-{}", self.name, self.version));
51-
// println!("ar: p: {:?}", &krate, extracted_path);
52-
archiv.unpack(&extracted_path).expect("Failed to extract!");
53-
// extract
47+
// unzip the tarball
48+
let dl = std::fs::File::open(krate_file_path).unwrap();
49+
50+
let ungz_tar = flate2::read::GzDecoder::new(dl);
51+
// extract the tar archive
52+
let mut archiv = tar::Archive::new(ungz_tar);
53+
let extract_path = extract_dir.join(format!("{}-{}/", self.name, self.version));
54+
archiv.unpack(&extract_path).expect("Failed to extract!");
55+
// extracted
5456

5557
Krate {
5658
version: self.version.clone(),
5759
name: self.name.clone(),
58-
path: extracted_path,
60+
path: extract_path,
5961
}
6062
}
6163
}
@@ -88,11 +90,13 @@ pub fn run() {
8890
// assert that clippy is found
8991
assert!(
9092
cargo_clippy_path.is_file(),
91-
"target/debug/cargo-clippy binary not found! {}", cargo_clippy_path.display()
93+
"target/debug/cargo-clippy binary not found! {}",
94+
cargo_clippy_path.display()
9295
);
9396
assert!(
9497
clippy_driver_path.is_file(),
95-
"target/debug/clippy-driver binary not found! {}", clippy_driver_path.display()
98+
"target/debug/clippy-driver binary not found! {}",
99+
clippy_driver_path.display()
96100
);
97101

98102
// download and extract the crates, then run clippy on them and collect clippys warnings

0 commit comments

Comments
 (0)