react-native-wgpu 0.5.13 → 0.5.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +13 -386
- package/lib/commonjs/index.js +7 -4
- package/lib/commonjs/index.js.map +1 -1
- package/lib/module/index.js +4 -4
- package/lib/module/index.js.map +1 -1
- package/lib/typescript/webgpu/src/Canvas.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/NativeWebGPUModule.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/Offscreen.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/WebGPUViewNativeComponent.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/external/ModuleProxy.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/external/index.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/external/reanimated/ReanimatedProxy.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/external/reanimated/index.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/external/reanimated/registerWebGPUForReanimated.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/hooks.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/index.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/main/index.d.ts.map +1 -0
- package/lib/typescript/webgpu/src/types.d.ts.map +1 -0
- package/lib/typescript/{eslint.config.d.mts.map → webgpu-shim/eslint.config.d.mts.map} +1 -1
- package/lib/typescript/{lib → webgpu-shim/lib}/commonjs/index.d.ts.map +1 -1
- package/lib/typescript/webgpu-shim/lib/module/index.d.ts +2 -0
- package/lib/typescript/{lib → webgpu-shim/lib}/module/index.d.ts.map +1 -1
- package/lib/typescript/webgpu-shim/src/index.d.ts +2 -0
- package/lib/typescript/webgpu-shim/src/index.d.ts.map +1 -0
- package/package.json +12 -81
- package/src/index.ts +9 -0
- package/LICENSE +0 -20
- package/android/CMakeLists.txt +0 -110
- package/android/build.gradle +0 -138
- package/android/cpp/AndroidPlatformContext.h +0 -328
- package/android/cpp/cpp-adapter.cpp +0 -71
- package/android/src/main/AndroidManifest.xml +0 -3
- package/android/src/main/java/com/webgpu/WebGPUAHBView.java +0 -298
- package/android/src/main/java/com/webgpu/WebGPUAPI.java +0 -20
- package/android/src/main/java/com/webgpu/WebGPUBaseView.java +0 -61
- package/android/src/main/java/com/webgpu/WebGPUModule.java +0 -50
- package/android/src/main/java/com/webgpu/WebGPUSurfaceView.java +0 -41
- package/android/src/main/java/com/webgpu/WebGPUSurfaceViewWithSC.java +0 -79
- package/android/src/main/java/com/webgpu/WebGPUTextureView.java +0 -46
- package/android/src/main/java/com/webgpu/WebGPUView.java +0 -108
- package/android/src/main/java/com/webgpu/WebGPUViewManager.java +0 -38
- package/android/src/main/java/com/webgpu/WebGPUViewPackage.java +0 -50
- package/android/src/newarch/com/webgpu/WebGPUViewManagerSpec.java +0 -24
- package/apple/ApplePlatformContext.h +0 -44
- package/apple/ApplePlatformContext.mm +0 -302
- package/apple/AppleVideoPlayer.h +0 -31
- package/apple/AppleVideoPlayer.mm +0 -314
- package/apple/MetalView.h +0 -13
- package/apple/MetalView.mm +0 -50
- package/apple/RNWGUIKit.h +0 -16
- package/apple/WebGPUModule.h +0 -13
- package/apple/WebGPUModule.mm +0 -89
- package/apple/WebGPUView.h +0 -12
- package/apple/WebGPUView.mm +0 -66
- package/cpp/WGPULogger.h +0 -100
- package/cpp/dawn_logging.cpp +0 -119
- package/cpp/jsi/EnumMapper.h +0 -45
- package/cpp/jsi/JSIConverter.h +0 -473
- package/cpp/jsi/NativeObject.h +0 -607
- package/cpp/jsi/Promise.cpp +0 -44
- package/cpp/jsi/Promise.h +0 -35
- package/cpp/jsi/RuntimeAwareCache.cpp +0 -7
- package/cpp/jsi/RuntimeAwareCache.h +0 -100
- package/cpp/jsi/RuntimeLifecycleMonitor.cpp +0 -72
- package/cpp/jsi/RuntimeLifecycleMonitor.h +0 -32
- package/cpp/rnwgpu/ArrayBuffer.h +0 -117
- package/cpp/rnwgpu/PlatformContext.h +0 -127
- package/cpp/rnwgpu/RNWebGPUManager.cpp +0 -237
- package/cpp/rnwgpu/RNWebGPUManager.h +0 -46
- package/cpp/rnwgpu/SurfaceRegistry.h +0 -230
- package/cpp/rnwgpu/api/Canvas.h +0 -57
- package/cpp/rnwgpu/api/Convertors.h +0 -783
- package/cpp/rnwgpu/api/External.h +0 -12
- package/cpp/rnwgpu/api/GPU.cpp +0 -154
- package/cpp/rnwgpu/api/GPU.h +0 -58
- package/cpp/rnwgpu/api/GPUAdapter.cpp +0 -267
- package/cpp/rnwgpu/api/GPUAdapter.h +0 -59
- package/cpp/rnwgpu/api/GPUAdapterInfo.h +0 -57
- package/cpp/rnwgpu/api/GPUBindGroup.cpp +0 -3
- package/cpp/rnwgpu/api/GPUBindGroup.h +0 -51
- package/cpp/rnwgpu/api/GPUBindGroupLayout.h +0 -52
- package/cpp/rnwgpu/api/GPUBuffer.cpp +0 -97
- package/cpp/rnwgpu/api/GPUBuffer.h +0 -87
- package/cpp/rnwgpu/api/GPUCanvasContext.cpp +0 -67
- package/cpp/rnwgpu/api/GPUCanvasContext.h +0 -66
- package/cpp/rnwgpu/api/GPUCommandBuffer.h +0 -45
- package/cpp/rnwgpu/api/GPUCommandEncoder.cpp +0 -179
- package/cpp/rnwgpu/api/GPUCommandEncoder.h +0 -111
- package/cpp/rnwgpu/api/GPUCompilationInfo.h +0 -79
- package/cpp/rnwgpu/api/GPUCompilationMessage.h +0 -36
- package/cpp/rnwgpu/api/GPUComputePassEncoder.cpp +0 -60
- package/cpp/rnwgpu/api/GPUComputePassEncoder.h +0 -85
- package/cpp/rnwgpu/api/GPUComputePipeline.cpp +0 -12
- package/cpp/rnwgpu/api/GPUComputePipeline.h +0 -60
- package/cpp/rnwgpu/api/GPUDevice.cpp +0 -545
- package/cpp/rnwgpu/api/GPUDevice.h +0 -265
- package/cpp/rnwgpu/api/GPUDeviceLostInfo.cpp +0 -7
- package/cpp/rnwgpu/api/GPUDeviceLostInfo.h +0 -40
- package/cpp/rnwgpu/api/GPUError.h +0 -35
- package/cpp/rnwgpu/api/GPUExtent3D.h +0 -66
- package/cpp/rnwgpu/api/GPUExternalTexture.cpp +0 -335
- package/cpp/rnwgpu/api/GPUExternalTexture.h +0 -90
- package/cpp/rnwgpu/api/GPUFeatures.h +0 -206
- package/cpp/rnwgpu/api/GPUInternalError.h +0 -31
- package/cpp/rnwgpu/api/GPUOrigin2D.h +0 -55
- package/cpp/rnwgpu/api/GPUOrigin3D.h +0 -62
- package/cpp/rnwgpu/api/GPUOutOfMemoryError.h +0 -33
- package/cpp/rnwgpu/api/GPUPipelineLayout.h +0 -45
- package/cpp/rnwgpu/api/GPUQuerySet.cpp +0 -11
- package/cpp/rnwgpu/api/GPUQuerySet.h +0 -73
- package/cpp/rnwgpu/api/GPUQueue.cpp +0 -169
- package/cpp/rnwgpu/api/GPUQueue.h +0 -81
- package/cpp/rnwgpu/api/GPURenderBundle.h +0 -44
- package/cpp/rnwgpu/api/GPURenderBundleEncoder.cpp +0 -131
- package/cpp/rnwgpu/api/GPURenderBundleEncoder.h +0 -110
- package/cpp/rnwgpu/api/GPURenderPassEncoder.cpp +0 -165
- package/cpp/rnwgpu/api/GPURenderPassEncoder.h +0 -130
- package/cpp/rnwgpu/api/GPURenderPipeline.cpp +0 -13
- package/cpp/rnwgpu/api/GPURenderPipeline.h +0 -61
- package/cpp/rnwgpu/api/GPUSampler.h +0 -44
- package/cpp/rnwgpu/api/GPUShaderModule.cpp +0 -50
- package/cpp/rnwgpu/api/GPUShaderModule.h +0 -66
- package/cpp/rnwgpu/api/GPUSharedTextureMemory.cpp +0 -80
- package/cpp/rnwgpu/api/GPUSharedTextureMemory.h +0 -71
- package/cpp/rnwgpu/api/GPUSupportedLimits.cpp +0 -129
- package/cpp/rnwgpu/api/GPUSupportedLimits.h +0 -131
- package/cpp/rnwgpu/api/GPUTexture.cpp +0 -47
- package/cpp/rnwgpu/api/GPUTexture.h +0 -162
- package/cpp/rnwgpu/api/GPUTextureView.h +0 -44
- package/cpp/rnwgpu/api/GPUUncapturedErrorEvent.h +0 -71
- package/cpp/rnwgpu/api/GPUValidationError.h +0 -32
- package/cpp/rnwgpu/api/ImageBitmap.h +0 -48
- package/cpp/rnwgpu/api/RNWebGPU.h +0 -241
- package/cpp/rnwgpu/api/RnFeatures.h +0 -53
- package/cpp/rnwgpu/api/VideoFrame.h +0 -76
- package/cpp/rnwgpu/api/VideoPlayer.h +0 -69
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupDescriptor.h +0 -65
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupEntry.h +0 -81
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupLayoutDescriptor.h +0 -57
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupLayoutEntry.h +0 -98
- package/cpp/rnwgpu/api/descriptors/GPUBlendComponent.h +0 -58
- package/cpp/rnwgpu/api/descriptors/GPUBlendState.h +0 -53
- package/cpp/rnwgpu/api/descriptors/GPUBufferBinding.h +0 -57
- package/cpp/rnwgpu/api/descriptors/GPUBufferBindingLayout.h +0 -57
- package/cpp/rnwgpu/api/descriptors/GPUBufferDescriptor.h +0 -60
- package/cpp/rnwgpu/api/descriptors/GPUBufferUsage.h +0 -39
- package/cpp/rnwgpu/api/descriptors/GPUCanvasConfiguration.h +0 -76
- package/cpp/rnwgpu/api/descriptors/GPUColor.h +0 -67
- package/cpp/rnwgpu/api/descriptors/GPUColorTargetState.h +0 -59
- package/cpp/rnwgpu/api/descriptors/GPUColorWrite.h +0 -29
- package/cpp/rnwgpu/api/descriptors/GPUCommandBufferDescriptor.h +0 -46
- package/cpp/rnwgpu/api/descriptors/GPUCommandEncoderDescriptor.h +0 -46
- package/cpp/rnwgpu/api/descriptors/GPUComputePassDescriptor.h +0 -57
- package/cpp/rnwgpu/api/descriptors/GPUComputePassTimestampWrites.h +0 -59
- package/cpp/rnwgpu/api/descriptors/GPUComputePipelineDescriptor.h +0 -68
- package/cpp/rnwgpu/api/descriptors/GPUDawnTogglesDescriptor.h +0 -57
- package/cpp/rnwgpu/api/descriptors/GPUDepthStencilState.h +0 -104
- package/cpp/rnwgpu/api/descriptors/GPUDeviceDescriptor.h +0 -115
- package/cpp/rnwgpu/api/descriptors/GPUExternalTextureBindingLayout.h +0 -39
- package/cpp/rnwgpu/api/descriptors/GPUExternalTextureDescriptor.h +0 -82
- package/cpp/rnwgpu/api/descriptors/GPUFragmentState.h +0 -74
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyBuffer.h +0 -63
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyExternalImage.h +0 -63
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyTexture.h +0 -66
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyTextureTagged.h +0 -82
- package/cpp/rnwgpu/api/descriptors/GPUImageDataLayout.h +0 -55
- package/cpp/rnwgpu/api/descriptors/GPUMapMode.h +0 -22
- package/cpp/rnwgpu/api/descriptors/GPUMultisampleState.h +0 -55
- package/cpp/rnwgpu/api/descriptors/GPUPipelineLayoutDescriptor.h +0 -58
- package/cpp/rnwgpu/api/descriptors/GPUPrimitiveState.h +0 -70
- package/cpp/rnwgpu/api/descriptors/GPUProgrammableStage.h +0 -62
- package/cpp/rnwgpu/api/descriptors/GPUQuerySetDescriptor.h +0 -56
- package/cpp/rnwgpu/api/descriptors/GPUQueueDescriptor.h +0 -44
- package/cpp/rnwgpu/api/descriptors/GPURenderBundleDescriptor.h +0 -46
- package/cpp/rnwgpu/api/descriptors/GPURenderBundleEncoderDescriptor.h +0 -81
- package/cpp/rnwgpu/api/descriptors/GPURenderPassColorAttachment.h +0 -82
- package/cpp/rnwgpu/api/descriptors/GPURenderPassDepthStencilAttachment.h +0 -102
- package/cpp/rnwgpu/api/descriptors/GPURenderPassDescriptor.h +0 -93
- package/cpp/rnwgpu/api/descriptors/GPURenderPassTimestampWrites.h +0 -59
- package/cpp/rnwgpu/api/descriptors/GPURenderPipelineDescriptor.h +0 -104
- package/cpp/rnwgpu/api/descriptors/GPURequestAdapterOptions.h +0 -52
- package/cpp/rnwgpu/api/descriptors/GPUSamplerBindingLayout.h +0 -46
- package/cpp/rnwgpu/api/descriptors/GPUSamplerDescriptor.h +0 -111
- package/cpp/rnwgpu/api/descriptors/GPUShaderModuleCompilationHint.h +0 -61
- package/cpp/rnwgpu/api/descriptors/GPUShaderModuleDescriptor.h +0 -63
- package/cpp/rnwgpu/api/descriptors/GPUShaderStage.h +0 -25
- package/cpp/rnwgpu/api/descriptors/GPUSharedTextureMemoryDescriptor.h +0 -62
- package/cpp/rnwgpu/api/descriptors/GPUStencilFaceState.h +0 -65
- package/cpp/rnwgpu/api/descriptors/GPUStorageTextureBindingLayout.h +0 -60
- package/cpp/rnwgpu/api/descriptors/GPUTextureBindingLayout.h +0 -60
- package/cpp/rnwgpu/api/descriptors/GPUTextureDescriptor.h +0 -92
- package/cpp/rnwgpu/api/descriptors/GPUTextureUsage.h +0 -29
- package/cpp/rnwgpu/api/descriptors/GPUTextureViewDescriptor.h +0 -92
- package/cpp/rnwgpu/api/descriptors/GPUUncapturedErrorEventInit.h +0 -65
- package/cpp/rnwgpu/api/descriptors/GPUVertexAttribute.h +0 -54
- package/cpp/rnwgpu/api/descriptors/GPUVertexBufferLayout.h +0 -63
- package/cpp/rnwgpu/api/descriptors/GPUVertexState.h +0 -74
- package/cpp/rnwgpu/api/descriptors/Unions.h +0 -1979
- package/cpp/rnwgpu/async/AsyncDispatcher.h +0 -28
- package/cpp/rnwgpu/async/AsyncRunner.cpp +0 -215
- package/cpp/rnwgpu/async/AsyncRunner.h +0 -53
- package/cpp/rnwgpu/async/AsyncTaskHandle.cpp +0 -181
- package/cpp/rnwgpu/async/AsyncTaskHandle.h +0 -55
- package/cpp/rnwgpu/async/JSIMicrotaskDispatcher.cpp +0 -23
- package/cpp/rnwgpu/async/JSIMicrotaskDispatcher.h +0 -22
- package/cpp/webgpu/webgpu.h +0 -4979
- package/cpp/webgpu/webgpu_cpp.h +0 -10059
- package/cpp/webgpu/webgpu_cpp_chained_struct.h +0 -57
- package/cpp/webgpu/webgpu_cpp_print.h +0 -2844
- package/cpp/webgpu/webgpu_enum_class_bitmasks.h +0 -161
- package/lib/commonjs/Canvas.js +0 -55
- package/lib/commonjs/Canvas.js.map +0 -1
- package/lib/commonjs/NativeWebGPUModule.js +0 -10
- package/lib/commonjs/NativeWebGPUModule.js.map +0 -1
- package/lib/commonjs/Offscreen.js +0 -103
- package/lib/commonjs/Offscreen.js.map +0 -1
- package/lib/commonjs/WebGPUViewNativeComponent.js +0 -10
- package/lib/commonjs/WebGPUViewNativeComponent.js.map +0 -1
- package/lib/commonjs/WebGPUViewNativeComponent.web.js +0 -103
- package/lib/commonjs/WebGPUViewNativeComponent.web.js.map +0 -1
- package/lib/commonjs/WebPolyfillGPUModule.js +0 -40
- package/lib/commonjs/WebPolyfillGPUModule.js.map +0 -1
- package/lib/commonjs/external/ModuleProxy.js +0 -36
- package/lib/commonjs/external/ModuleProxy.js.map +0 -1
- package/lib/commonjs/external/index.js +0 -17
- package/lib/commonjs/external/index.js.map +0 -1
- package/lib/commonjs/external/reanimated/ReanimatedProxy.js +0 -18
- package/lib/commonjs/external/reanimated/ReanimatedProxy.js.map +0 -1
- package/lib/commonjs/external/reanimated/index.js +0 -21
- package/lib/commonjs/external/reanimated/index.js.map +0 -1
- package/lib/commonjs/external/reanimated/registerWebGPUForReanimated.js +0 -49
- package/lib/commonjs/external/reanimated/registerWebGPUForReanimated.js.map +0 -1
- package/lib/commonjs/hooks.js +0 -83
- package/lib/commonjs/hooks.js.map +0 -1
- package/lib/commonjs/main/index.js +0 -91
- package/lib/commonjs/main/index.js.map +0 -1
- package/lib/commonjs/main/index.web.js +0 -51
- package/lib/commonjs/main/index.web.js.map +0 -1
- package/lib/commonjs/types.js +0 -2
- package/lib/commonjs/types.js.map +0 -1
- package/lib/commonjs/utils.js +0 -11
- package/lib/commonjs/utils.js.map +0 -1
- package/lib/module/Canvas.js +0 -46
- package/lib/module/Canvas.js.map +0 -1
- package/lib/module/NativeWebGPUModule.js +0 -4
- package/lib/module/NativeWebGPUModule.js.map +0 -1
- package/lib/module/Offscreen.js +0 -96
- package/lib/module/Offscreen.js.map +0 -1
- package/lib/module/WebGPUViewNativeComponent.js +0 -4
- package/lib/module/WebGPUViewNativeComponent.js.map +0 -1
- package/lib/module/WebGPUViewNativeComponent.web.js +0 -96
- package/lib/module/WebGPUViewNativeComponent.web.js.map +0 -1
- package/lib/module/WebPolyfillGPUModule.js +0 -38
- package/lib/module/WebPolyfillGPUModule.js.map +0 -1
- package/lib/module/external/ModuleProxy.js +0 -28
- package/lib/module/external/ModuleProxy.js.map +0 -1
- package/lib/module/external/index.js +0 -2
- package/lib/module/external/index.js.map +0 -1
- package/lib/module/external/reanimated/ReanimatedProxy.js +0 -12
- package/lib/module/external/reanimated/ReanimatedProxy.js.map +0 -1
- package/lib/module/external/reanimated/index.js +0 -3
- package/lib/module/external/reanimated/index.js.map +0 -1
- package/lib/module/external/reanimated/registerWebGPUForReanimated.js +0 -42
- package/lib/module/external/reanimated/registerWebGPUForReanimated.js.map +0 -1
- package/lib/module/hooks.js +0 -70
- package/lib/module/hooks.js.map +0 -1
- package/lib/module/main/index.js +0 -33
- package/lib/module/main/index.js.map +0 -1
- package/lib/module/main/index.web.js +0 -8
- package/lib/module/main/index.web.js.map +0 -1
- package/lib/module/types.js +0 -2
- package/lib/module/types.js.map +0 -1
- package/lib/module/utils.js +0 -5
- package/lib/module/utils.js.map +0 -1
- package/lib/typescript/babel.config.d.ts +0 -3
- package/lib/typescript/babel.config.d.ts.map +0 -1
- package/lib/typescript/jest.config.d.ts +0 -9
- package/lib/typescript/jest.config.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/Canvas.d.ts +0 -7
- package/lib/typescript/lib/commonjs/Canvas.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/NativeWebGPUModule.d.ts +0 -5
- package/lib/typescript/lib/commonjs/NativeWebGPUModule.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/Offscreen.d.ts +0 -26
- package/lib/typescript/lib/commonjs/Offscreen.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.d.ts +0 -5
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.web.d.ts +0 -4
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.web.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/WebPolyfillGPUModule.d.ts +0 -2
- package/lib/typescript/lib/commonjs/WebPolyfillGPUModule.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/external/ModuleProxy.d.ts +0 -12
- package/lib/typescript/lib/commonjs/external/ModuleProxy.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/external/index.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/external/reanimated/ReanimatedProxy.d.ts +0 -6
- package/lib/typescript/lib/commonjs/external/reanimated/ReanimatedProxy.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/external/reanimated/index.d.ts +0 -4
- package/lib/typescript/lib/commonjs/external/reanimated/index.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/external/reanimated/registerWebGPUForReanimated.d.ts +0 -9
- package/lib/typescript/lib/commonjs/external/reanimated/registerWebGPUForReanimated.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/hooks.d.ts +0 -18
- package/lib/typescript/lib/commonjs/hooks.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/index.d.ts +0 -2
- package/lib/typescript/lib/commonjs/main/index.d.ts +0 -3
- package/lib/typescript/lib/commonjs/main/index.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/main/index.web.d.ts +0 -2
- package/lib/typescript/lib/commonjs/main/index.web.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/types.d.ts +0 -1
- package/lib/typescript/lib/commonjs/types.d.ts.map +0 -1
- package/lib/typescript/lib/commonjs/utils.d.ts +0 -3
- package/lib/typescript/lib/commonjs/utils.d.ts.map +0 -1
- package/lib/typescript/lib/module/Canvas.d.ts +0 -8
- package/lib/typescript/lib/module/Canvas.d.ts.map +0 -1
- package/lib/typescript/lib/module/NativeWebGPUModule.d.ts +0 -3
- package/lib/typescript/lib/module/NativeWebGPUModule.d.ts.map +0 -1
- package/lib/typescript/lib/module/Offscreen.d.ts +0 -25
- package/lib/typescript/lib/module/Offscreen.d.ts.map +0 -1
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.d.ts +0 -3
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.d.ts.map +0 -1
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.web.d.ts +0 -3
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.web.d.ts.map +0 -1
- package/lib/typescript/lib/module/WebPolyfillGPUModule.d.ts +0 -2
- package/lib/typescript/lib/module/WebPolyfillGPUModule.d.ts.map +0 -1
- package/lib/typescript/lib/module/external/ModuleProxy.d.ts +0 -7
- package/lib/typescript/lib/module/external/ModuleProxy.d.ts.map +0 -1
- package/lib/typescript/lib/module/external/index.d.ts.map +0 -1
- package/lib/typescript/lib/module/external/reanimated/ReanimatedProxy.d.ts +0 -5
- package/lib/typescript/lib/module/external/reanimated/ReanimatedProxy.d.ts.map +0 -1
- package/lib/typescript/lib/module/external/reanimated/index.d.ts.map +0 -1
- package/lib/typescript/lib/module/external/reanimated/registerWebGPUForReanimated.d.ts +0 -2
- package/lib/typescript/lib/module/external/reanimated/registerWebGPUForReanimated.d.ts.map +0 -1
- package/lib/typescript/lib/module/hooks.d.ts +0 -18
- package/lib/typescript/lib/module/hooks.d.ts.map +0 -1
- package/lib/typescript/lib/module/index.d.ts +0 -2
- package/lib/typescript/lib/module/main/index.d.ts.map +0 -1
- package/lib/typescript/lib/module/main/index.web.d.ts +0 -5
- package/lib/typescript/lib/module/main/index.web.d.ts.map +0 -1
- package/lib/typescript/lib/module/types.d.ts +0 -1
- package/lib/typescript/lib/module/types.d.ts.map +0 -1
- package/lib/typescript/lib/module/utils.d.ts +0 -2
- package/lib/typescript/lib/module/utils.d.ts.map +0 -1
- package/lib/typescript/src/Canvas.d.ts.map +0 -1
- package/lib/typescript/src/NativeWebGPUModule.d.ts.map +0 -1
- package/lib/typescript/src/Offscreen.d.ts.map +0 -1
- package/lib/typescript/src/WebGPUViewNativeComponent.d.ts.map +0 -1
- package/lib/typescript/src/WebGPUViewNativeComponent.web.d.ts +0 -9
- package/lib/typescript/src/WebGPUViewNativeComponent.web.d.ts.map +0 -1
- package/lib/typescript/src/WebPolyfillGPUModule.d.ts +0 -2
- package/lib/typescript/src/WebPolyfillGPUModule.d.ts.map +0 -1
- package/lib/typescript/src/external/ModuleProxy.d.ts.map +0 -1
- package/lib/typescript/src/external/index.d.ts +0 -2
- package/lib/typescript/src/external/index.d.ts.map +0 -1
- package/lib/typescript/src/external/reanimated/ReanimatedProxy.d.ts.map +0 -1
- package/lib/typescript/src/external/reanimated/index.d.ts +0 -3
- package/lib/typescript/src/external/reanimated/index.d.ts.map +0 -1
- package/lib/typescript/src/external/reanimated/registerWebGPUForReanimated.d.ts.map +0 -1
- package/lib/typescript/src/hooks.d.ts.map +0 -1
- package/lib/typescript/src/index.d.ts.map +0 -1
- package/lib/typescript/src/main/index.d.ts +0 -6
- package/lib/typescript/src/main/index.d.ts.map +0 -1
- package/lib/typescript/src/main/index.web.d.ts +0 -6
- package/lib/typescript/src/main/index.web.d.ts.map +0 -1
- package/lib/typescript/src/types.d.ts.map +0 -1
- package/lib/typescript/src/utils.d.ts +0 -2
- package/lib/typescript/src/utils.d.ts.map +0 -1
- package/libs/android/arm64-v8a/libwebgpu_dawn.so +0 -0
- package/libs/android/armeabi-v7a/libwebgpu_dawn.so +0 -0
- package/libs/android/x86/libwebgpu_dawn.so +0 -0
- package/libs/android/x86_64/libwebgpu_dawn.so +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/Info.plist +0 -59
- package/libs/apple/libwebgpu_dawn.xcframework/ios-arm64/libwebgpu_dawn.a +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/ios-arm64_x86_64-simulator/libwebgpu_dawn.a +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/macos-arm64_x86_64/libwebgpu_dawn.a +0 -0
- package/react-native-wgpu.podspec +0 -47
- package/src/Canvas.tsx +0 -76
- package/src/NativeWebGPUModule.ts +0 -9
- package/src/Offscreen.ts +0 -113
- package/src/WebGPUViewNativeComponent.ts +0 -11
- package/src/WebGPUViewNativeComponent.web.ts +0 -113
- package/src/WebPolyfillGPUModule.ts +0 -53
- package/src/external/ModuleProxy.ts +0 -30
- package/src/external/index.ts +0 -1
- package/src/external/reanimated/ReanimatedProxy.ts +0 -19
- package/src/external/reanimated/index.ts +0 -2
- package/src/external/reanimated/registerWebGPUForReanimated.ts +0 -43
- package/src/hooks.tsx +0 -93
- package/src/index.tsx +0 -91
- package/src/main/index.tsx +0 -40
- package/src/main/index.web.tsx +0 -8
- package/src/types.ts +0 -102
- package/src/utils.ts +0 -4
- /package/lib/typescript/{src → webgpu/src}/Canvas.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/NativeWebGPUModule.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/Offscreen.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/WebGPUViewNativeComponent.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/external/ModuleProxy.d.ts +0 -0
- /package/lib/typescript/{lib/module → webgpu/src}/external/index.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/external/reanimated/ReanimatedProxy.d.ts +0 -0
- /package/lib/typescript/{lib/module → webgpu/src}/external/reanimated/index.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/external/reanimated/registerWebGPUForReanimated.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/hooks.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/index.d.ts +0 -0
- /package/lib/typescript/{lib/module → webgpu/src}/main/index.d.ts +0 -0
- /package/lib/typescript/{src → webgpu/src}/types.d.ts +0 -0
- /package/lib/typescript/{eslint.config.d.mts → webgpu-shim/eslint.config.d.mts} +0 -0
- /package/lib/typescript/{lib/commonjs/external → webgpu-shim/lib/commonjs}/index.d.ts +0 -0
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "webgpu/webgpu_cpp.h"
|
|
4
|
-
|
|
5
|
-
namespace rnwgpu {
|
|
6
|
-
enum class PredefinedColorSpace : uint32_t {
|
|
7
|
-
DisplayP3 = 0,
|
|
8
|
-
Srgb = 1,
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
enum class PremultiplyAlpha : uint32_t { Default = 0, None = 1, Premultiply };
|
|
12
|
-
} // namespace rnwgpu
|
package/cpp/rnwgpu/api/GPU.cpp
DELETED
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
#include "GPU.h"
|
|
2
|
-
|
|
3
|
-
#include <cstdio>
|
|
4
|
-
#include <memory>
|
|
5
|
-
#include <string>
|
|
6
|
-
#include <unordered_set>
|
|
7
|
-
#include <utility>
|
|
8
|
-
#include <vector>
|
|
9
|
-
|
|
10
|
-
#include "Convertors.h"
|
|
11
|
-
#include "JSIConverter.h"
|
|
12
|
-
#include "rnwgpu/async/JSIMicrotaskDispatcher.h"
|
|
13
|
-
|
|
14
|
-
namespace rnwgpu {
|
|
15
|
-
|
|
16
|
-
GPU::GPU(jsi::Runtime &runtime) : NativeObject(CLASS_NAME) {
|
|
17
|
-
static const auto kTimedWaitAny = wgpu::InstanceFeatureName::TimedWaitAny;
|
|
18
|
-
wgpu::InstanceDescriptor instanceDesc{.requiredFeatureCount = 1,
|
|
19
|
-
.requiredFeatures = &kTimedWaitAny};
|
|
20
|
-
|
|
21
|
-
wgpu::InstanceLimits limits{.timedWaitAnyMaxCount = 64};
|
|
22
|
-
instanceDesc.requiredLimits = &limits;
|
|
23
|
-
|
|
24
|
-
// Expose Dawn's experimental adapter features. Several features needed by
|
|
25
|
-
// our Android external-texture path (YCbCrVulkanSamplers,
|
|
26
|
-
// OpaqueYCbCrAndroidForExternalTexture) are tagged Experimental in Dawn's
|
|
27
|
-
// feature table and are otherwise filtered out of adapter.features by
|
|
28
|
-
// PhysicalDeviceBase::GetSupportedFeatures. The allow_unsafe_apis toggle
|
|
29
|
-
// disables that filter so the features become visible;
|
|
30
|
-
// expose_wgsl_experimental_features is the parallel toggle for WGSL language
|
|
31
|
-
// features.
|
|
32
|
-
//
|
|
33
|
-
// Trade-off: these are instance-level Dawn toggles, so they apply to every
|
|
34
|
-
// adapter/device created from this instance, not just the external-texture
|
|
35
|
-
// path. There is no finer-grained, per-feature mechanism to surface these.
|
|
36
|
-
// The exposure is acceptable because the toggle only *un-hides* experimental
|
|
37
|
-
// features in adapter.features; it does not enable any of them. Nothing
|
|
38
|
-
// experimental becomes active unless application code explicitly lists that
|
|
39
|
-
// feature in requiredFeatures at device creation, so the default behavior of
|
|
40
|
-
// a device that asks for no experimental features is unchanged.
|
|
41
|
-
static const char *const kEnabledToggles[] = {
|
|
42
|
-
"allow_unsafe_apis",
|
|
43
|
-
"expose_wgsl_experimental_features",
|
|
44
|
-
};
|
|
45
|
-
wgpu::DawnTogglesDescriptor toggles;
|
|
46
|
-
toggles.enabledToggleCount = std::size(kEnabledToggles);
|
|
47
|
-
toggles.enabledToggles = kEnabledToggles;
|
|
48
|
-
instanceDesc.nextInChain = &toggles;
|
|
49
|
-
|
|
50
|
-
_instance = wgpu::CreateInstance(&instanceDesc);
|
|
51
|
-
|
|
52
|
-
auto dispatcher = std::make_shared<async::JSIMicrotaskDispatcher>(runtime);
|
|
53
|
-
_async = async::AsyncRunner::getOrCreate(runtime, _instance, dispatcher);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
async::AsyncTaskHandle GPU::requestAdapter(
|
|
57
|
-
std::optional<std::shared_ptr<GPURequestAdapterOptions>> options) {
|
|
58
|
-
wgpu::RequestAdapterOptions aOptions;
|
|
59
|
-
Convertor conv;
|
|
60
|
-
if (!conv(aOptions, options)) {
|
|
61
|
-
throw std::runtime_error("Failed to convert GPUDeviceDescriptor");
|
|
62
|
-
}
|
|
63
|
-
#ifdef __APPLE__
|
|
64
|
-
constexpr auto kDefaultBackendType = wgpu::BackendType::Metal;
|
|
65
|
-
#else
|
|
66
|
-
constexpr auto kDefaultBackendType = wgpu::BackendType::Vulkan;
|
|
67
|
-
#endif
|
|
68
|
-
aOptions.backendType = kDefaultBackendType;
|
|
69
|
-
return _async->postTask(
|
|
70
|
-
[this, aOptions](const async::AsyncTaskHandle::ResolveFunction &resolve,
|
|
71
|
-
const async::AsyncTaskHandle::RejectFunction &reject) {
|
|
72
|
-
_instance.RequestAdapter(
|
|
73
|
-
&aOptions, wgpu::CallbackMode::AllowProcessEvents,
|
|
74
|
-
[asyncRunner = _async, resolve,
|
|
75
|
-
reject](wgpu::RequestAdapterStatus status, wgpu::Adapter adapter,
|
|
76
|
-
wgpu::StringView message) {
|
|
77
|
-
if (message.length) {
|
|
78
|
-
fprintf(stderr, "%s", message.data);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
if (status == wgpu::RequestAdapterStatus::Success && adapter) {
|
|
82
|
-
auto adapterHost = std::make_shared<GPUAdapter>(
|
|
83
|
-
std::move(adapter), asyncRunner);
|
|
84
|
-
auto result =
|
|
85
|
-
std::variant<std::nullptr_t, std::shared_ptr<GPUAdapter>>(
|
|
86
|
-
adapterHost);
|
|
87
|
-
resolve([result =
|
|
88
|
-
std::move(result)](jsi::Runtime &runtime) mutable {
|
|
89
|
-
return JSIConverter<decltype(result)>::toJSI(runtime, result);
|
|
90
|
-
});
|
|
91
|
-
} else {
|
|
92
|
-
auto result =
|
|
93
|
-
std::variant<std::nullptr_t, std::shared_ptr<GPUAdapter>>(
|
|
94
|
-
nullptr);
|
|
95
|
-
resolve([result =
|
|
96
|
-
std::move(result)](jsi::Runtime &runtime) mutable {
|
|
97
|
-
return JSIConverter<decltype(result)>::toJSI(runtime, result);
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
std::unordered_set<std::string> GPU::getWgslLanguageFeatures() {
|
|
105
|
-
wgpu::SupportedWGSLLanguageFeatures supportedFeatures = {};
|
|
106
|
-
_instance.GetWGSLLanguageFeatures(&supportedFeatures);
|
|
107
|
-
|
|
108
|
-
std::unordered_set<std::string> result;
|
|
109
|
-
for (size_t i = 0; i < supportedFeatures.featureCount; i++) {
|
|
110
|
-
wgpu::WGSLLanguageFeatureName feature = supportedFeatures.features[i];
|
|
111
|
-
std::string name;
|
|
112
|
-
switch (feature) {
|
|
113
|
-
case wgpu::WGSLLanguageFeatureName::ReadonlyAndReadwriteStorageTextures:
|
|
114
|
-
name = "readonly_and_readwrite_storage_textures";
|
|
115
|
-
break;
|
|
116
|
-
case wgpu::WGSLLanguageFeatureName::Packed4x8IntegerDotProduct:
|
|
117
|
-
name = "packed_4x8_integer_dot_product";
|
|
118
|
-
break;
|
|
119
|
-
case wgpu::WGSLLanguageFeatureName::UnrestrictedPointerParameters:
|
|
120
|
-
name = "unrestricted_pointer_parameters";
|
|
121
|
-
break;
|
|
122
|
-
case wgpu::WGSLLanguageFeatureName::PointerCompositeAccess:
|
|
123
|
-
name = "pointer_composite_access";
|
|
124
|
-
break;
|
|
125
|
-
case wgpu::WGSLLanguageFeatureName::ChromiumTestingUnimplemented:
|
|
126
|
-
name = "chromium_testing_unimplemented";
|
|
127
|
-
break;
|
|
128
|
-
case wgpu::WGSLLanguageFeatureName::ChromiumTestingUnsafeExperimental:
|
|
129
|
-
name = "chromium_testing_unsafe_experimental";
|
|
130
|
-
break;
|
|
131
|
-
case wgpu::WGSLLanguageFeatureName::ChromiumTestingExperimental:
|
|
132
|
-
name = "chromium_testing_experimental";
|
|
133
|
-
break;
|
|
134
|
-
case wgpu::WGSLLanguageFeatureName::ChromiumTestingShippedWithKillswitch:
|
|
135
|
-
name = "chromium_testing_shipped_with_killswitch";
|
|
136
|
-
break;
|
|
137
|
-
case wgpu::WGSLLanguageFeatureName::ChromiumTestingShipped:
|
|
138
|
-
name = "chromium_testing_shipped";
|
|
139
|
-
break;
|
|
140
|
-
}
|
|
141
|
-
result.insert(name);
|
|
142
|
-
}
|
|
143
|
-
return result;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
wgpu::TextureFormat GPU::getPreferredCanvasFormat() {
|
|
147
|
-
#if defined(__ANDROID__)
|
|
148
|
-
return wgpu::TextureFormat::RGBA8Unorm;
|
|
149
|
-
#else
|
|
150
|
-
return wgpu::TextureFormat::BGRA8Unorm;
|
|
151
|
-
#endif // defined(__ANDROID__)
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
} // namespace rnwgpu
|
package/cpp/rnwgpu/api/GPU.h
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <memory>
|
|
4
|
-
#include <string>
|
|
5
|
-
#include <unordered_set>
|
|
6
|
-
#include <variant>
|
|
7
|
-
|
|
8
|
-
#include "Unions.h"
|
|
9
|
-
|
|
10
|
-
#include "NativeObject.h"
|
|
11
|
-
|
|
12
|
-
#include "rnwgpu/async/AsyncRunner.h"
|
|
13
|
-
#include "rnwgpu/async/AsyncTaskHandle.h"
|
|
14
|
-
|
|
15
|
-
#include "webgpu/webgpu_cpp.h"
|
|
16
|
-
|
|
17
|
-
#include "GPUAdapter.h"
|
|
18
|
-
#include "GPURequestAdapterOptions.h"
|
|
19
|
-
|
|
20
|
-
#include <webgpu/webgpu.h>
|
|
21
|
-
|
|
22
|
-
namespace rnwgpu {
|
|
23
|
-
|
|
24
|
-
namespace jsi = facebook::jsi;
|
|
25
|
-
|
|
26
|
-
class GPU : public NativeObject<GPU> {
|
|
27
|
-
public:
|
|
28
|
-
static constexpr const char *CLASS_NAME = "GPU";
|
|
29
|
-
|
|
30
|
-
explicit GPU(jsi::Runtime &runtime);
|
|
31
|
-
|
|
32
|
-
public:
|
|
33
|
-
std::string getBrand() { return CLASS_NAME; }
|
|
34
|
-
|
|
35
|
-
async::AsyncTaskHandle requestAdapter(
|
|
36
|
-
std::optional<std::shared_ptr<GPURequestAdapterOptions>> options);
|
|
37
|
-
wgpu::TextureFormat getPreferredCanvasFormat();
|
|
38
|
-
|
|
39
|
-
std::unordered_set<std::string> getWgslLanguageFeatures();
|
|
40
|
-
|
|
41
|
-
static void definePrototype(jsi::Runtime &runtime, jsi::Object &prototype) {
|
|
42
|
-
installGetter(runtime, prototype, "__brand", &GPU::getBrand);
|
|
43
|
-
installMethod(runtime, prototype, "requestAdapter", &GPU::requestAdapter);
|
|
44
|
-
installMethod(runtime, prototype, "getPreferredCanvasFormat",
|
|
45
|
-
&GPU::getPreferredCanvasFormat);
|
|
46
|
-
installGetter(runtime, prototype, "wgslLanguageFeatures",
|
|
47
|
-
&GPU::getWgslLanguageFeatures);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
inline const wgpu::Instance get() { return _instance; }
|
|
51
|
-
inline std::shared_ptr<async::AsyncRunner> getAsyncRunner() { return _async; }
|
|
52
|
-
|
|
53
|
-
private:
|
|
54
|
-
wgpu::Instance _instance;
|
|
55
|
-
std::shared_ptr<async::AsyncRunner> _async;
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
} // namespace rnwgpu
|
|
@@ -1,267 +0,0 @@
|
|
|
1
|
-
#include "GPUAdapter.h"
|
|
2
|
-
|
|
3
|
-
#include <algorithm>
|
|
4
|
-
#include <cstdio>
|
|
5
|
-
#include <memory>
|
|
6
|
-
#include <string>
|
|
7
|
-
#include <unordered_set>
|
|
8
|
-
#include <utility>
|
|
9
|
-
#include <vector>
|
|
10
|
-
|
|
11
|
-
#include "Convertors.h"
|
|
12
|
-
|
|
13
|
-
#include "GPUFeatures.h"
|
|
14
|
-
#include "JSIConverter.h"
|
|
15
|
-
#include "RnFeatures.h"
|
|
16
|
-
#include "WGPULogger.h"
|
|
17
|
-
|
|
18
|
-
namespace rnwgpu {
|
|
19
|
-
|
|
20
|
-
async::AsyncTaskHandle GPUAdapter::requestDevice(
|
|
21
|
-
std::optional<std::shared_ptr<GPUDeviceDescriptor>> descriptor) {
|
|
22
|
-
// Enable the react-native-wgpu "native-texture" umbrella by default, mirroring
|
|
23
|
-
// the web where importExternalTexture is core and needs no feature request.
|
|
24
|
-
// We append the umbrella's backing Dawn features to requiredFeatures so the
|
|
25
|
-
// capability is on without the caller listing it. Two rules keep this safe:
|
|
26
|
-
// - All-or-nothing: only inject when the adapter supports *every* backing
|
|
27
|
-
// feature (same semantics as maybeSynthesizeRnNativeTextureFeature). On a
|
|
28
|
-
// web/fallback adapter the backing set is empty or unsupported, so this is
|
|
29
|
-
// a no-op and device creation is unaffected.
|
|
30
|
-
// - Requesting a feature the adapter doesn't support makes RequestDevice
|
|
31
|
-
// fail, hence the support check below.
|
|
32
|
-
// Callers can still pass "rnwebgpu/native-texture" explicitly; the dedupe
|
|
33
|
-
// keeps that idempotent.
|
|
34
|
-
{
|
|
35
|
-
auto backing = rnNativeTextureBackingFeatures();
|
|
36
|
-
if (!backing.empty()) {
|
|
37
|
-
wgpu::SupportedFeatures supported;
|
|
38
|
-
_instance.GetFeatures(&supported);
|
|
39
|
-
std::unordered_set<wgpu::FeatureName> supportedSet(
|
|
40
|
-
supported.features, supported.features + supported.featureCount);
|
|
41
|
-
bool allSupported = std::all_of(
|
|
42
|
-
backing.begin(), backing.end(),
|
|
43
|
-
[&](wgpu::FeatureName f) { return supportedSet.count(f) > 0; });
|
|
44
|
-
if (allSupported) {
|
|
45
|
-
if (!descriptor.has_value()) {
|
|
46
|
-
descriptor = std::make_shared<GPUDeviceDescriptor>();
|
|
47
|
-
}
|
|
48
|
-
auto &desc = descriptor.value();
|
|
49
|
-
if (!desc->requiredFeatures.has_value()) {
|
|
50
|
-
desc->requiredFeatures = std::vector<wgpu::FeatureName>{};
|
|
51
|
-
}
|
|
52
|
-
auto &features = desc->requiredFeatures.value();
|
|
53
|
-
for (auto f : backing) {
|
|
54
|
-
if (std::find(features.begin(), features.end(), f) ==
|
|
55
|
-
features.end()) {
|
|
56
|
-
features.push_back(f);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
wgpu::DeviceDescriptor aDescriptor;
|
|
64
|
-
Convertor conv;
|
|
65
|
-
if (!conv(aDescriptor, descriptor)) {
|
|
66
|
-
throw std::runtime_error("Failed to convert GPUDeviceDescriptor");
|
|
67
|
-
}
|
|
68
|
-
auto deviceLostBinding = std::make_shared<std::weak_ptr<GPUDevice>>();
|
|
69
|
-
// Set device lost callback using new template API
|
|
70
|
-
aDescriptor.SetDeviceLostCallback(
|
|
71
|
-
wgpu::CallbackMode::AllowSpontaneous,
|
|
72
|
-
[deviceLostBinding](const wgpu::Device & /*device*/,
|
|
73
|
-
wgpu::DeviceLostReason reason,
|
|
74
|
-
wgpu::StringView message) {
|
|
75
|
-
const char *lostReason = "";
|
|
76
|
-
switch (reason) {
|
|
77
|
-
case wgpu::DeviceLostReason::Destroyed:
|
|
78
|
-
lostReason = "Destroyed";
|
|
79
|
-
break;
|
|
80
|
-
case wgpu::DeviceLostReason::Unknown:
|
|
81
|
-
lostReason = "Unknown";
|
|
82
|
-
break;
|
|
83
|
-
default:
|
|
84
|
-
lostReason = "Unknown";
|
|
85
|
-
}
|
|
86
|
-
std::string msg =
|
|
87
|
-
message.length ? std::string(message.data, message.length) : "";
|
|
88
|
-
Logger::logToConsole("GPU Device Lost (%s): %s", lostReason,
|
|
89
|
-
msg.c_str());
|
|
90
|
-
if (auto deviceHost = deviceLostBinding->lock()) {
|
|
91
|
-
deviceHost->notifyDeviceLost(reason, std::move(msg));
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
// Set uncaptured error callback using new template API
|
|
96
|
-
// Note: This callback cannot capture variables, so we use a static registry
|
|
97
|
-
// to look up the GPUDevice from the wgpu::Device handle.
|
|
98
|
-
aDescriptor.SetUncapturedErrorCallback([](const wgpu::Device &device,
|
|
99
|
-
wgpu::ErrorType type,
|
|
100
|
-
wgpu::StringView message) {
|
|
101
|
-
const char *errorType = "";
|
|
102
|
-
switch (type) {
|
|
103
|
-
case wgpu::ErrorType::Validation:
|
|
104
|
-
errorType = "Validation";
|
|
105
|
-
break;
|
|
106
|
-
case wgpu::ErrorType::OutOfMemory:
|
|
107
|
-
errorType = "Out of Memory";
|
|
108
|
-
break;
|
|
109
|
-
case wgpu::ErrorType::Internal:
|
|
110
|
-
errorType = "Internal";
|
|
111
|
-
break;
|
|
112
|
-
case wgpu::ErrorType::Unknown:
|
|
113
|
-
errorType = "Unknown";
|
|
114
|
-
break;
|
|
115
|
-
default:
|
|
116
|
-
errorType = "Unknown";
|
|
117
|
-
}
|
|
118
|
-
std::string msg =
|
|
119
|
-
message.length > 0 ? std::string(message.data, message.length) : "";
|
|
120
|
-
std::string fullMessage =
|
|
121
|
-
msg.length() > 0 ? std::string(errorType) + ": " + msg : "no message";
|
|
122
|
-
fprintf(stderr, "%s\n", fullMessage.c_str());
|
|
123
|
-
|
|
124
|
-
// Look up the GPUDevice from the registry and notify it
|
|
125
|
-
if (auto gpuDevice = GPUDevice::lookupDevice(device.Get())) {
|
|
126
|
-
gpuDevice->notifyUncapturedError(type, std::move(msg));
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
std::string label =
|
|
130
|
-
descriptor.has_value() ? descriptor.value()->label.value_or("") : "";
|
|
131
|
-
|
|
132
|
-
auto creationRuntime = getCreationRuntime();
|
|
133
|
-
return _async->postTask(
|
|
134
|
-
[this, aDescriptor, descriptor, label = std::move(label),
|
|
135
|
-
deviceLostBinding,
|
|
136
|
-
creationRuntime](const async::AsyncTaskHandle::ResolveFunction &resolve,
|
|
137
|
-
const async::AsyncTaskHandle::RejectFunction &reject) {
|
|
138
|
-
// Build a local mutable copy so we can chain Dawn's device toggles.
|
|
139
|
-
// The toggle name strings are owned by `descriptor` (captured above),
|
|
140
|
-
// and the const char* / DawnTogglesDescriptor locals live for the
|
|
141
|
-
// whole synchronous RequestDevice call below, which is when Dawn reads
|
|
142
|
-
// the chained struct.
|
|
143
|
-
wgpu::DeviceDescriptor deviceDesc = aDescriptor;
|
|
144
|
-
wgpu::DawnTogglesDescriptor toggles{};
|
|
145
|
-
std::vector<const char *> enabledToggles;
|
|
146
|
-
std::vector<const char *> disabledToggles;
|
|
147
|
-
if (descriptor.has_value() && descriptor.value()->dawnToggles) {
|
|
148
|
-
const auto &dawnToggles = descriptor.value()->dawnToggles.value();
|
|
149
|
-
if (dawnToggles->enabledToggles) {
|
|
150
|
-
for (const auto &t : dawnToggles->enabledToggles.value()) {
|
|
151
|
-
enabledToggles.push_back(t.c_str());
|
|
152
|
-
}
|
|
153
|
-
toggles.enabledToggleCount = enabledToggles.size();
|
|
154
|
-
toggles.enabledToggles = enabledToggles.data();
|
|
155
|
-
}
|
|
156
|
-
if (dawnToggles->disabledToggles) {
|
|
157
|
-
for (const auto &t : dawnToggles->disabledToggles.value()) {
|
|
158
|
-
disabledToggles.push_back(t.c_str());
|
|
159
|
-
}
|
|
160
|
-
toggles.disabledToggleCount = disabledToggles.size();
|
|
161
|
-
toggles.disabledToggles = disabledToggles.data();
|
|
162
|
-
}
|
|
163
|
-
deviceDesc.nextInChain = &toggles;
|
|
164
|
-
}
|
|
165
|
-
_instance.RequestDevice(
|
|
166
|
-
&deviceDesc, wgpu::CallbackMode::AllowProcessEvents,
|
|
167
|
-
[asyncRunner = _async, resolve, reject, label, creationRuntime,
|
|
168
|
-
deviceLostBinding](wgpu::RequestDeviceStatus status,
|
|
169
|
-
wgpu::Device device,
|
|
170
|
-
wgpu::StringView message) {
|
|
171
|
-
if (message.length) {
|
|
172
|
-
fprintf(stderr, "%s", message.data);
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
if (status != wgpu::RequestDeviceStatus::Success || !device) {
|
|
176
|
-
std::string error =
|
|
177
|
-
message.length ? std::string(message.data, message.length)
|
|
178
|
-
: "Failed to request device";
|
|
179
|
-
reject(std::move(error));
|
|
180
|
-
return;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
device.SetLoggingCallback(
|
|
184
|
-
[](wgpu::LoggingType type, wgpu::StringView msg,
|
|
185
|
-
jsi::Runtime *creationRuntime) {
|
|
186
|
-
if (creationRuntime == nullptr) {
|
|
187
|
-
return;
|
|
188
|
-
}
|
|
189
|
-
const char *logLevel = "";
|
|
190
|
-
switch (type) {
|
|
191
|
-
case wgpu::LoggingType::Warning:
|
|
192
|
-
logLevel = "Warning";
|
|
193
|
-
Logger::warnToJavascriptConsole(
|
|
194
|
-
*creationRuntime,
|
|
195
|
-
std::string(msg.data, msg.length));
|
|
196
|
-
break;
|
|
197
|
-
case wgpu::LoggingType::Error:
|
|
198
|
-
logLevel = "Error";
|
|
199
|
-
Logger::errorToJavascriptConsole(
|
|
200
|
-
*creationRuntime,
|
|
201
|
-
std::string(msg.data, msg.length));
|
|
202
|
-
break;
|
|
203
|
-
case wgpu::LoggingType::Verbose:
|
|
204
|
-
logLevel = "Verbose";
|
|
205
|
-
break;
|
|
206
|
-
case wgpu::LoggingType::Info:
|
|
207
|
-
logLevel = "Info";
|
|
208
|
-
break;
|
|
209
|
-
default:
|
|
210
|
-
logLevel = "Unknown";
|
|
211
|
-
Logger::logToConsole("%s: %.*s", logLevel,
|
|
212
|
-
static_cast<int>(msg.length),
|
|
213
|
-
msg.data);
|
|
214
|
-
}
|
|
215
|
-
},
|
|
216
|
-
creationRuntime);
|
|
217
|
-
|
|
218
|
-
auto deviceHost = std::make_shared<GPUDevice>(std::move(device),
|
|
219
|
-
asyncRunner, label);
|
|
220
|
-
*deviceLostBinding = deviceHost;
|
|
221
|
-
|
|
222
|
-
// Register the device in the static registry so the uncaptured
|
|
223
|
-
// error callback can find it
|
|
224
|
-
GPUDevice::registerDevice(deviceHost->get().Get(), deviceHost);
|
|
225
|
-
|
|
226
|
-
resolve([deviceHost = std::move(deviceHost)](
|
|
227
|
-
jsi::Runtime &runtime) mutable {
|
|
228
|
-
return JSIConverter<std::shared_ptr<GPUDevice>>::toJSI(
|
|
229
|
-
runtime, deviceHost);
|
|
230
|
-
});
|
|
231
|
-
});
|
|
232
|
-
});
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
std::unordered_set<std::string> GPUAdapter::getFeatures() {
|
|
236
|
-
wgpu::SupportedFeatures supportedFeatures;
|
|
237
|
-
_instance.GetFeatures(&supportedFeatures);
|
|
238
|
-
std::unordered_set<std::string> result;
|
|
239
|
-
std::unordered_set<wgpu::FeatureName> enabled;
|
|
240
|
-
for (size_t i = 0; i < supportedFeatures.featureCount; ++i) {
|
|
241
|
-
auto feature = supportedFeatures.features[i];
|
|
242
|
-
enabled.insert(feature);
|
|
243
|
-
std::string name;
|
|
244
|
-
convertEnumToJSUnion(feature, &name);
|
|
245
|
-
if (name != "") {
|
|
246
|
-
result.insert(name);
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
maybeSynthesizeRnNativeTextureFeature(enabled, result);
|
|
250
|
-
return result;
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
std::shared_ptr<GPUSupportedLimits> GPUAdapter::getLimits() {
|
|
254
|
-
wgpu::Limits limits{};
|
|
255
|
-
if (!_instance.GetLimits(&limits)) {
|
|
256
|
-
throw std::runtime_error("Failed to get limits");
|
|
257
|
-
}
|
|
258
|
-
return std::make_shared<GPUSupportedLimits>(limits);
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
std::shared_ptr<GPUAdapterInfo> GPUAdapter::getInfo() {
|
|
262
|
-
wgpu::AdapterInfo info = {};
|
|
263
|
-
_instance.GetInfo(&info);
|
|
264
|
-
return std::make_shared<GPUAdapterInfo>(info);
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
} // namespace rnwgpu
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <memory>
|
|
4
|
-
#include <string>
|
|
5
|
-
#include <unordered_set>
|
|
6
|
-
|
|
7
|
-
#include "Unions.h"
|
|
8
|
-
|
|
9
|
-
#include "NativeObject.h"
|
|
10
|
-
|
|
11
|
-
#include "rnwgpu/async/AsyncRunner.h"
|
|
12
|
-
#include "rnwgpu/async/AsyncTaskHandle.h"
|
|
13
|
-
|
|
14
|
-
#include "webgpu/webgpu_cpp.h"
|
|
15
|
-
|
|
16
|
-
#include "GPUAdapterInfo.h"
|
|
17
|
-
#include "GPUDevice.h"
|
|
18
|
-
#include "GPUDeviceDescriptor.h"
|
|
19
|
-
#include "GPUSupportedLimits.h"
|
|
20
|
-
|
|
21
|
-
namespace rnwgpu {
|
|
22
|
-
|
|
23
|
-
namespace jsi = facebook::jsi;
|
|
24
|
-
|
|
25
|
-
class GPUAdapter : public NativeObject<GPUAdapter> {
|
|
26
|
-
public:
|
|
27
|
-
static constexpr const char *CLASS_NAME = "GPUAdapter";
|
|
28
|
-
|
|
29
|
-
explicit GPUAdapter(wgpu::Adapter instance,
|
|
30
|
-
std::shared_ptr<async::AsyncRunner> async)
|
|
31
|
-
: NativeObject(CLASS_NAME), _instance(instance), _async(async) {}
|
|
32
|
-
|
|
33
|
-
public:
|
|
34
|
-
std::string getBrand() { return CLASS_NAME; }
|
|
35
|
-
|
|
36
|
-
async::AsyncTaskHandle
|
|
37
|
-
requestDevice(std::optional<std::shared_ptr<GPUDeviceDescriptor>> descriptor);
|
|
38
|
-
|
|
39
|
-
std::unordered_set<std::string> getFeatures();
|
|
40
|
-
std::shared_ptr<GPUSupportedLimits> getLimits();
|
|
41
|
-
std::shared_ptr<GPUAdapterInfo> getInfo();
|
|
42
|
-
|
|
43
|
-
static void definePrototype(jsi::Runtime &runtime, jsi::Object &prototype) {
|
|
44
|
-
installGetter(runtime, prototype, "__brand", &GPUAdapter::getBrand);
|
|
45
|
-
installMethod(runtime, prototype, "requestDevice",
|
|
46
|
-
&GPUAdapter::requestDevice);
|
|
47
|
-
installGetter(runtime, prototype, "features", &GPUAdapter::getFeatures);
|
|
48
|
-
installGetter(runtime, prototype, "limits", &GPUAdapter::getLimits);
|
|
49
|
-
installGetter(runtime, prototype, "info", &GPUAdapter::getInfo);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
inline const wgpu::Adapter get() { return _instance; }
|
|
53
|
-
|
|
54
|
-
private:
|
|
55
|
-
wgpu::Adapter _instance;
|
|
56
|
-
std::shared_ptr<async::AsyncRunner> _async;
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
} // namespace rnwgpu
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <string>
|
|
4
|
-
#include <utility>
|
|
5
|
-
|
|
6
|
-
#include "Unions.h"
|
|
7
|
-
|
|
8
|
-
#include "NativeObject.h"
|
|
9
|
-
|
|
10
|
-
#include "Convertors.h"
|
|
11
|
-
|
|
12
|
-
#include "webgpu/webgpu_cpp.h"
|
|
13
|
-
|
|
14
|
-
namespace rnwgpu {
|
|
15
|
-
|
|
16
|
-
namespace jsi = facebook::jsi;
|
|
17
|
-
|
|
18
|
-
class GPUAdapterInfo : public NativeObject<GPUAdapterInfo> {
|
|
19
|
-
public:
|
|
20
|
-
static constexpr const char *CLASS_NAME = "GPUAdapterInfo";
|
|
21
|
-
|
|
22
|
-
explicit GPUAdapterInfo(wgpu::AdapterInfo &info)
|
|
23
|
-
: NativeObject(CLASS_NAME), _vendor(info.vendor),
|
|
24
|
-
_architecture(info.architecture), _device(info.device),
|
|
25
|
-
_description(info.description),
|
|
26
|
-
_isFallbackAdapter(info.adapterType == wgpu::AdapterType::CPU) {}
|
|
27
|
-
|
|
28
|
-
public:
|
|
29
|
-
std::string getBrand() { return CLASS_NAME; }
|
|
30
|
-
|
|
31
|
-
std::string getVendor() { return _vendor; }
|
|
32
|
-
std::string getArchitecture() { return _architecture; }
|
|
33
|
-
std::string getDevice() { return _device; }
|
|
34
|
-
std::string getDescription() { return _description; }
|
|
35
|
-
bool getIsFallbackAdapter() { return _isFallbackAdapter; }
|
|
36
|
-
|
|
37
|
-
static void definePrototype(jsi::Runtime &runtime, jsi::Object &prototype) {
|
|
38
|
-
installGetter(runtime, prototype, "__brand", &GPUAdapterInfo::getBrand);
|
|
39
|
-
installGetter(runtime, prototype, "vendor", &GPUAdapterInfo::getVendor);
|
|
40
|
-
installGetter(runtime, prototype, "architecture",
|
|
41
|
-
&GPUAdapterInfo::getArchitecture);
|
|
42
|
-
installGetter(runtime, prototype, "device", &GPUAdapterInfo::getDevice);
|
|
43
|
-
installGetter(runtime, prototype, "description",
|
|
44
|
-
&GPUAdapterInfo::getDescription);
|
|
45
|
-
installGetter(runtime, prototype, "isFallbackAdapter",
|
|
46
|
-
&GPUAdapterInfo::getIsFallbackAdapter);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
private:
|
|
50
|
-
std::string _vendor;
|
|
51
|
-
std::string _architecture;
|
|
52
|
-
std::string _device;
|
|
53
|
-
std::string _description;
|
|
54
|
-
bool _isFallbackAdapter;
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
} // namespace rnwgpu
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <string>
|
|
4
|
-
|
|
5
|
-
#include "Unions.h"
|
|
6
|
-
|
|
7
|
-
#include "NativeObject.h"
|
|
8
|
-
|
|
9
|
-
#include "webgpu/webgpu_cpp.h"
|
|
10
|
-
|
|
11
|
-
namespace rnwgpu {
|
|
12
|
-
|
|
13
|
-
namespace jsi = facebook::jsi;
|
|
14
|
-
|
|
15
|
-
class GPUBindGroup : public NativeObject<GPUBindGroup> {
|
|
16
|
-
public:
|
|
17
|
-
static constexpr const char *CLASS_NAME = "GPUBindGroup";
|
|
18
|
-
|
|
19
|
-
explicit GPUBindGroup(wgpu::BindGroup instance, std::string label)
|
|
20
|
-
: NativeObject(CLASS_NAME), _instance(instance), _label(label) {}
|
|
21
|
-
|
|
22
|
-
public:
|
|
23
|
-
std::string getBrand() { return CLASS_NAME; }
|
|
24
|
-
|
|
25
|
-
std::string getLabel() { return _label; }
|
|
26
|
-
void setLabel(const std::string &label) {
|
|
27
|
-
_label = label;
|
|
28
|
-
_instance.SetLabel(_label.c_str());
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
static void definePrototype(jsi::Runtime &runtime, jsi::Object &prototype) {
|
|
32
|
-
installGetter(runtime, prototype, "__brand", &GPUBindGroup::getBrand);
|
|
33
|
-
installGetterSetter(runtime, prototype, "label", &GPUBindGroup::getLabel,
|
|
34
|
-
&GPUBindGroup::setLabel);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
inline const wgpu::BindGroup get() { return _instance; }
|
|
38
|
-
|
|
39
|
-
size_t getMemoryPressure() override {
|
|
40
|
-
// Bind groups store resource bindings and descriptor state
|
|
41
|
-
// They reference buffers, textures, samplers, etc.
|
|
42
|
-
// Estimate: 1KB per bind group (descriptor tables and binding state)
|
|
43
|
-
return 1024;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
private:
|
|
47
|
-
wgpu::BindGroup _instance;
|
|
48
|
-
std::string _label;
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
} // namespace rnwgpu
|