mirror of
https://github.com/ggerganov/whisper.cpp.git
synced 2025-05-17 14:41:10 +02:00
This commit updates the documentation for the WASM examples to include a note about the generation of the `worker.js` file. As of Emscripten 3.1.58 (April 2024), separate worker.js files are no longer generated and the worker is embedded in the main JS file. The motivation for this change is to inform users about the new behavior of Emscripten and why the `worker.js` file may not be present. Refs: https://github.com/ggml-org/whisper.cpp/issues/3123
36 lines
1019 B
Markdown
36 lines
1019 B
Markdown
# stream.wasm
|
|
|
|
Real-time transcription in the browser using WebAssembly
|
|
|
|
Online demo: https://whisper.ggerganov.com/stream/
|
|
|
|
## Build instructions
|
|
|
|
```bash
|
|
# build using Emscripten (v3.1.2)
|
|
git clone https://github.com/ggerganov/whisper.cpp
|
|
cd whisper.cpp
|
|
mkdir build-em && cd build-em
|
|
emcmake cmake ..
|
|
make -j
|
|
```
|
|
The example can then be started by running a local HTTP server:
|
|
```console
|
|
python3 examples/server.py
|
|
```
|
|
And then opening a browser to the following URL:
|
|
http://localhost:8000/stream.wasm
|
|
|
|
To run the example in a different server, you need to copy the following files
|
|
to the server's HTTP path:
|
|
```
|
|
# copy the produced page to your HTTP path
|
|
cp bin/stream.wasm/* /path/to/html/
|
|
cp bin/libstream.js /path/to/html/
|
|
cp bin/libstream.worker.js /path/to/html/
|
|
```
|
|
|
|
> 📝 **Note:** As of Emscripten 3.1.58 (April 2024), separate worker.js files are no
|
|
> longer generated and the worker is embedded in the main JS file. So the worker
|
|
> file will not be geneated for versions later than `3.1.58`.
|