diff options
author | 2022-11-26 21:04:38 -0800 | |
---|---|---|
committer | 2022-11-26 21:04:38 -0800 | |
commit | 10996a797a6cae831a292b40f80ed3446277eccb (patch) | |
tree | 7da625d903dc2166d4b611d9e366ff96f0c9ebe9 /bench/snippets/text-decoder.mjs | |
parent | 949d715a141890286d3b04ded8e209ac899ed2af (diff) | |
download | bun-10996a797a6cae831a292b40f80ed3446277eccb.tar.gz bun-10996a797a6cae831a292b40f80ed3446277eccb.tar.zst bun-10996a797a6cae831a292b40f80ed3446277eccb.zip |
Faster UTF16 -> UTF8 and UTF8 -> UTF16 (#1552)
* Fix freezing test
* Add SIMDUTF
* More micro bench snippets
* Update .gitattributes
* Update .gitattributes
Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com>
Diffstat (limited to 'bench/snippets/text-decoder.mjs')
-rw-r--r-- | bench/snippets/text-decoder.mjs | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/bench/snippets/text-decoder.mjs b/bench/snippets/text-decoder.mjs new file mode 100644 index 000000000..b1d669f02 --- /dev/null +++ b/bench/snippets/text-decoder.mjs @@ -0,0 +1,49 @@ +import { bench, run } from "../node_modules/mitata/src/cli.mjs"; + +var short = new TextEncoder().encode("Hello World!"); +var shortUTF16 = new TextEncoder().encode("Hello World 💕💕💕"); +var long = new TextEncoder().encode("Hello World!".repeat(1024)); +var longUTF16 = new TextEncoder().encode("Hello World 💕💕💕".repeat(1024)); +bench(`${short.length} ascii`, () => { + var decoder = new TextDecoder(); + decoder.decode(short); +}); + +bench(`${short.length} utf8`, () => { + var decoder = new TextDecoder(); + decoder.decode(shortUTF16); +}); + +bench(`${long.length} ascii`, () => { + var decoder = new TextDecoder(); + decoder.decode(long); +}); + +bench(`${longUTF16.length} utf8`, () => { + var decoder = new TextDecoder(); + decoder.decode(longUTF16); +}); + +if ("Buffer" in globalThis) { + const buffer_short = Buffer.from(short); + bench(`Buffer ${buffer_short.length} ascii`, () => { + buffer_short.toString("ascii"); + }); + + const buffer_shortUTF16 = Buffer.from(short); + bench(`Buffer ${buffer_shortUTF16.length} utf8`, () => { + buffer_shortUTF16.toString("utf8"); + }); + + const buffer_long = Buffer.from(long); + bench(`Buffer ${buffer_long.length} ascii`, () => { + buffer_long.toString("ascii"); + }); + + const buffer_longUTF16 = Buffer.from(longUTF16); + bench(`Buffer ${buffer_longUTF16.length} utf8`, () => { + buffer_longUTF16.toString("utf8"); + }); +} + +await run(); |