2020-05-08 14:28:02 +01:00
|
|
|
|
# Tools
|
|
|
|
|
|
2020-10-03 13:19:11 -07:00
|
|
|
|
Documentation for various tooling in support of Deno development.
|
2020-05-08 14:28:02 +01:00
|
|
|
|
|
2020-11-05 15:53:21 +01:00
|
|
|
|
## format.js
|
2020-05-08 14:28:02 +01:00
|
|
|
|
|
2020-11-05 15:53:21 +01:00
|
|
|
|
This script will format the code (currently using dprint, rustfmt). It is a
|
|
|
|
|
prerequisite to run this before code check in.
|
2020-05-08 14:28:02 +01:00
|
|
|
|
|
|
|
|
|
To run formatting:
|
|
|
|
|
|
2020-09-24 00:07:43 +06:00
|
|
|
|
```sh
|
2020-11-05 16:49:03 +01:00
|
|
|
|
deno run --allow-read --allow-write --allow-run --unstable ./tools/format.js
|
2020-05-08 14:28:02 +01:00
|
|
|
|
```
|
|
|
|
|
|
2020-11-05 16:49:03 +01:00
|
|
|
|
## lint.js
|
2020-05-08 14:28:02 +01:00
|
|
|
|
|
2020-11-05 15:53:21 +01:00
|
|
|
|
This script will lint the code base (currently using dlint, clippy). It is a
|
|
|
|
|
prerequisite to run this before code check in.
|
2020-05-08 14:28:02 +01:00
|
|
|
|
|
|
|
|
|
To run linting:
|
|
|
|
|
|
2020-09-24 00:07:43 +06:00
|
|
|
|
```sh
|
2020-11-05 16:49:03 +01:00
|
|
|
|
deno run --allow-read --allow-write --allow-run --unstable ./tools/lint.js
|
2020-05-08 14:28:02 +01:00
|
|
|
|
```
|
2020-11-09 03:56:36 +08:00
|
|
|
|
|
|
|
|
|
Tip: You can also use cargo to run the current or pending build of the deno
|
|
|
|
|
executable
|
|
|
|
|
|
|
|
|
|
```sh
|
|
|
|
|
cargo run -- run --allow-read --allow-write --allow-run --unstable ./tools/<script>
|
|
|
|
|
```
|
2021-04-26 16:41:53 +02:00
|
|
|
|
|
|
|
|
|
## flamebench.js
|
|
|
|
|
|
|
|
|
|
`flamebench.js` facilitates profiling and generating flamegraphs from
|
|
|
|
|
benchmarks.
|
|
|
|
|
|
|
|
|
|
General usage:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
❯ ./tools/flamebench.js
|
|
|
|
|
flamebench <bench_name> [bench_filter]
|
|
|
|
|
|
|
|
|
|
Available benches:
|
|
|
|
|
op_baseline
|
|
|
|
|
ser
|
|
|
|
|
de
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
To profile the `op_baseline` bench, run `./tools/flamebench.js op_baseline`,
|
|
|
|
|
this will run all 3 benches in `op_baseline.
|
|
|
|
|
|
|
|
|
|
Often when profiling/optimizing, you'll want to focus on a specific sub-bench,
|
|
|
|
|
`flamebench` supports a bench/test filter arg like the regular cargo commands.
|
|
|
|
|
So you can simply run `./tools/flamebench.js op_baseline bench_op_async` or
|
|
|
|
|
`./tools/flamebench.js op_baseline bench_op_nop` to profile specific benches.
|
|
|
|
|
|
|
|
|
|
Tip: the `[bench_filter]` argument doesn't have to be an exact bench name, you
|
|
|
|
|
can use a shorthand or a partial match to profile a group of benches, e.g:
|
|
|
|
|
`./tools/flamebench.js de v8`
|
2022-01-24 23:47:05 +01:00
|
|
|
|
|
|
|
|
|
## wgpu_sync.js
|
|
|
|
|
|
|
|
|
|
`wgpu_sync.js` streamlines updating `deno_webgpu` from
|
|
|
|
|
[gfx-rs/wgpu](https://github.com/gfx-rs/wgpu/).
|
|
|
|
|
|
|
|
|
|
It essentially vendors the `deno_webgpu` tree with a few minor patches applied
|
|
|
|
|
on top, somewhat similar to `git subtree`.
|
|
|
|
|
|
|
|
|
|
1. Update `COMMIT` or `V_WGPU` in `./tools/wgpu_sync.js`
|
|
|
|
|
2. Run `./tools/wgpu_sync.js`
|
|
|
|
|
3. Double check changes, possibly patch
|
|
|
|
|
4. Commit & send a PR with the updates
|