Stremio shell using WebView2/mpv, written in Rust
Find a file
Claude b4955b58e6
feat: add play-external IPC for launching media in an external player
Mirrors stremio-glutin-shell's play-external action (PR Stremio/stremio-glutin-shell#2)
so the Windows shell can hand a stream off to mpv, VLC or PotPlayer
when the user picks an external player in the WebUI.

- Allowlist of Windows player URL schemes: mpv://, vlc://, potplayer://.
  iOS/macOS-only schemes (iina, infuse, outplayer, open-vidhub) have
  no Windows handlers and are intentionally not listed.
- mpv has no Windows URL handler: spawn the binary directly with `--`
  separating options from the stream URL. Tries common install paths
  (Program Files, scoop's %LOCALAPPDATA%\Programs\mpv, %LOCALAPPDATA%\mpv)
  before falling back to PATH lookup.
- Spawned with CREATE_BREAKAWAY_FROM_JOB so the JobObject's
  KILL_ON_JOB_CLOSE doesn't kill mpv when the shell exits.
- vlc:// and potplayer:// are routed through `open::that` to use the
  OS protocol handler the user already has registered.

Test: cargo fmt --all -- --check, cargo clippy --all -- -D warnings.
2026-05-10 18:39:44 +00:00
.github/workflows Fix checkout action 2026-03-10 12:13:52 +02:00
bin Us correct DLLs 2025-08-05 13:49:03 +03:00
bin-arm64 Arm64 installer 2025-12-18 12:40:50 +02:00
images Arm64 installer 2025-12-18 12:40:50 +02:00
mpv-arm64 Windows no ARM build 2025-11-12 18:02:41 +02:00
mpv-x64 Windows no ARM build 2025-11-12 18:02:41 +02:00
setup Arm64 installer 2025-12-18 12:40:50 +02:00
src feat: add play-external IPC for launching media in an external player 2026-05-10 18:39:44 +00:00
.gitignore 64 bit build 2025-06-30 12:39:12 +03:00
build-arm64.ps1 Remove build thread arm64 2026-03-12 17:54:25 +02:00
build.ps1 Remove sign thread 2026-03-12 17:27:44 +02:00
build.rs Arm64 installer 2025-12-18 12:40:50 +02:00
Cargo.lock Version updated to v5.0.20 2026-03-23 14:18:20 +02:00
Cargo.toml Version updated to v5.0.21 2026-04-27 13:18:20 +03:00
generate_descriptor.js Multi architecture descriptors 2025-12-05 15:44:01 +02:00
libmpv-2_arm64.zip Windows no ARM build 2025-11-12 18:02:41 +02:00
libmpv-2_x64.zip Fix libmpv 2025-11-27 18:12:02 +02:00
README.md fix typo 2025-02-05 09:14:50 +02:00
rust-toolchain.toml Windows no ARM build 2025-11-12 18:02:41 +02:00
server.js update server to v4.20.17 2026-03-20 14:16:19 +02:00
stremiover.js Version check 2026-03-10 10:54:23 +02:00
upload.ps1 Better uploader 2026-02-05 13:48:58 +02:00

Stremio shell: new gen

A Windows-only shell using WebView2 and MPV

Goals:

  • Performance
  • Reliability
  • Easy to ship

In all three, this architecture excels the Qt-based shell: it is about 2-5x more efficient depending on the use case, as it allows MPV to render directly in the window through it's optimal video output rather than using libmpv to integrate with Qt.

This is due to Qt having a complex rendering pipeline involving ANGLE and multiple levels of composing and drawing to textures, which inhibits full HW acceleration.

Meanwhile in this setup MPV uses whichever pipeline it considers to be optimal (like the mpv desktop app), which is normally d3d11, allowing full HW acceleration.

For web rendering, we use the native WebView2, which is Chromium based but shipped as a part of Windows 10: therefore we do not need to ship our own "distribution" of Chromium.

Finally, this should be a lot more reliable as it uses a much simpler and more native overall architecture.