|
2 | 2 |
|
3 | 3 | extern crate swc_malloc;
|
4 | 4 |
|
5 |
| -use std::{env, fs, path::PathBuf, time::Instant}; |
| 5 | +use std::{env, path::PathBuf, time::Instant}; |
6 | 6 |
|
7 | 7 | use anyhow::Result;
|
8 | 8 | use rayon::prelude::*;
|
@@ -55,20 +55,26 @@ fn expand_dirs(dirs: Vec<String>) -> Vec<PathBuf> {
|
55 | 55 | .collect()
|
56 | 56 | }
|
57 | 57 |
|
58 |
| -struct Worker; |
| 58 | +struct Worker { |
| 59 | + total_size: usize, |
| 60 | +} |
59 | 61 |
|
60 | 62 | impl Parallel for Worker {
|
61 | 63 | fn create(&self) -> Self {
|
62 |
| - Worker |
| 64 | + Worker { total_size: 0 } |
63 | 65 | }
|
64 | 66 |
|
65 |
| - fn merge(&mut self, _: Self) {} |
| 67 | + fn merge(&mut self, other: Self) { |
| 68 | + self.total_size += other.total_size; |
| 69 | + } |
66 | 70 | }
|
67 | 71 |
|
68 | 72 | #[inline(never)] // For profiling
|
69 | 73 | fn minify_all(files: &[PathBuf]) {
|
70 | 74 | GLOBALS.set(&Default::default(), || {
|
71 |
| - Worker.maybe_par(2, files, |_, path| { |
| 75 | + let mut worker = Worker { total_size: 0 }; |
| 76 | + |
| 77 | + worker.maybe_par(2, files, |worker, path| { |
72 | 78 | testing::run_test(false, |cm, handler| {
|
73 | 79 | let fm = cm.load_file(path).expect("failed to load file");
|
74 | 80 |
|
@@ -114,12 +120,14 @@ fn minify_all(files: &[PathBuf]) {
|
114 | 120 |
|
115 | 121 | let code = print(cm.clone(), &[output], true);
|
116 | 122 |
|
117 |
| - fs::write("output.js", code.as_bytes()).expect("failed to write output"); |
| 123 | + worker.total_size += code.len(); |
118 | 124 |
|
119 | 125 | Ok(())
|
120 | 126 | })
|
121 | 127 | .unwrap()
|
122 | 128 | });
|
| 129 | + |
| 130 | + eprintln!("Total size: {}", worker.total_size); |
123 | 131 | });
|
124 | 132 | }
|
125 | 133 |
|
|
0 commit comments