mirror of
https://github.com/swc-project/swc.git
synced 2024-12-30 00:52:29 +03:00
0ac55ae68b
testing: - Remove dependency on relative_path swc_common: - Span's byte positions are now self-contained and `GLOBALS` is not required while parsing. - Changed `Comments` into a trait. - Provide single-threaded implementation of `Comments` - Cargo feature `tty-emiiter` (To remove tty related stuffs ) - Cargo feature `sourcemap` (To remove sourcemap for web assets) - Removed dependency on dashmap swc_ecma_parser: - No duplicated comments. - Removed dependency on once_cell and regex - Add a test suite to visualize and test span of nodes. swc_ecma_utils: - Removed dependency on parser swc: - Remove dependency on derive_more and path-clean - Add multi-threaded implementation of `Comments` swc_ecmascript: - A new crate contains `ast`, `codegen`, `parser`, `utils`, `visit`.
82 lines
2.0 KiB
Rust
82 lines
2.0 KiB
Rust
#![feature(test)]
|
|
extern crate test;
|
|
|
|
use swc_common::{FileName, Mark};
|
|
use swc_ecma_parser::{Parser, StringInput, Syntax};
|
|
use swc_ecma_preset_env::{preset_env, Config};
|
|
use swc_ecma_visit::FoldWith;
|
|
use test::Bencher;
|
|
|
|
fn run(b: &mut Bencher, src: &str, config: Config) {
|
|
b.bytes = src.len() as _;
|
|
|
|
let _ = ::testing::run_test(false, |cm, handler| {
|
|
let fm = cm.new_source_file(FileName::Anon, src.into());
|
|
|
|
let mut parser = Parser::new(Syntax::default(), StringInput::from(&*fm), None);
|
|
let module = parser
|
|
.parse_module()
|
|
.map_err(|e| e.into_diagnostic(&handler).emit())
|
|
.unwrap();
|
|
|
|
for e in parser.take_errors() {
|
|
e.into_diagnostic(&handler).emit()
|
|
}
|
|
|
|
let mut folder = preset_env(Mark::fresh(Mark::root()), config);
|
|
|
|
b.iter(|| test::black_box(module.clone().fold_with(&mut folder)));
|
|
Ok(())
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn usage_builtin_type(b: &mut Bencher) {
|
|
const SOURCE: &str = r#"
|
|
// From a length
|
|
var float32 = new Float32Array(2);
|
|
float32[0] = 42;
|
|
console.log(float32[0]); // 42
|
|
console.log(float32.length); // 2
|
|
console.log(float32.BYTES_PER_ELEMENT); // 4
|
|
|
|
// From an array
|
|
var arr = new Float32Array([21,31]);
|
|
console.log(arr[1]); // 31
|
|
|
|
// From another TypedArray
|
|
var x = new Float32Array([21, 31]);
|
|
var y = new Float32Array(x);
|
|
console.log(y[0]); // 21
|
|
|
|
// From an ArrayBuffer
|
|
var buffer = new ArrayBuffer(16);
|
|
var z = new Float32Array(buffer, 0, 4);
|
|
|
|
// From an iterable
|
|
var iterable = function*(){ yield* [1,2,3]; }();
|
|
var float32 = new Float32Array(iterable);
|
|
// Float32Array[1, 2, 3]
|
|
"#;
|
|
|
|
run(b, SOURCE, Default::default())
|
|
}
|
|
|
|
#[bench]
|
|
fn usage_property(b: &mut Bencher) {
|
|
const SOURCE: &str = r#"
|
|
const target = { a: 1, b: 2 };
|
|
const source = { b: 4, c: 5 };
|
|
|
|
const returnedTarget = Object.assign(target, source);
|
|
|
|
console.log(target);
|
|
// expected output: Object { a: 1, b: 4, c: 5 }
|
|
|
|
console.log(returnedTarget);
|
|
// expected output: Object { a: 1, b: 4, c: 5 }
|
|
"#;
|
|
|
|
run(b, SOURCE, Default::default())
|
|
}
|