1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-21 13:00:36 -05:00

move surface and byow to objectwrap

This commit is contained in:
crowlkats 2025-01-17 23:45:55 +01:00
parent 679a46d6f0
commit 9404dfc8cb
No known key found for this signature in database
GPG key ID: A82C9D461FC483E8
9 changed files with 505 additions and 536 deletions

225
Cargo.lock generated
View file

@ -212,11 +212,11 @@ dependencies = [
[[package]] [[package]]
name = "ash" name = "ash"
version = "0.37.3+1.3.251" version = "0.38.0+1.3.281"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "39e9c3835d686b0a6084ab4234fcd1b07dbf6e4767dce60874b12356a25ecd4a" checksum = "0bb44936d800fea8f016d7f2311c6a4f97aebd5dc86f09906139ec848cf3a46f"
dependencies = [ dependencies = [
"libloading 0.7.4", "libloading 0.8.5",
] ]
[[package]] [[package]]
@ -231,7 +231,7 @@ dependencies = [
"nom 7.1.3", "nom 7.1.3",
"num-traits", "num-traits",
"rusticata-macros", "rusticata-macros",
"thiserror 1.0.64", "thiserror 1.0.69",
"time", "time",
] ]
@ -525,7 +525,16 @@ version = "0.5.3"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0700ddab506f33b20a03b13996eccd309a48e5ff77d0d95926aa0210fb4e95f1" checksum = "0700ddab506f33b20a03b13996eccd309a48e5ff77d0d95926aa0210fb4e95f1"
dependencies = [ dependencies = [
"bit-vec", "bit-vec 0.6.3",
]
[[package]]
name = "bit-set"
version = "0.8.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "08807e080ed7f9d5433fa9b275196cfc35414f66a0c79d864dc51a0d825231a3"
dependencies = [
"bit-vec 0.8.0",
] ]
[[package]] [[package]]
@ -534,6 +543,12 @@ version = "0.6.3"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "349f9b6a179ed607305526ca489b34ad0a41aed5f7980fa90eb03160b69598fb" checksum = "349f9b6a179ed607305526ca489b34ad0a41aed5f7980fa90eb03160b69598fb"
[[package]]
name = "bit-vec"
version = "0.8.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5e764a1d40d510daf35e07be9eb06e75770908c27d411ee6c92109c9840eaaf7"
[[package]] [[package]]
name = "bitflags" name = "bitflags"
version = "1.3.2" version = "1.3.2"
@ -646,9 +661,9 @@ dependencies = [
[[package]] [[package]]
name = "bytemuck" name = "bytemuck"
version = "1.15.0" version = "1.21.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5d6d68c57235a3a081186990eca2867354726650f42f7516ca50c28d6281fd15" checksum = "ef657dfab802224e671f5818e9a4935f9b1957ed18e58292690cc39e7a4092a3"
[[package]] [[package]]
name = "byteorder" name = "byteorder"
@ -1155,17 +1170,6 @@ dependencies = [
"syn 2.0.87", "syn 2.0.87",
] ]
[[package]]
name = "d3d12"
version = "0.20.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b28bfe653d79bd16c77f659305b195b82bb5ce0c0eb2a4846b82ddbd77586813"
dependencies = [
"bitflags 2.6.0",
"libloading 0.8.5",
"winapi",
]
[[package]] [[package]]
name = "darling" name = "darling"
version = "0.20.10" version = "0.20.10"
@ -1480,7 +1484,7 @@ dependencies = [
"serde_json", "serde_json",
"sha2", "sha2",
"sys_traits", "sys_traits",
"thiserror 1.0.64", "thiserror 1.0.69",
"url", "url",
] ]
@ -1533,14 +1537,12 @@ dependencies = [
[[package]] [[package]]
name = "deno_core" name = "deno_core"
version = "0.331.0" version = "0.331.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ce2d1779358cad2bc56d71176298767be628d707bb75585f6f8a4be2da8ccda1"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"az", "az",
"bincode", "bincode",
"bit-set", "bit-set 0.5.3",
"bit-vec", "bit-vec 0.6.3",
"bytes", "bytes",
"capacity_builder 0.1.3", "capacity_builder 0.1.3",
"cooked-waker", "cooked-waker",
@ -2152,8 +2154,6 @@ dependencies = [
[[package]] [[package]]
name = "deno_ops" name = "deno_ops"
version = "0.207.0" version = "0.207.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "96f000a21f6969b4c945bc8e9e785aa439f11ca4fd3fbddcd5bebc102167eb37"
dependencies = [ dependencies = [
"indexmap 2.3.0", "indexmap 2.3.0",
"proc-macro-rules", "proc-macro-rules",
@ -2392,7 +2392,7 @@ dependencies = [
"nix", "nix",
"os_pipe", "os_pipe",
"path-dedot", "path-dedot",
"thiserror 1.0.64", "thiserror 1.0.69",
"tokio", "tokio",
"windows-sys 0.59.0", "windows-sys 0.59.0",
] ]
@ -2533,8 +2533,10 @@ version = "0.153.0"
dependencies = [ dependencies = [
"deno_core", "deno_core",
"deno_error", "deno_error",
"indexmap 2.3.0",
"raw-window-handle", "raw-window-handle",
"serde", "serde",
"serde_json",
"thiserror 2.0.3", "thiserror 2.0.3",
"tokio", "tokio",
"wgpu-core", "wgpu-core",
@ -2864,9 +2866,9 @@ dependencies = [
[[package]] [[package]]
name = "document-features" name = "document-features"
version = "0.2.8" version = "0.2.10"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ef5282ad69563b5fc40319526ba27e0e7363d552a896f0297d54f767717f9b95" checksum = "cb6969eaabd2421f8a2775cfd2471a2b634372b4a25d41e3bd647b79912850a0"
dependencies = [ dependencies = [
"litrs", "litrs",
] ]
@ -3103,7 +3105,7 @@ dependencies = [
"debug-ignore", "debug-ignore",
"indexmap 2.3.0", "indexmap 2.3.0",
"log", "log",
"thiserror 1.0.64", "thiserror 1.0.69",
"zerocopy", "zerocopy",
] ]
@ -3250,7 +3252,7 @@ version = "0.10.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0678ab2d46fa5195aaf59ad034c083d351377d4af57f3e073c074d0da3e3c766" checksum = "0678ab2d46fa5195aaf59ad034c083d351377d4af57f3e073c074d0da3e3c766"
dependencies = [ dependencies = [
"bit-set", "bit-set 0.5.3",
"regex", "regex",
] ]
@ -3263,7 +3265,7 @@ dependencies = [
"anyhow", "anyhow",
"async-trait", "async-trait",
"log", "log",
"thiserror 1.0.64", "thiserror 1.0.69",
"tokio", "tokio",
"tokio-stream", "tokio-stream",
] ]
@ -3298,7 +3300,7 @@ dependencies = [
"rand", "rand",
"sha1", "sha1",
"simdutf8", "simdutf8",
"thiserror 1.0.64", "thiserror 1.0.69",
"tokio", "tokio",
"utf-8", "utf-8",
] ]
@ -3356,7 +3358,7 @@ dependencies = [
"deno_terminal 0.1.1", "deno_terminal 0.1.1",
"parking_lot", "parking_lot",
"regex", "regex",
"thiserror 1.0.64", "thiserror 1.0.69",
] ]
[[package]] [[package]]
@ -3705,9 +3707,9 @@ dependencies = [
[[package]] [[package]]
name = "glow" name = "glow"
version = "0.13.1" version = "0.14.2"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "bd348e04c43b32574f2de31c8bb397d96c9fcfa1371bd4ca6d8bdc464ab121b1" checksum = "d51fa363f025f5c111e03f13eda21162faeacb6911fe8caa0c0349f9cf0c4483"
dependencies = [ dependencies = [
"js-sys", "js-sys",
"slotmap", "slotmap",
@ -3717,9 +3719,9 @@ dependencies = [
[[package]] [[package]]
name = "glutin_wgl_sys" name = "glutin_wgl_sys"
version = "0.5.0" version = "0.6.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6c8098adac955faa2d31079b65dc48841251f69efd3ac25477903fc424362ead" checksum = "2c4ee00b289aba7a9e5306d57c2d05499b2e5dc427f84ac708bd2c090212cf3e"
dependencies = [ dependencies = [
"gl_generator", "gl_generator",
] ]
@ -3743,6 +3745,18 @@ dependencies = [
"bitflags 2.6.0", "bitflags 2.6.0",
] ]
[[package]]
name = "gpu-allocator"
version = "0.27.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c151a2a5ef800297b4e79efa4f4bec035c5f51d5ae587287c9b952bdf734cacd"
dependencies = [
"log",
"presser",
"thiserror 1.0.69",
"windows 0.58.0",
]
[[package]] [[package]]
name = "gpu-descriptor" name = "gpu-descriptor"
version = "0.3.0" version = "0.3.0"
@ -3843,7 +3857,7 @@ dependencies = [
"pest_derive", "pest_derive",
"serde", "serde",
"serde_json", "serde_json",
"thiserror 1.0.64", "thiserror 1.0.69",
] ]
[[package]] [[package]]
@ -4614,10 +4628,11 @@ dependencies = [
[[package]] [[package]]
name = "js-sys" name = "js-sys"
version = "0.3.69" version = "0.3.77"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "29c15563dc2726973df627357ce0c9ddddbea194836909d655df6a75d2cf296d" checksum = "1cfaf33c695fc6e08064efbc1f72ec937429614f25eef83af942d0e227c3a28f"
dependencies = [ dependencies = [
"once_cell",
"wasm-bindgen", "wasm-bindgen",
] ]
@ -4649,7 +4664,7 @@ dependencies = [
"anyhow", "anyhow",
"serde", "serde",
"serde_json", "serde_json",
"thiserror 1.0.64", "thiserror 1.0.69",
"uuid", "uuid",
] ]
@ -5023,9 +5038,9 @@ dependencies = [
[[package]] [[package]]
name = "metal" name = "metal"
version = "0.28.0" version = "0.29.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5637e166ea14be6063a3f8ba5ccb9a4159df7d8f6d61c02fc3d480b1f90dcfcb" checksum = "7ecfd3296f8c56b7c1f6fbac3c71cefa9d78ce009850c45000015f206dc7fa21"
dependencies = [ dependencies = [
"bitflags 2.6.0", "bitflags 2.6.0",
"block", "block",
@ -5091,7 +5106,7 @@ dependencies = [
"rustc_version 0.4.0", "rustc_version 0.4.0",
"smallvec", "smallvec",
"tagptr", "tagptr",
"thiserror 1.0.64", "thiserror 1.0.69",
"uuid", "uuid",
] ]
@ -5109,23 +5124,23 @@ checksum = "e5ce46fe64a9d73be07dcbe690a38ce1b293be448fd8ce1e6c1b8062c9f72c6a"
[[package]] [[package]]
name = "naga" name = "naga"
version = "0.20.0" version = "23.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e536ae46fcab0876853bd4a632ede5df4b1c2527a58f6c5a4150fe86be858231" checksum = "364f94bc34f61332abebe8cad6f6cd82a5b65cff22c828d05d0968911462ca4f"
dependencies = [ dependencies = [
"arrayvec", "arrayvec",
"bit-set", "bit-set 0.8.0",
"bitflags 2.6.0", "bitflags 2.6.0",
"cfg_aliases 0.1.1",
"codespan-reporting", "codespan-reporting",
"hexf-parse", "hexf-parse",
"indexmap 2.3.0", "indexmap 2.3.0",
"log", "log",
"num-traits",
"rustc-hash 1.1.0", "rustc-hash 1.1.0",
"serde", "serde",
"spirv", "spirv",
"termcolor", "termcolor",
"thiserror 1.0.64", "thiserror 1.0.69",
"unicode-xid", "unicode-xid",
] ]
@ -5424,7 +5439,7 @@ dependencies = [
"js-sys", "js-sys",
"once_cell", "once_cell",
"pin-project-lite", "pin-project-lite",
"thiserror 1.0.64", "thiserror 1.0.69",
] ]
[[package]] [[package]]
@ -5454,7 +5469,7 @@ dependencies = [
"opentelemetry_sdk", "opentelemetry_sdk",
"prost", "prost",
"serde_json", "serde_json",
"thiserror 1.0.64", "thiserror 1.0.69",
"tokio", "tokio",
"tonic", "tonic",
"tracing", "tracing",
@ -5496,7 +5511,7 @@ dependencies = [
"percent-encoding", "percent-encoding",
"rand", "rand",
"serde_json", "serde_json",
"thiserror 1.0.64", "thiserror 1.0.69",
"tracing", "tracing",
] ]
@ -5686,7 +5701,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "311fb059dee1a7b802f036316d790138c613a4e8b180c822e3925a662e9f0c95" checksum = "311fb059dee1a7b802f036316d790138c613a4e8b180c822e3925a662e9f0c95"
dependencies = [ dependencies = [
"memchr", "memchr",
"thiserror 1.0.64", "thiserror 1.0.69",
"ucd-trie", "ucd-trie",
] ]
@ -5905,6 +5920,12 @@ dependencies = [
"num-traits", "num-traits",
] ]
[[package]]
name = "presser"
version = "0.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e8cf8e6a8aa66ce33f63993ffc4ea4271eb5b0530a9002db8455ea6050c77bfa"
[[package]] [[package]]
name = "pretty_assertions" name = "pretty_assertions"
version = "1.4.0" version = "1.4.0"
@ -6116,7 +6137,7 @@ dependencies = [
"indexmap 2.3.0", "indexmap 2.3.0",
"quick-xml", "quick-xml",
"strip-ansi-escapes", "strip-ansi-escapes",
"thiserror 1.0.64", "thiserror 1.0.69",
"uuid", "uuid",
] ]
@ -6312,7 +6333,7 @@ checksum = "bd283d9651eeda4b2a83a43c1c91b266c40fd76ecd39a50a8c630ae69dc72891"
dependencies = [ dependencies = [
"getrandom", "getrandom",
"libredox", "libredox",
"thiserror 1.0.64", "thiserror 1.0.69",
] ]
[[package]] [[package]]
@ -6861,9 +6882,9 @@ checksum = "388a1df253eca08550bef6c72392cfe7c30914bf41df5269b68cbd6ff8f570a3"
[[package]] [[package]]
name = "serde" name = "serde"
version = "1.0.205" version = "1.0.217"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e33aedb1a7135da52b7c21791455563facbbcc43d0f0f66165b42c21b3dfb150" checksum = "02fc4265df13d6fa1d00ecff087228cc0a2b5f3c0e87e258d8b94a156e984c70"
dependencies = [ dependencies = [
"serde_derive", "serde_derive",
] ]
@ -6900,9 +6921,9 @@ dependencies = [
[[package]] [[package]]
name = "serde_derive" name = "serde_derive"
version = "1.0.205" version = "1.0.217"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "692d6f5ac90220161d6774db30c662202721e64aed9058d2c394f451261420c1" checksum = "5a9bf7cf98d04a2b28aead066b7496853d4779c9cc183c440dbac457641e19a0"
dependencies = [ dependencies = [
"proc-macro2", "proc-macro2",
"quote", "quote",
@ -6948,8 +6969,6 @@ dependencies = [
[[package]] [[package]]
name = "serde_v8" name = "serde_v8"
version = "0.240.0" version = "0.240.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "cd0494d74c40ab94f53a19485de359ea6a55f05341b817b93440b673c1ce8ec6"
dependencies = [ dependencies = [
"deno_error", "deno_error",
"num-bigint", "num-bigint",
@ -7988,11 +8007,11 @@ dependencies = [
[[package]] [[package]]
name = "thiserror" name = "thiserror"
version = "1.0.64" version = "1.0.69"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d50af8abc119fb8bb6dbabcfa89656f46f84aa0ac7688088608076ad2b459a84" checksum = "b6aaf5339b578ea85b50e080feb250a3e8ae8cfcdff9a461c9ec2904bc923f52"
dependencies = [ dependencies = [
"thiserror-impl 1.0.64", "thiserror-impl 1.0.69",
] ]
[[package]] [[package]]
@ -8006,9 +8025,9 @@ dependencies = [
[[package]] [[package]]
name = "thiserror-impl" name = "thiserror-impl"
version = "1.0.64" version = "1.0.69"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "08904e7672f5eb876eaaf87e0ce17857500934f4981c4a0ab2b4aa98baac7fc3" checksum = "4fee6c4efc90059e10f81e6d42c60a18f76588c3d74cb83a0b242a2b6c7504c1"
dependencies = [ dependencies = [
"proc-macro2", "proc-macro2",
"quote", "quote",
@ -8178,7 +8197,7 @@ checksum = "51165dfa029d2a65969413a6cc96f354b86b464498702f174a4efa13608fd8c0"
dependencies = [ dependencies = [
"either", "either",
"futures-util", "futures-util",
"thiserror 1.0.64", "thiserror 1.0.69",
"tokio", "tokio",
] ]
@ -8515,9 +8534,9 @@ checksum = "0336d538f7abc86d282a4189614dfaa90810dfc2c6f6427eaf88e16311dd225d"
[[package]] [[package]]
name = "unicode-xid" name = "unicode-xid"
version = "0.2.4" version = "0.2.6"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c" checksum = "ebc1c04c71510c7f702b52b7c350734c9ff1295c464a03335b00bb84fc54f853"
[[package]] [[package]]
name = "unicode_categories" name = "unicode_categories"
@ -8634,7 +8653,7 @@ dependencies = [
"indexmap 2.3.0", "indexmap 2.3.0",
"num-bigint", "num-bigint",
"serde", "serde",
"thiserror 1.0.64", "thiserror 1.0.69",
"wtf8", "wtf8",
] ]
@ -8729,23 +8748,24 @@ checksum = "b8dad83b4f25e74f184f64c43b150b91efe7647395b42289f38e50566d82855b"
[[package]] [[package]]
name = "wasm-bindgen" name = "wasm-bindgen"
version = "0.2.92" version = "0.2.100"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "4be2531df63900aeb2bca0daaaddec08491ee64ceecbee5076636a3b026795a8" checksum = "1edc8929d7499fc4e8f0be2262a241556cfc54a0bea223790e71446f2aab1ef5"
dependencies = [ dependencies = [
"cfg-if", "cfg-if",
"once_cell",
"rustversion",
"wasm-bindgen-macro", "wasm-bindgen-macro",
] ]
[[package]] [[package]]
name = "wasm-bindgen-backend" name = "wasm-bindgen-backend"
version = "0.2.92" version = "0.2.100"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "614d787b966d3989fa7bb98a654e369c762374fd3213d212cfc0251257e747da" checksum = "2f0a0651a5c2bc21487bde11ee802ccaf4c51935d0d3d42a6101f98161700bc6"
dependencies = [ dependencies = [
"bumpalo", "bumpalo",
"log", "log",
"once_cell",
"proc-macro2", "proc-macro2",
"quote", "quote",
"syn 2.0.87", "syn 2.0.87",
@ -8766,9 +8786,9 @@ dependencies = [
[[package]] [[package]]
name = "wasm-bindgen-macro" name = "wasm-bindgen-macro"
version = "0.2.92" version = "0.2.100"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a1f8823de937b71b9460c0c34e25f3da88250760bec0ebac694b49997550d726" checksum = "7fe63fc6d09ed3792bd0897b314f53de8e16568c2b3f7982f468c0bf9bd0b407"
dependencies = [ dependencies = [
"quote", "quote",
"wasm-bindgen-macro-support", "wasm-bindgen-macro-support",
@ -8776,9 +8796,9 @@ dependencies = [
[[package]] [[package]]
name = "wasm-bindgen-macro-support" name = "wasm-bindgen-macro-support"
version = "0.2.92" version = "0.2.100"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" checksum = "8ae87ea40c9f689fc23f209965b6fb8a99ad69aeeb0231408be24920604395de"
dependencies = [ dependencies = [
"proc-macro2", "proc-macro2",
"quote", "quote",
@ -8789,9 +8809,12 @@ dependencies = [
[[package]] [[package]]
name = "wasm-bindgen-shared" name = "wasm-bindgen-shared"
version = "0.2.92" version = "0.2.100"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96" checksum = "1a05d73b933a847d6cccdda8f838a22ff101ad9bf93e33684f39c1f5f0eece3d"
dependencies = [
"unicode-ident",
]
[[package]] [[package]]
name = "wasm-streams" name = "wasm-streams"
@ -8818,9 +8841,9 @@ dependencies = [
[[package]] [[package]]
name = "web-sys" name = "web-sys"
version = "0.3.69" version = "0.3.77"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "77afa9a11836342370f4817622a2f0f418b134426d91a82dfb48f532d2ec13ef" checksum = "33b6dd2ef9186f1f2072e409e99cd22a975331a6b3591b12c764e0e55c60d5d2"
dependencies = [ dependencies = [
"js-sys", "js-sys",
"wasm-bindgen", "wasm-bindgen",
@ -8856,15 +8879,14 @@ dependencies = [
[[package]] [[package]]
name = "wgpu-core" name = "wgpu-core"
version = "0.21.1" version = "23.0.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d50819ab545b867d8a454d1d756b90cd5f15da1f2943334ca314af10583c9d39" checksum = "d63c3c478de8e7e01786479919c8769f62a22eec16788d8c2ac77ce2c132778a"
dependencies = [ dependencies = [
"arrayvec", "arrayvec",
"bit-vec", "bit-vec 0.8.0",
"bitflags 2.6.0", "bitflags 2.6.0",
"cfg_aliases 0.1.1", "cfg_aliases 0.1.1",
"codespan-reporting",
"document-features", "document-features",
"indexmap 2.3.0", "indexmap 2.3.0",
"log", "log",
@ -8877,30 +8899,30 @@ dependencies = [
"rustc-hash 1.1.0", "rustc-hash 1.1.0",
"serde", "serde",
"smallvec", "smallvec",
"thiserror 1.0.64", "thiserror 1.0.69",
"web-sys",
"wgpu-hal", "wgpu-hal",
"wgpu-types", "wgpu-types",
] ]
[[package]] [[package]]
name = "wgpu-hal" name = "wgpu-hal"
version = "0.21.1" version = "23.0.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "172e490a87295564f3fcc0f165798d87386f6231b04d4548bca458cbbfd63222" checksum = "89364b8a0b211adc7b16aeaf1bd5ad4a919c1154b44c9ce27838213ba05fd821"
dependencies = [ dependencies = [
"android_system_properties", "android_system_properties",
"arrayvec", "arrayvec",
"ash", "ash",
"bit-set", "bit-set 0.8.0",
"bitflags 2.6.0", "bitflags 2.6.0",
"block", "block",
"bytemuck",
"cfg_aliases 0.1.1", "cfg_aliases 0.1.1",
"core-graphics-types", "core-graphics-types",
"d3d12",
"glow", "glow",
"glutin_wgl_sys", "glutin_wgl_sys",
"gpu-alloc", "gpu-alloc",
"gpu-allocator",
"gpu-descriptor", "gpu-descriptor",
"js-sys", "js-sys",
"khronos-egl", "khronos-egl",
@ -8918,18 +8940,19 @@ dependencies = [
"raw-window-handle", "raw-window-handle",
"rustc-hash 1.1.0", "rustc-hash 1.1.0",
"smallvec", "smallvec",
"thiserror 1.0.64", "thiserror 1.0.69",
"wasm-bindgen", "wasm-bindgen",
"web-sys", "web-sys",
"wgpu-types", "wgpu-types",
"winapi", "windows 0.58.0",
"windows-core 0.58.0",
] ]
[[package]] [[package]]
name = "wgpu-types" name = "wgpu-types"
version = "0.20.0" version = "23.0.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "1353d9a46bff7f955a680577f34c69122628cc2076e1d6f3a9be6ef00ae793ef" checksum = "610f6ff27778148c31093f3b03abc4840f9636d58d597ca2f5977433acfe0068"
dependencies = [ dependencies = [
"bitflags 2.6.0", "bitflags 2.6.0",
"js-sys", "js-sys",
@ -8972,7 +8995,7 @@ version = "2.0.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5b2b1bf557d947847a30eb73f79aa6cdb3eaf3ce02f5e9599438f77896a62b3c" checksum = "5b2b1bf557d947847a30eb73f79aa6cdb3eaf3ce02f5e9599438f77896a62b3c"
dependencies = [ dependencies = [
"thiserror 1.0.64", "thiserror 1.0.69",
"windows 0.52.0", "windows 0.52.0",
] ]
@ -9334,7 +9357,7 @@ dependencies = [
"nom 7.1.3", "nom 7.1.3",
"oid-registry", "oid-registry",
"rusticata-macros", "rusticata-macros",
"thiserror 1.0.64", "thiserror 1.0.69",
"time", "time",
] ]
@ -9478,7 +9501,7 @@ dependencies = [
"parking_lot", "parking_lot",
"rand", "rand",
"regex", "regex",
"thiserror 1.0.64", "thiserror 1.0.69",
"tokio", "tokio",
"tokio-util", "tokio-util",
"uuid", "uuid",
@ -9519,7 +9542,7 @@ dependencies = [
"flate2", "flate2",
"indexmap 2.3.0", "indexmap 2.3.0",
"memchr", "memchr",
"thiserror 1.0.64", "thiserror 1.0.69",
] ]
[[package]] [[package]]

View file

@ -690,9 +690,7 @@ ObjectDefineProperty(GPUQuerySet, customInspect, {
const GPUQuerySetPrototype = GPUQuerySet.prototype; const GPUQuerySetPrototype = GPUQuerySet.prototype;
// Converters // Converters
/*
// DICTIONARY: GPUPipelineErrorInit
webidl.converters["GPUPipelineErrorInit"] = webidl.createDictionaryConverter( webidl.converters["GPUPipelineErrorInit"] = webidl.createDictionaryConverter(
"GPUPipelineErrorInit", "GPUPipelineErrorInit",
[ [
@ -704,7 +702,6 @@ webidl.converters["GPUPipelineErrorInit"] = webidl.createDictionaryConverter(
], ],
); );
// ENUM: GPUPipelineErrorReason
webidl.converters["GPUPipelineErrorReason"] = webidl.createEnumConverter( webidl.converters["GPUPipelineErrorReason"] = webidl.createEnumConverter(
"GPUPipelineErrorReason", "GPUPipelineErrorReason",
[ [
@ -713,16 +710,8 @@ webidl.converters["GPUPipelineErrorReason"] = webidl.createEnumConverter(
], ],
); );
// TYPEDEF: GPUError webidl.converters["GPUError"] = webidl.converters.any /* put union here! */;
webidl.converters["GPUError"] = webidl.converters.any /!** put union here! **!/;
// // INTERFACE: GPUUncapturedErrorEvent
// webidl.converters.GPUUncapturedErrorEvent = webidl.createInterfaceConverter(
// "GPUUncapturedErrorEvent",
// GPUUncapturedErrorEvent.prototype,
// );
// DICTIONARY: GPUUncapturedErrorEventInit
const dictMembersGPUUncapturedErrorEventInit = [ const dictMembersGPUUncapturedErrorEventInit = [
{ key: "error", converter: webidl.converters["GPUError"], required: true }, { key: "error", converter: webidl.converters["GPUError"], required: true },
]; ];
@ -733,71 +722,6 @@ webidl.converters["GPUUncapturedErrorEventInit"] = webidl
dictMembersGPUUncapturedErrorEventInit, dictMembersGPUUncapturedErrorEventInit,
); );
// BYOW
// ENUM: GPUCanvasAlphaMode
webidl.converters["GPUCanvasAlphaMode"] = webidl.createEnumConverter(
"GPUCanvasAlphaMode",
[
"opaque",
"premultiplied",
],
);
// NON-SPEC: ENUM: GPUPresentMode
webidl.converters["GPUPresentMode"] = webidl.createEnumConverter(
"GPUPresentMode",
[
"autoVsync",
"autoNoVsync",
"fifo",
"fifoRelaxed",
"immediate",
"mailbox",
],
);
// DICT: GPUCanvasConfiguration
const dictMembersGPUCanvasConfiguration = [
{ key: "device", converter: webidl.converters.GPUDevice, required: true },
{
key: "format",
converter: webidl.converters.GPUTextureFormat,
required: true,
},
{
key: "usage",
converter: webidl.converters["GPUTextureUsageFlags"],
defaultValue: GPUTextureUsage.RENDER_ATTACHMENT,
},
{
key: "alphaMode",
converter: webidl.converters["GPUCanvasAlphaMode"],
defaultValue: "opaque",
},
// Extended from spec
{
key: "presentMode",
converter: webidl.converters["GPUPresentMode"],
},
{
key: "viewFormats",
converter: webidl.createSequenceConverter(
webidl.converters["GPUTextureFormat"],
),
get defaultValue() {
return [];
},
},
];
webidl.converters["GPUCanvasConfiguration"] = webidl
.createDictionaryConverter(
"GPUCanvasConfiguration",
dictMembersGPUCanvasConfiguration,
);
*/
let gpu; let gpu;
function initGPU() { function initGPU() {
if (!gpu) { if (!gpu) {

View file

@ -7,146 +7,16 @@
/// <reference path="./lib.deno_webgpu.d.ts" /> /// <reference path="./lib.deno_webgpu.d.ts" />
import { primordials } from "ext:core/mod.js"; import { primordials } from "ext:core/mod.js";
import { import { GPUCanvasContext, UnsafeWindowSurface } from "ext:core/ops";
op_webgpu_surface_configure,
op_webgpu_surface_create,
op_webgpu_surface_get_current_texture,
op_webgpu_surface_present,
} from "ext:core/ops";
const { const {
ObjectDefineProperty,
ObjectPrototypeIsPrototypeOf, ObjectPrototypeIsPrototypeOf,
Symbol,
SymbolFor, SymbolFor,
TypeError,
} = primordials; } = primordials;
import * as webidl from "ext:deno_webidl/00_webidl.js";
import { createFilteredInspectProxy } from "ext:deno_console/01_console.js"; import { createFilteredInspectProxy } from "ext:deno_console/01_console.js";
import { loadWebGPU } from "ext:deno_webgpu/00_init.js";
const _surfaceRid = Symbol("[[surfaceRid]]"); ObjectDefineProperty(GPUCanvasContext, SymbolFor("Deno.privateCustomInspect"), {
const _configuration = Symbol("[[configuration]]"); value(inspect, inspectOptions) {
const _canvas = Symbol("[[canvas]]");
const _currentTexture = Symbol("[[currentTexture]]");
const _present = Symbol("[[present]]");
const _dim = Symbol("[[dimensions]]");
class GPUCanvasContext {
/** @type {number} */
[_surfaceRid];
[_configuration];
[_canvas];
/** @type {GPUTexture | undefined} */
[_currentTexture];
[_dim];
get canvas() {
webidl.assertBranded(this, GPUCanvasContextPrototype);
return this[_canvas];
}
constructor() {
webidl.illegalConstructor();
}
configure(configuration) {
webidl.assertBranded(this, GPUCanvasContextPrototype);
const prefix = "Failed to execute 'configure' on 'GPUCanvasContext'";
webidl.requiredArguments(arguments.length, 1, { prefix });
configuration = webidl.converters.GPUCanvasConfiguration(configuration, {
prefix,
context: "Argument 1",
});
const { _device, assertDevice } = loadWebGPU();
this[_device] = configuration.device[_device];
this[_configuration] = configuration;
const device = assertDevice(this, {
prefix,
context: "configuration.device",
});
const { err } = op_webgpu_surface_configure({
surfaceRid: this[_surfaceRid],
deviceRid: device.rid,
format: configuration.format,
viewFormats: configuration.viewFormats,
usage: configuration.usage,
width: this[_dim].width,
height: this[_dim].height,
alphaMode: configuration.alphaMode,
});
device.pushError(err);
}
unconfigure() {
const { _device } = loadWebGPU();
webidl.assertBranded(this, GPUCanvasContextPrototype);
this[_configuration] = null;
this[_device] = null;
}
getCurrentTexture() {
webidl.assertBranded(this, GPUCanvasContextPrototype);
const prefix =
"Failed to execute 'getCurrentTexture' on 'GPUCanvasContext'";
if (this[_configuration] === null) {
throw new DOMException("Context is not configured", "InvalidStateError");
}
const { createGPUTexture, assertDevice } = loadWebGPU();
const device = assertDevice(this, { prefix, context: "this" });
if (this[_currentTexture]) {
return this[_currentTexture];
}
const { rid } = op_webgpu_surface_get_current_texture(
device.rid,
this[_surfaceRid],
);
const texture = createGPUTexture(
{
size: {
width: this[_dim].width,
height: this[_dim].height,
depthOrArrayLayers: 1,
},
mipLevelCount: 1,
sampleCount: 1,
dimension: "2d",
format: this[_configuration].format,
usage: this[_configuration].usage,
},
device,
rid,
);
device.trackResource(texture);
this[_currentTexture] = texture;
return texture;
}
// Required to present the texture; browser don't need this.
[_present]() {
const { assertDevice } = loadWebGPU();
webidl.assertBranded(this, GPUCanvasContextPrototype);
const prefix = "Failed to execute 'present' on 'GPUCanvasContext'";
const device = assertDevice(this[_currentTexture], {
prefix,
context: "this",
});
op_webgpu_surface_present(device.rid, this[_surfaceRid]);
this[_currentTexture].destroy();
this[_currentTexture] = undefined;
}
[SymbolFor("Deno.privateCustomInspect")](inspect, inspectOptions) {
return inspect( return inspect(
createFilteredInspectProxy({ createFilteredInspectProxy({
object: this, object: this,
@ -157,60 +27,8 @@ class GPUCanvasContext {
}), }),
inspectOptions, inspectOptions,
); );
} },
} });
const GPUCanvasContextPrototype = GPUCanvasContext.prototype; const GPUCanvasContextPrototype = GPUCanvasContext.prototype;
function createCanvasContext(options) {
// lazy load webgpu if needed
const canvasContext = webidl.createBranded(GPUCanvasContext);
canvasContext[_surfaceRid] = options.surfaceRid;
canvasContext[_canvas] = options.canvas;
canvasContext[_dim] = { width: options.width, height: options.height };
return canvasContext;
}
// External webgpu surfaces
// TODO(@littledivy): This will extend `OffscreenCanvas` when we add it.
class UnsafeWindowSurface {
#ctx;
#surfaceRid;
#options;
constructor(options) {
if (typeof options !== "object") {
throw new TypeError("options must be provided.");
}
if (
typeof options.width !== "number" || typeof options.height !== "number"
) {
throw new TypeError("width and height must be provided.");
}
this.#surfaceRid = op_webgpu_surface_create(
options.system,
options.windowHandle,
options.displayHandle,
);
this.#options = options;
}
getContext(context) {
if (context !== "webgpu") {
throw new TypeError("Only 'webgpu' context is supported");
}
this.#ctx = createCanvasContext({
surfaceRid: this.#surfaceRid,
...this.#options,
});
return this.#ctx;
}
present() {
this.#ctx[_present]();
}
}
export { GPUCanvasContext, UnsafeWindowSurface }; export { GPUCanvasContext, UnsafeWindowSurface };

View file

@ -1,5 +1,4 @@
// Copyright 2018-2025 the Deno authors. MIT license. use std::cell::RefCell;
use std::ffi::c_void; use std::ffi::c_void;
#[cfg(any( #[cfg(any(
target_os = "linux", target_os = "linux",
@ -9,11 +8,17 @@ use std::ffi::c_void;
))] ))]
use std::ptr::NonNull; use std::ptr::NonNull;
use deno_core::cppgc::SameObject;
use deno_core::op2; use deno_core::op2;
use deno_core::v8;
use deno_core::v8::Local;
use deno_core::v8::Value;
use deno_core::FromV8;
use deno_core::GarbageCollected;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ResourceId; use deno_error::JsErrorBox;
use crate::surface::WebGpuSurface; use crate::surface::GPUCanvasContext;
#[derive(Debug, thiserror::Error, deno_error::JsError)] #[derive(Debug, thiserror::Error, deno_error::JsError)]
pub enum ByowError { pub enum ByowError {
@ -65,21 +70,33 @@ pub enum ByowError {
NSViewDisplay, NSViewDisplay,
} }
#[op2(fast)] // TODO(@littledivy): This will extend `OffscreenCanvas` when we add it.
#[smi] pub struct UnsafeWindowSurface {
pub fn op_webgpu_surface_create( pub id: wgpu_core::id::SurfaceId,
pub width: RefCell<u32>,
pub height: RefCell<u32>,
pub context: SameObject<GPUCanvasContext>,
}
impl GarbageCollected for UnsafeWindowSurface {}
#[op2]
impl UnsafeWindowSurface {
#[constructor]
#[cppgc]
fn new(
state: &mut OpState, state: &mut OpState,
#[string] system: &str, #[from_v8] options: UnsafeWindowSurfaceOptions,
p1: *const c_void, ) -> Result<UnsafeWindowSurface, ByowError> {
p2: *const c_void,
) -> Result<ResourceId, ByowError> {
let instance = state let instance = state
.try_borrow::<super::Instance>() .try_borrow::<super::Instance>()
.ok_or(ByowError::WebGPUNotInitiated)?; .ok_or(ByowError::WebGPUNotInitiated)?;
// Security note: // Security note:
// //
// The `p1` and `p2` parameters are pointers to platform-specific window // The `window_handle` and `display_handle` options are pointers to
// handles. // platform-specific window handles.
// //
// The code below works under the assumption that: // The code below works under the assumption that:
// //
@ -89,22 +106,120 @@ pub fn op_webgpu_surface_create(
// - `*const c_void` deserizalizes null and v8::External. // - `*const c_void` deserizalizes null and v8::External.
// //
// - Only FFI can export v8::External to user code. // - Only FFI can export v8::External to user code.
if p1.is_null() { if options.window_handle.is_null() {
return Err(ByowError::InvalidParameters); return Err(ByowError::InvalidParameters);
} }
let (win_handle, display_handle) = raw_window(system, p1, p2)?; let (win_handle, display_handle) = raw_window(
options.system,
options.window_handle,
options.display_handle,
)?;
// SAFETY: see above comment // SAFETY: see above comment
let surface = unsafe { let id = unsafe {
instance instance
.instance_create_surface(display_handle, win_handle, None) .instance_create_surface(display_handle, win_handle, None)
.map_err(ByowError::CreateSurface)? .map_err(ByowError::CreateSurface)?
}; };
let rid = state Ok(UnsafeWindowSurface {
.resource_table id,
.add(WebGpuSurface(instance.clone(), surface)); width: RefCell::new(options.width),
Ok(rid) height: RefCell::new(options.height),
context: SameObject::new(),
})
}
#[global]
fn get_context(&self, scope: &mut v8::HandleScope) -> v8::Global<v8::Object> {
self.context.get(scope, |_| GPUCanvasContext {
surface_id: self.id,
width: self.width.clone(),
height: self.height.clone(),
config: RefCell::new(None),
texture: RefCell::new(None),
})
}
#[nofast]
fn present(&self, scope: &mut v8::HandleScope) -> Result<(), JsErrorBox> {
let Some(context) = self.context.value(scope) else {
return Err(JsErrorBox::type_error("getContext was never called"));
};
context.present().map_err(JsErrorBox::from_err)
}
}
struct UnsafeWindowSurfaceOptions {
system: UnsafeWindowSurfaceSystem,
window_handle: *const c_void,
display_handle: *const c_void,
width: u32,
height: u32,
}
#[derive(Eq, PartialEq)]
enum UnsafeWindowSurfaceSystem {
Cocoa,
Win32,
X11,
Wayland,
}
impl<'a> FromV8<'a> for UnsafeWindowSurfaceOptions {
type Error = JsErrorBox;
fn from_v8(
scope: &mut v8::HandleScope<'a>,
value: Local<'a, Value>,
) -> Result<Self, Self::Error> {
let obj = value.try_cast::<v8::Object>().unwrap();
let key = v8::String::new(scope, "system").unwrap();
let val = obj.get(scope, key.into()).unwrap();
let s = String::from_v8(scope, val).unwrap();
let system = match s.as_str() {
"cocoa" => UnsafeWindowSurfaceSystem::Cocoa,
"win32" => UnsafeWindowSurfaceSystem::Win32,
"x11" => UnsafeWindowSurfaceSystem::X11,
"wayland" => UnsafeWindowSurfaceSystem::Wayland,
_ => {
return Err(JsErrorBox::type_error(format!(
"Invalid system kind '{s}'"
)))
}
};
let key = v8::String::new(scope, "windowHandle").unwrap();
let val = obj.get(scope, key.into()).unwrap();
let Some(window_handle) = deno_core::_ops::to_external_option(&val) else {
return Err(JsErrorBox::type_error("expected external"));
};
let key = v8::String::new(scope, "displayHandle").unwrap();
let val = obj.get(scope, key.into()).unwrap();
let Some(display_handle) = deno_core::_ops::to_external_option(&val) else {
return Err(JsErrorBox::type_error("expected external"));
};
let key = v8::String::new(scope, "width").unwrap();
let val = obj.get(scope, key.into()).unwrap();
let width = deno_core::convert::Number::<u32>::from_v8(scope, val)?.0;
let key = v8::String::new(scope, "height").unwrap();
let val = obj.get(scope, key.into()).unwrap();
let height = deno_core::convert::Number::<u32>::from_v8(scope, val)?.0;
Ok(Self {
system,
window_handle,
display_handle,
width,
height,
})
}
} }
type RawHandles = ( type RawHandles = (
@ -114,11 +229,11 @@ type RawHandles = (
#[cfg(target_os = "macos")] #[cfg(target_os = "macos")]
fn raw_window( fn raw_window(
system: &str, system: UnsafeWindowSurfaceSystem,
_ns_window: *const c_void, _ns_window: *const c_void,
ns_view: *const c_void, ns_view: *const c_void,
) -> Result<RawHandles, ByowError> { ) -> Result<RawHandles, ByowError> {
if system != "cocoa" { if system != UnsafeWindowSurfaceSystem::Cocoa {
return Err(ByowError::InvalidSystem); return Err(ByowError::InvalidSystem);
} }
@ -136,12 +251,12 @@ fn raw_window(
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
fn raw_window( fn raw_window(
system: &str, system: UnsafeWindowSurfaceSystem,
window: *const c_void, window: *const c_void,
hinstance: *const c_void, hinstance: *const c_void,
) -> Result<RawHandles, ByowError> { ) -> Result<RawHandles, ByowError> {
use raw_window_handle::WindowsDisplayHandle; use raw_window_handle::WindowsDisplayHandle;
if system != "win32" { if system != UnsafeWindowSurfaceSystem::Win32 {
return Err(ByowError::InvalidSystem); return Err(ByowError::InvalidSystem);
} }
@ -162,12 +277,12 @@ fn raw_window(
#[cfg(any(target_os = "linux", target_os = "freebsd", target_os = "openbsd"))] #[cfg(any(target_os = "linux", target_os = "freebsd", target_os = "openbsd"))]
fn raw_window( fn raw_window(
system: &str, system: UnsafeWindowSurfaceSystem,
window: *const c_void, window: *const c_void,
display: *const c_void, display: *const c_void,
) -> Result<RawHandles, ByowError> { ) -> Result<RawHandles, ByowError> {
let (win_handle, display_handle); let (win_handle, display_handle);
if system == "x11" { if system == UnsafeWindowSurfaceSystem::X11 {
win_handle = raw_window_handle::RawWindowHandle::Xlib( win_handle = raw_window_handle::RawWindowHandle::Xlib(
raw_window_handle::XlibWindowHandle::new(window as *mut c_void as _), raw_window_handle::XlibWindowHandle::new(window as *mut c_void as _),
); );
@ -178,7 +293,7 @@ fn raw_window(
0, 0,
), ),
); );
} else if system == "wayland" { } else if system == UnsafeWindowSurfaceSystem::Wayland {
win_handle = raw_window_handle::RawWindowHandle::Wayland( win_handle = raw_window_handle::RawWindowHandle::Wayland(
raw_window_handle::WaylandWindowHandle::new( raw_window_handle::WaylandWindowHandle::new(
NonNull::new(window as *mut c_void).ok_or(ByowError::NullWindow)?, NonNull::new(window as *mut c_void).ok_or(ByowError::NullWindow)?,
@ -205,7 +320,7 @@ fn raw_window(
target_os = "openbsd", target_os = "openbsd",
)))] )))]
fn raw_window( fn raw_window(
_system: &str, _system: UnsafeWindowSurfaceSystem,
_window: *const c_void, _window: *const c_void,
_display: *const c_void, _display: *const c_void,
) -> Result<RawHandles, deno_error::JsErrorBox> { ) -> Result<RawHandles, deno_error::JsErrorBox> {

View file

@ -6,6 +6,7 @@ use std::rc::Rc;
use deno_core::cppgc::SameObject; use deno_core::cppgc::SameObject;
use deno_core::op2; use deno_core::op2;
use deno_core::v8; use deno_core::v8;
use deno_core::webidl::WebIdlInterfaceConverter;
use deno_core::GarbageCollected; use deno_core::GarbageCollected;
use deno_error::JsErrorBox; use deno_error::JsErrorBox;
use wgpu_core::binding_model::BindingResource; use wgpu_core::binding_model::BindingResource;
@ -57,6 +58,10 @@ impl Drop for GPUDevice {
} }
} }
impl WebIdlInterfaceConverter for GPUDevice {
const NAME: &'static str = "GPUDevice";
}
impl GarbageCollected for GPUDevice {} impl GarbageCollected for GPUDevice {}
// TODO: extend EventTarget // TODO: extend EventTarget

View file

@ -18,6 +18,7 @@ mod adapter;
mod bind_group; mod bind_group;
mod bind_group_layout; mod bind_group_layout;
mod buffer; mod buffer;
mod byow;
mod command_buffer; mod command_buffer;
mod command_encoder; mod command_encoder;
mod compute_pass; mod compute_pass;
@ -32,14 +33,12 @@ mod render_pass;
mod render_pipeline; mod render_pipeline;
mod sampler; mod sampler;
mod shader; mod shader;
mod surface;
mod texture; mod texture;
mod webidl; mod webidl;
pub const UNSTABLE_FEATURE_NAME: &str = "webgpu"; pub const UNSTABLE_FEATURE_NAME: &str = "webgpu";
//pub mod byow;
//pub mod surface;
pub type Instance = Arc<wgpu_core::global::Global>; pub type Instance = Arc<wgpu_core::global::Global>;
deno_core::extension!( deno_core::extension!(
@ -72,8 +71,10 @@ deno_core::extension!(
adapter::GPUSupportedLimits, adapter::GPUSupportedLimits,
texture::GPUTexture, texture::GPUTexture,
texture::GPUTextureView, texture::GPUTextureView,
byow::UnsafeWindowSurface,
surface::GPUCanvasContext,
], ],
esm = ["00_init.js"], esm = ["00_init.js", "02_surface.js"],
lazy_loaded_esm = ["01_webgpu.js"], lazy_loaded_esm = ["01_webgpu.js"],
); );

View file

@ -1,146 +1,229 @@
// Copyright 2018-2025 the Deno authors. MIT license. use std::cell::RefCell;
use std::borrow::Cow;
use std::rc::Rc;
use deno_core::error::ResourceError;
use deno_core::op2; use deno_core::op2;
use deno_core::OpState; use deno_core::v8;
use deno_core::Resource; use deno_core::GarbageCollected;
use deno_core::ResourceId; use deno_core::WebIDL;
use deno_core::_ops::make_cppgc_object;
use deno_core::cppgc::Ptr;
use deno_error::JsErrorBox; use deno_error::JsErrorBox;
use serde::Deserialize;
use wgpu_types::SurfaceStatus; use wgpu_types::SurfaceStatus;
use crate::error::WebGpuResult; use crate::device::GPUDevice;
use crate::texture::GPUTexture;
use crate::texture::GPUTextureFormat;
#[derive(Debug, thiserror::Error, deno_error::JsError)] #[derive(Debug, thiserror::Error, deno_error::JsError)]
pub enum SurfaceError { pub enum SurfaceError {
#[class(inherit)] #[class("DOMExceptionInvalidStateError")]
#[error(transparent)] #[error("Context is not configured")]
Resource( UnconfiguredContext,
#[from]
#[inherit]
ResourceError,
),
#[class(generic)] #[class(generic)]
#[error("Invalid Surface Status")] #[error("Invalid Surface Status")]
InvalidStatus, InvalidStatus,
#[class(generic)] #[class(generic)]
#[error(transparent)] #[error(transparent)]
Surface(wgpu_core::present::SurfaceError), Surface(#[from] wgpu_core::present::SurfaceError),
} }
pub struct WebGpuSurface(pub crate::Instance, pub wgpu_core::id::SurfaceId); pub struct Configuration {
impl Resource for WebGpuSurface { pub device: Ptr<GPUDevice>,
fn name(&self) -> Cow<str> { pub usage: u32,
"webGPUSurface".into() pub format: GPUTextureFormat,
} }
fn close(self: Rc<Self>) { pub struct GPUCanvasContext {
self.0.surface_drop(self.1); pub surface_id: wgpu_core::id::SurfaceId,
} pub width: RefCell<u32>,
pub height: RefCell<u32>,
pub config: RefCell<Option<Configuration>>,
pub texture: RefCell<Option<v8::Global<v8::Object>>>,
} }
#[derive(Deserialize)] impl GarbageCollected for GPUCanvasContext {}
#[serde(rename_all = "camelCase")]
pub struct SurfaceConfigureArgs {
surface_rid: ResourceId,
device_rid: ResourceId,
format: wgpu_types::TextureFormat,
usage: u32,
width: u32,
height: u32,
present_mode: Option<wgpu_types::PresentMode>,
alpha_mode: wgpu_types::CompositeAlphaMode,
view_formats: Vec<wgpu_types::TextureFormat>,
}
#[op2] #[op2]
#[serde] impl GPUCanvasContext {
pub fn op_webgpu_surface_configure( #[getter]
state: &mut OpState, #[global]
#[serde] args: SurfaceConfigureArgs, fn canvas(&self) -> v8::Global<v8::Value> {
) -> Result<WebGpuResult, ResourceError> { todo!()
let instance = state.borrow::<super::Instance>(); }
let device_resource = state
.resource_table
.get::<super::WebGpuDevice>(args.device_rid)?;
let device = device_resource.1;
let surface_resource = state
.resource_table
.get::<WebGpuSurface>(args.surface_rid)?;
let surface = surface_resource.1;
let conf = wgpu_types::SurfaceConfiguration::<Vec<wgpu_types::TextureFormat>> { fn configure(
usage: wgpu_types::TextureUsages::from_bits(args.usage) &self,
.ok_or_else(|| JsErrorBox::type_error("usage is not valid"))?, #[webidl] configuration: GPUCanvasConfiguration,
format: args.format, ) -> Result<(), JsErrorBox> {
width: args.width, let usage = wgpu_types::TextureUsages::from_bits(configuration.usage)
height: args.height, .ok_or_else(|| JsErrorBox::type_error("usage is not valid"))?;
present_mode: args.present_mode.unwrap_or_default(), let format = configuration.format.clone().into();
alpha_mode: args.alpha_mode, let conf = wgpu_types::SurfaceConfiguration {
view_formats: args.view_formats, usage,
format,
width: *self.width.borrow(),
height: *self.height.borrow(),
present_mode: configuration
.present_mode
.map(Into::into)
.unwrap_or_default(),
alpha_mode: configuration.alpha_mode.into(),
view_formats: configuration
.view_formats
.into_iter()
.map(Into::into)
.collect(),
desired_maximum_frame_latency: 2, desired_maximum_frame_latency: 2,
}; };
let err = let device = configuration.device;
gfx_select!(device => instance.surface_configure(surface, device, &conf));
Ok(WebGpuResult::maybe_err(err)) let err =
device
.instance
.surface_configure(self.surface_id, device.id, &conf);
device.error_handler.push_error(err);
self.config.borrow_mut().replace(Configuration {
device,
usage: configuration.usage,
format: configuration.format,
});
Ok(())
} }
#[op2] #[fast]
#[serde] fn unconfigure(&self) {
pub fn op_webgpu_surface_get_current_texture( *self.config.borrow_mut() = None;
state: &mut OpState, }
#[smi] device_rid: ResourceId,
#[smi] surface_rid: ResourceId,
) -> Result<WebGpuResult, SurfaceError> {
let instance = state.borrow::<super::Instance>();
let device_resource = state
.resource_table
.get::<super::WebGpuDevice>(device_rid)?;
let device = device_resource.1;
let surface_resource =
state.resource_table.get::<WebGpuSurface>(surface_rid)?;
let surface = surface_resource.1;
let output = #[global]
gfx_select!(device => instance.surface_get_current_texture(surface, None)) fn get_current_texture(
.map_err(SurfaceError::Surface)?; &self,
scope: &mut v8::HandleScope,
) -> Result<v8::Global<v8::Object>, SurfaceError> {
let config = self.config.borrow();
let Some(config) = config.as_ref() else {
return Err(SurfaceError::UnconfiguredContext);
};
{
if let Some(obj) = self.texture.borrow().as_ref() {
return Ok(obj.clone());
}
}
let output = config
.device
.instance
.surface_get_current_texture(self.surface_id, None)?;
match output.status { match output.status {
SurfaceStatus::Good | SurfaceStatus::Suboptimal => { SurfaceStatus::Good | SurfaceStatus::Suboptimal => {
let id = output.texture_id.unwrap(); let id = output.texture_id.unwrap();
let rid = state.resource_table.add(crate::texture::WebGpuTexture {
instance: instance.clone(), let texture = GPUTexture {
instance: config.device.instance.clone(),
error_handler: config.device.error_handler.clone(),
id, id,
owned: false, label: "".to_string(),
}); size: wgpu_types::Extent3d {
Ok(WebGpuResult::rid(rid)) width: *self.width.borrow(),
height: *self.height.borrow(),
depth_or_array_layers: 1,
},
mip_level_count: 0,
sample_count: 0,
dimension: crate::texture::GPUTextureDimension::D2,
format: config.format.clone(),
usage: config.usage,
};
let obj = make_cppgc_object(scope, texture);
let obj = v8::Global::new(scope, obj);
*self.texture.borrow_mut() = Some(obj.clone());
Ok(obj)
} }
_ => Err(SurfaceError::InvalidStatus), _ => Err(SurfaceError::InvalidStatus),
} }
} }
}
#[op2(fast)] impl GPUCanvasContext {
pub fn op_webgpu_surface_present( pub fn present(&self) -> Result<(), SurfaceError> {
state: &mut OpState, let config = self.config.borrow();
#[smi] device_rid: ResourceId, let Some(config) = config.as_ref() else {
#[smi] surface_rid: ResourceId, return Err(SurfaceError::UnconfiguredContext);
) -> Result<(), SurfaceError> { };
let instance = state.borrow::<super::Instance>();
let device_resource = state
.resource_table
.get::<super::WebGpuDevice>(device_rid)?;
let device = device_resource.1;
let surface_resource =
state.resource_table.get::<WebGpuSurface>(surface_rid)?;
let surface = surface_resource.1;
let _ = gfx_select!(device => instance.surface_present(surface)) config.device.instance.surface_present(self.surface_id)?;
.map_err(SurfaceError::Surface)?;
Ok(()) Ok(())
} }
}
#[derive(WebIDL)]
#[webidl(dictionary)]
struct GPUCanvasConfiguration {
device: Ptr<GPUDevice>,
format: GPUTextureFormat,
#[webidl(default = wgpu_types::TextureUsages::RENDER_ATTACHMENT.bits())]
#[options(enforce_range = true)]
usage: u32,
#[webidl(default = GPUCanvasAlphaMode::Opaque)]
alpha_mode: GPUCanvasAlphaMode,
// Extended from spec
present_mode: Option<GPUPresentMode>,
#[webidl(default = vec![])]
view_formats: Vec<GPUTextureFormat>,
}
#[derive(WebIDL)]
#[webidl(enum)]
enum GPUCanvasAlphaMode {
Opaque,
Premultiplied,
}
impl From<GPUCanvasAlphaMode> for wgpu_types::CompositeAlphaMode {
fn from(value: GPUCanvasAlphaMode) -> Self {
match value {
GPUCanvasAlphaMode::Opaque => Self::Opaque,
GPUCanvasAlphaMode::Premultiplied => Self::PreMultiplied,
}
}
}
// Extended from spec
#[derive(WebIDL)]
#[webidl(enum)]
enum GPUPresentMode {
#[webidl(rename = "autoVsync")]
AutoVsync,
#[webidl(rename = "autoNoVsync")]
AutoNoVsync,
#[webidl(rename = "fifo")]
Fifo,
#[webidl(rename = "fifoRelaxed")]
FifoRelaxed,
#[webidl(rename = "immediate")]
Immediate,
#[webidl(rename = "mailbox")]
Mailbox,
}
impl From<GPUPresentMode> for wgpu_types::PresentMode {
fn from(value: GPUPresentMode) -> Self {
match value {
GPUPresentMode::AutoVsync => Self::AutoVsync,
GPUPresentMode::AutoNoVsync => Self::AutoNoVsync,
GPUPresentMode::Fifo => Self::Fifo,
GPUPresentMode::FifoRelaxed => Self::FifoRelaxed,
GPUPresentMode::Immediate => Self::Immediate,
GPUPresentMode::Mailbox => Self::Mailbox,
}
}
}

View file

@ -28,7 +28,7 @@ import * as signals from "ext:deno_os/40_signals.js";
import * as tty from "ext:runtime/40_tty.js"; import * as tty from "ext:runtime/40_tty.js";
import * as kv from "ext:deno_kv/01_db.ts"; import * as kv from "ext:deno_kv/01_db.ts";
import * as cron from "ext:deno_cron/01_cron.ts"; import * as cron from "ext:deno_cron/01_cron.ts";
//import * as webgpuSurface from "ext:deno_webgpu/02_surface.js"; import * as webgpuSurface from "ext:deno_webgpu/02_surface.js";
import * as telemetry from "ext:deno_telemetry/telemetry.ts"; import * as telemetry from "ext:deno_telemetry/telemetry.ts";
const { ObjectDefineProperties } = primordials; const { ObjectDefineProperties } = primordials;
@ -203,7 +203,7 @@ ObjectDefineProperties(denoNsUnstableById[unstableIds.net], {
// denoNsUnstableById[unstableIds.unsafeProto] = { __proto__: null } // denoNsUnstableById[unstableIds.unsafeProto] = { __proto__: null }
denoNsUnstableById[unstableIds.webgpu] = { denoNsUnstableById[unstableIds.webgpu] = {
//UnsafeWindowSurface: webgpuSurface.UnsafeWindowSurface, UnsafeWindowSurface: webgpuSurface.UnsafeWindowSurface,
}; };
// denoNsUnstableById[unstableIds.workerOptions] = { __proto__: null } // denoNsUnstableById[unstableIds.workerOptions] = { __proto__: null }

View file

@ -35,7 +35,7 @@ import process from "node:process";
import { Buffer } from "node:buffer"; import { Buffer } from "node:buffer";
import { clearImmediate, setImmediate } from "node:timers"; import { clearImmediate, setImmediate } from "node:timers";
import { loadWebGPU } from "ext:deno_webgpu/00_init.js"; import { loadWebGPU } from "ext:deno_webgpu/00_init.js";
//import * as webgpuSurface from "ext:deno_webgpu/02_surface.js"; import * as webgpuSurface from "ext:deno_webgpu/02_surface.js";
import { unstableIds } from "ext:runtime/90_deno_ns.js"; import { unstableIds } from "ext:runtime/90_deno_ns.js";
const loadImage = core.createLazyLoader("ext:deno_canvas/01_image.js"); const loadImage = core.createLazyLoader("ext:deno_canvas/01_image.js");
@ -164,7 +164,7 @@ const windowOrWorkerGlobalScope = {
(webgpu) => webgpu.GPUBufferUsage, (webgpu) => webgpu.GPUBufferUsage,
loadWebGPU, loadWebGPU,
), ),
//GPUCanvasContext: core.propNonEnumerable(webgpuSurface.GPUCanvasContext), GPUCanvasContext: core.propNonEnumerable(webgpuSurface.GPUCanvasContext),
GPUColorWrite: core.propNonEnumerableLazyLoaded( GPUColorWrite: core.propNonEnumerableLazyLoaded(
(webgpu) => webgpu.GPUColorWrite, (webgpu) => webgpu.GPUColorWrite,
loadWebGPU, loadWebGPU,