react-native-wgpu 0.2.10 → 0.3.1
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 +155 -69
- package/android/CMakeLists.txt +5 -7
- package/android/build.gradle +7 -18
- package/android/src/main/java/com/webgpu/WebGPUViewPackage.java +34 -10
- package/apple/MetalView.mm +0 -19
- package/apple/WebGPUModule.h +1 -9
- package/apple/WebGPUModule.mm +0 -3
- package/apple/WebGPUView.h +0 -3
- package/apple/WebGPUView.mm +0 -2
- package/cpp/WGPULogger.h +10 -0
- package/cpp/dawn/dawn_proc_table.h +1 -1
- package/cpp/dawn/webgpu.h +4855 -0
- package/cpp/dawn/webgpu_cpp.h +10168 -0
- package/cpp/dawn/wire/client/webgpu.h +354 -0
- package/cpp/dawn/wire/client/webgpu_cpp.h +10343 -0
- package/cpp/dawn/wire/client/webgpu_cpp_print.h +2715 -0
- package/cpp/jsi/RNFHybridObject.cpp +8 -4
- package/cpp/jsi/RNFHybridObject.h +7 -2
- package/cpp/jsi/RNFJSIConverter.h +13 -102
- package/cpp/jsi/RNFJSIHelper.h +5 -3
- package/cpp/jsi/RNFRuntimeState.cpp +18 -0
- package/cpp/jsi/RNFRuntimeState.h +106 -0
- package/cpp/rnwgpu/RNWebGPUManager.cpp +1 -9
- package/cpp/rnwgpu/api/GPU.cpp +51 -26
- package/cpp/rnwgpu/api/GPU.h +5 -18
- package/cpp/rnwgpu/api/GPUAdapter.cpp +79 -54
- package/cpp/rnwgpu/api/GPUAdapter.h +6 -6
- package/cpp/rnwgpu/api/GPUAdapterInfo.h +0 -1
- package/cpp/rnwgpu/api/GPUBindGroup.h +1 -3
- package/cpp/rnwgpu/api/GPUBindGroupLayout.h +1 -3
- package/cpp/rnwgpu/api/GPUBuffer.cpp +35 -32
- package/cpp/rnwgpu/api/GPUBuffer.h +9 -7
- package/cpp/rnwgpu/api/GPUCanvasContext.cpp +5 -1
- package/cpp/rnwgpu/api/GPUCanvasContext.h +0 -2
- package/cpp/rnwgpu/api/GPUCommandBuffer.h +1 -3
- package/cpp/rnwgpu/api/GPUCommandEncoder.h +1 -3
- package/cpp/rnwgpu/api/GPUCompilationInfo.h +0 -2
- package/cpp/rnwgpu/api/GPUCompilationMessage.h +1 -3
- package/cpp/rnwgpu/api/GPUComputePassEncoder.h +1 -3
- package/cpp/rnwgpu/api/GPUComputePipeline.h +1 -3
- package/cpp/rnwgpu/api/GPUDevice.cpp +183 -128
- package/cpp/rnwgpu/api/GPUDevice.h +22 -21
- package/cpp/rnwgpu/api/GPUDeviceLostInfo.h +1 -3
- package/cpp/rnwgpu/api/GPUExternalTexture.h +1 -3
- package/cpp/rnwgpu/api/GPUPipelineLayout.h +1 -3
- package/cpp/rnwgpu/api/GPUQuerySet.h +1 -3
- package/cpp/rnwgpu/api/GPUQueue.cpp +19 -8
- package/cpp/rnwgpu/api/GPUQueue.h +7 -6
- package/cpp/rnwgpu/api/GPURenderBundle.h +1 -3
- package/cpp/rnwgpu/api/GPURenderBundleEncoder.h +1 -3
- package/cpp/rnwgpu/api/GPURenderPassEncoder.h +1 -3
- package/cpp/rnwgpu/api/GPURenderPipeline.h +1 -3
- package/cpp/rnwgpu/api/GPUSampler.h +1 -3
- package/cpp/rnwgpu/api/GPUShaderModule.cpp +42 -28
- package/cpp/rnwgpu/api/GPUShaderModule.h +6 -6
- package/cpp/rnwgpu/api/GPUSupportedLimits.h +1 -3
- package/cpp/rnwgpu/api/GPUTexture.h +1 -3
- package/cpp/rnwgpu/api/GPUTextureView.h +1 -3
- package/cpp/rnwgpu/api/RNWebGPU.h +1 -7
- package/cpp/rnwgpu/async/AsyncDispatcher.h +28 -0
- package/cpp/rnwgpu/async/AsyncRunner.cpp +215 -0
- package/cpp/rnwgpu/async/AsyncRunner.h +53 -0
- package/cpp/rnwgpu/async/AsyncTaskHandle.cpp +181 -0
- package/cpp/rnwgpu/async/AsyncTaskHandle.h +55 -0
- package/cpp/rnwgpu/async/JSIMicrotaskDispatcher.cpp +23 -0
- package/cpp/rnwgpu/async/JSIMicrotaskDispatcher.h +22 -0
- package/cpp/webgpu/webgpu.h +5 -4827
- package/cpp/webgpu/webgpu_cpp.h +5 -10140
- package/cpp/{dawn/native/WebGPUBackend.h → webgpu/webgpu_cpp_print.h} +4 -20
- package/lib/commonjs/Canvas.js +6 -66
- package/lib/commonjs/Canvas.js.map +1 -1
- package/lib/commonjs/hooks.js +6 -42
- package/lib/commonjs/hooks.js.map +1 -1
- package/lib/module/Canvas.js +7 -67
- package/lib/module/Canvas.js.map +1 -1
- package/lib/module/hooks.js +5 -40
- package/lib/module/hooks.js.map +1 -1
- package/lib/typescript/lib/commonjs/hooks.d.ts +1 -5
- package/lib/typescript/lib/commonjs/hooks.d.ts.map +1 -1
- package/lib/typescript/lib/module/Canvas.d.ts.map +1 -1
- package/lib/typescript/lib/module/hooks.d.ts +1 -5
- package/lib/typescript/lib/module/hooks.d.ts.map +1 -1
- package/lib/typescript/src/Canvas.d.ts +0 -1
- package/lib/typescript/src/Canvas.d.ts.map +1 -1
- package/lib/typescript/src/hooks.d.ts +2 -7
- package/lib/typescript/src/hooks.d.ts.map +1 -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 +5 -35
- 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/package.json +4 -3
- package/react-native-wgpu.podspec +12 -16
- package/src/Canvas.tsx +8 -69
- package/src/hooks.tsx +14 -48
- package/android/cpp/platform/ThreadUtils.cpp +0 -41
- package/android/src/oldarch/com/webgpu/NativeWebGPUModuleSpec.java +0 -23
- package/android/src/oldarch/com/webgpu/WebGPUViewManagerSpec.java +0 -12
- package/apple/WebGPUViewManager.mm +0 -24
- package/apple/platform/ThreadUtils.cpp +0 -34
- package/cpp/dawn/dawn_proc.h +0 -50
- package/cpp/dawn/dawn_thread_dispatch_proc.h +0 -47
- package/cpp/dawn/native/D3D11Backend.h +0 -77
- package/cpp/dawn/native/D3D12Backend.h +0 -68
- package/cpp/dawn/native/D3DBackend.h +0 -56
- package/cpp/dawn/native/MetalBackend.h +0 -56
- package/cpp/dawn/platform/DawnPlatform.h +0 -167
- package/cpp/dawn/platform/dawn_platform_export.h +0 -49
- package/cpp/jsi/RNFRuntimeCache.cpp +0 -57
- package/cpp/jsi/RNFRuntimeCache.h +0 -79
- package/cpp/jsi/RNFWorkletRuntimeCollector.h +0 -43
- package/cpp/jsi/RNFWorkletRuntimeRegistry.cpp +0 -12
- package/cpp/jsi/RNFWorkletRuntimeRegistry.h +0 -44
- package/cpp/platform/ThreadUtils.h +0 -30
- package/cpp/rnwgpu/api/AsyncRunner.h +0 -30
- package/cpp/threading/CallInvokerDispatcher.h +0 -37
- package/cpp/threading/Dispatcher.cpp +0 -55
- package/cpp/threading/Dispatcher.h +0 -93
- package/cpp/threading/ThreadPool.cpp +0 -88
- package/cpp/threading/ThreadPool.h +0 -53
- package/cpp/webgpu/webgpu_glfw.h +0 -88
- package/lib/typescript/src/__tests__/Alpha.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/Alpha.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/ArrayBuffer.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/ArrayBuffer.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/Buffer.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/Buffer.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/ComputeShader.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/ComputeShader.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/Constants.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/Constants.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/Device.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/Device.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/ErrorScope.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/ErrorScope.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/ExternalTexture.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/ExternalTexture.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/GPU.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/GPU.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/ImageData.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/ImageData.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/Shaders.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/Shaders.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/Texture.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/Texture.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/Wireframe/Shaders.d.ts +0 -3
- package/lib/typescript/src/__tests__/components/Wireframe/Shaders.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/Wireframe/models.d.ts +0 -29
- package/lib/typescript/src/__tests__/components/Wireframe/models.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/Wireframe/utils.d.ts +0 -5
- package/lib/typescript/src/__tests__/components/Wireframe/utils.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/cube.d.ts +0 -7
- package/lib/typescript/src/__tests__/components/cube.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/meshes/mesh.d.ts +0 -22
- package/lib/typescript/src/__tests__/components/meshes/mesh.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/meshes/sphere.d.ts +0 -12
- package/lib/typescript/src/__tests__/components/meshes/sphere.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/meshes/stanfordDragon.d.ts +0 -7
- package/lib/typescript/src/__tests__/components/meshes/stanfordDragon.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/meshes/stanfordDragonData.d.ts +0 -6
- package/lib/typescript/src/__tests__/components/meshes/stanfordDragonData.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/meshes/teapot.d.ts +0 -6
- package/lib/typescript/src/__tests__/components/meshes/teapot.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/meshes/utils.d.ts +0 -10
- package/lib/typescript/src/__tests__/components/meshes/utils.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/components/triangle.d.ts +0 -3
- package/lib/typescript/src/__tests__/components/triangle.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/config.d.ts +0 -3
- package/lib/typescript/src/__tests__/config.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/ABuffer.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/ABuffer.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/Blur.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/Blur.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/Cube.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/Cube.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/FractalCube.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/FractalCube.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/OcclusionQuery.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/OcclusionQuery.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/RenderBundles.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/RenderBundles.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/Triangle.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/Triangle.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/demos/Wireframe.spec.d.ts +0 -2
- package/lib/typescript/src/__tests__/demos/Wireframe.spec.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/globalSetup.d.ts +0 -3
- package/lib/typescript/src/__tests__/globalSetup.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/globalTeardown.d.ts +0 -3
- package/lib/typescript/src/__tests__/globalTeardown.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/setup.d.ts +0 -63
- package/lib/typescript/src/__tests__/setup.d.ts.map +0 -1
- package/libs/apple/arm64_iphoneos/libwebgpu_dawn.a +0 -0
- package/libs/apple/arm64_iphonesimulator/libwebgpu_dawn.a +0 -0
- package/libs/apple/arm64_xros/libwebgpu_dawn.a +0 -0
- package/libs/apple/arm64_xrsimulator/libwebgpu_dawn.a +0 -0
- package/libs/apple/iphonesimulator/libwebgpu_dawn.a +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/xros-arm64/libwebgpu_dawn.a +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/xros-arm64-simulator/libwebgpu_dawn.a +0 -0
- package/libs/apple/universal_macosx/libwebgpu_dawn.a +0 -0
- package/libs/apple/x86_64_iphonesimulator/libwebgpu_dawn.a +0 -0
- package/libs/dawn.json +0 -4670
- package/src/__tests__/Alpha.spec.ts +0 -28
- package/src/__tests__/ArrayBuffer.spec.ts +0 -76
- package/src/__tests__/Buffer.spec.ts +0 -357
- package/src/__tests__/ComputeShader.spec.ts +0 -375
- package/src/__tests__/Constants.spec.ts +0 -89
- package/src/__tests__/Device.spec.ts +0 -84
- package/src/__tests__/ErrorScope.spec.ts +0 -92
- package/src/__tests__/ExternalTexture.spec.ts +0 -284
- package/src/__tests__/GPU.spec.ts +0 -272
- package/src/__tests__/ImageData.spec.ts +0 -26
- package/src/__tests__/Shaders.spec.ts +0 -232
- package/src/__tests__/Texture.spec.ts +0 -197
- package/src/__tests__/assets/Di-3d.png +0 -0
- package/src/__tests__/components/Wireframe/Shaders.ts +0 -138
- package/src/__tests__/components/Wireframe/models.ts +0 -113
- package/src/__tests__/components/Wireframe/utils.ts +0 -22
- package/src/__tests__/components/cube.ts +0 -51
- package/src/__tests__/components/meshes/mesh.ts +0 -96
- package/src/__tests__/components/meshes/sphere.ts +0 -103
- package/src/__tests__/components/meshes/stanfordDragon.ts +0 -44
- package/src/__tests__/components/meshes/stanfordDragonData.ts +0 -5
- package/src/__tests__/components/meshes/teapot.ts +0 -13
- package/src/__tests__/components/meshes/utils.ts +0 -235
- package/src/__tests__/components/triangle.ts +0 -17
- package/src/__tests__/config.ts +0 -2
- package/src/__tests__/demos/ABuffer.spec.ts +0 -890
- package/src/__tests__/demos/Blur.spec.ts +0 -398
- package/src/__tests__/demos/Cube.spec.ts +0 -929
- package/src/__tests__/demos/FractalCube.spec.ts +0 -240
- package/src/__tests__/demos/OcclusionQuery.spec.ts +0 -376
- package/src/__tests__/demos/RenderBundles.spec.ts +0 -580
- package/src/__tests__/demos/Triangle.spec.ts +0 -266
- package/src/__tests__/demos/Wireframe.spec.ts +0 -188
- package/src/__tests__/globalSetup.ts +0 -45
- package/src/__tests__/globalTeardown.ts +0 -11
- package/src/__tests__/setup.ts +0 -423
- package/src/__tests__/snapshots/abuffer.png +0 -0
- package/src/__tests__/snapshots/asteroid.png +0 -0
- package/src/__tests__/snapshots/blur.png +0 -0
- package/src/__tests__/snapshots/buffer.png +0 -0
- package/src/__tests__/snapshots/constant-triangle.png +0 -0
- package/src/__tests__/snapshots/cube.png +0 -0
- package/src/__tests__/snapshots/f.png +0 -0
- package/src/__tests__/snapshots/f2.png +0 -0
- package/src/__tests__/snapshots/fractal-cubes.png +0 -0
- package/src/__tests__/snapshots/instanced-cubes.png +0 -0
- package/src/__tests__/snapshots/occlusion-query.png +0 -0
- package/src/__tests__/snapshots/ref.png +0 -0
- package/src/__tests__/snapshots/semi-opaque-cyan.png +0 -0
- package/src/__tests__/snapshots/texture.png +0 -0
- package/src/__tests__/snapshots/textured-cube.png +0 -0
- package/src/__tests__/snapshots/triangle-msaa.png +0 -0
- package/src/__tests__/snapshots/triangle.png +0 -0
- package/src/__tests__/snapshots/two-cube.png +0 -0
|
@@ -3,36 +3,50 @@
|
|
|
3
3
|
#include <memory>
|
|
4
4
|
#include <utility>
|
|
5
5
|
|
|
6
|
+
#include "RNFJSIConverter.h"
|
|
7
|
+
|
|
6
8
|
namespace rnwgpu {
|
|
7
9
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
10
|
+
async::AsyncTaskHandle GPUShaderModule::getCompilationInfo() {
|
|
11
|
+
auto module = _instance;
|
|
12
|
+
|
|
13
|
+
return _async->postTask(
|
|
14
|
+
[module](const async::AsyncTaskHandle::ResolveFunction &resolve,
|
|
15
|
+
const async::AsyncTaskHandle::RejectFunction &reject) {
|
|
16
|
+
auto result = std::make_shared<GPUCompilationInfo>();
|
|
17
|
+
module.GetCompilationInfo(
|
|
18
|
+
wgpu::CallbackMode::AllowProcessEvents,
|
|
19
|
+
[result, resolve,
|
|
20
|
+
reject](wgpu::CompilationInfoRequestStatus status,
|
|
21
|
+
const wgpu::CompilationInfo *compilationInfo) mutable {
|
|
22
|
+
if (status != wgpu::CompilationInfoRequestStatus::Success ||
|
|
23
|
+
compilationInfo == nullptr) {
|
|
24
|
+
reject("Failed to get compilation info");
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
result->_messages.reserve(compilationInfo->messageCount);
|
|
29
|
+
for (size_t i = 0; i < compilationInfo->messageCount; ++i) {
|
|
30
|
+
const auto &wgpuMessage = compilationInfo->messages[i];
|
|
31
|
+
GPUCompilationMessage message;
|
|
32
|
+
message.message =
|
|
33
|
+
wgpuMessage.message.length ? wgpuMessage.message.data : "";
|
|
34
|
+
message.type = wgpuMessage.type;
|
|
35
|
+
message.lineNum = wgpuMessage.lineNum;
|
|
36
|
+
message.linePos = wgpuMessage.linePos;
|
|
37
|
+
message.offset = wgpuMessage.offset;
|
|
38
|
+
message.length = wgpuMessage.length;
|
|
39
|
+
result->_messages.push_back(std::move(message));
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
resolve(
|
|
43
|
+
[result = std::move(result)](jsi::Runtime &runtime) mutable {
|
|
44
|
+
return margelo::JSIConverter<
|
|
45
|
+
std::shared_ptr<GPUCompilationInfo>>::toJSI(runtime,
|
|
46
|
+
result);
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
});
|
|
36
50
|
}
|
|
37
51
|
|
|
38
52
|
} // namespace rnwgpu
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
#pragma once
|
|
2
2
|
|
|
3
|
-
#include <future>
|
|
4
3
|
#include <memory>
|
|
5
4
|
#include <string>
|
|
6
5
|
|
|
@@ -8,7 +7,8 @@
|
|
|
8
7
|
|
|
9
8
|
#include "RNFHybridObject.h"
|
|
10
9
|
|
|
11
|
-
#include "AsyncRunner.h"
|
|
10
|
+
#include "rnwgpu/async/AsyncRunner.h"
|
|
11
|
+
#include "rnwgpu/async/AsyncTaskHandle.h"
|
|
12
12
|
|
|
13
13
|
#include "webgpu/webgpu_cpp.h"
|
|
14
14
|
|
|
@@ -21,7 +21,7 @@ namespace m = margelo;
|
|
|
21
21
|
class GPUShaderModule : public m::HybridObject {
|
|
22
22
|
public:
|
|
23
23
|
explicit GPUShaderModule(wgpu::ShaderModule instance,
|
|
24
|
-
std::shared_ptr<AsyncRunner> async,
|
|
24
|
+
std::shared_ptr<async::AsyncRunner> async,
|
|
25
25
|
std::string label)
|
|
26
26
|
: HybridObject("GPUShaderModule"), _instance(instance), _async(async),
|
|
27
27
|
_label(label) {}
|
|
@@ -29,7 +29,7 @@ public:
|
|
|
29
29
|
public:
|
|
30
30
|
std::string getBrand() { return _name; }
|
|
31
31
|
|
|
32
|
-
|
|
32
|
+
async::AsyncTaskHandle getCompilationInfo();
|
|
33
33
|
|
|
34
34
|
std::string getLabel() { return _label; }
|
|
35
35
|
void setLabel(const std::string &label) {
|
|
@@ -58,8 +58,8 @@ public:
|
|
|
58
58
|
|
|
59
59
|
private:
|
|
60
60
|
wgpu::ShaderModule _instance;
|
|
61
|
-
std::shared_ptr<AsyncRunner> _async;
|
|
61
|
+
std::shared_ptr<async::AsyncRunner> _async;
|
|
62
62
|
std::string _label;
|
|
63
63
|
};
|
|
64
64
|
|
|
65
|
-
} // namespace rnwgpu
|
|
65
|
+
} // namespace rnwgpu
|
|
@@ -8,8 +8,6 @@
|
|
|
8
8
|
|
|
9
9
|
#include "RNFHybridObject.h"
|
|
10
10
|
|
|
11
|
-
#include "AsyncRunner.h"
|
|
12
|
-
|
|
13
11
|
#include "webgpu/webgpu_cpp.h"
|
|
14
12
|
|
|
15
13
|
#include "GPUTextureView.h"
|
|
@@ -145,4 +143,4 @@ private:
|
|
|
145
143
|
std::string _label;
|
|
146
144
|
};
|
|
147
145
|
|
|
148
|
-
} // namespace rnwgpu
|
|
146
|
+
} // namespace rnwgpu
|
|
@@ -30,13 +30,7 @@ public:
|
|
|
30
30
|
|
|
31
31
|
std::shared_ptr<GPU> getGPU() { return _gpu; }
|
|
32
32
|
|
|
33
|
-
bool getFabric() {
|
|
34
|
-
#ifdef RCT_NEW_ARCH_ENABLED
|
|
35
|
-
return true;
|
|
36
|
-
#else
|
|
37
|
-
return false;
|
|
38
|
-
#endif
|
|
39
|
-
}
|
|
33
|
+
bool getFabric() { return true; }
|
|
40
34
|
|
|
41
35
|
std::shared_ptr<GPUCanvasContext>
|
|
42
36
|
MakeWebGPUCanvasContext(int contextId, float width, float height) {
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <functional>
|
|
4
|
+
#include <memory>
|
|
5
|
+
|
|
6
|
+
#include <jsi/jsi.h>
|
|
7
|
+
|
|
8
|
+
namespace rnwgpu::async {
|
|
9
|
+
|
|
10
|
+
namespace jsi = facebook::jsi;
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Abstract dispatcher used by the AsyncRunner to enqueue work back onto the
|
|
14
|
+
* JavaScript thread.
|
|
15
|
+
*/
|
|
16
|
+
class AsyncDispatcher {
|
|
17
|
+
public:
|
|
18
|
+
using Work = std::function<void(jsi::Runtime &)>;
|
|
19
|
+
|
|
20
|
+
virtual ~AsyncDispatcher() = default;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Enqueue a unit of work that will be executed on the JavaScript thread.
|
|
24
|
+
*/
|
|
25
|
+
virtual void post(Work work) = 0;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
} // namespace rnwgpu::async
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
#include "AsyncRunner.h"
|
|
2
|
+
|
|
3
|
+
#include <chrono>
|
|
4
|
+
#include <stdexcept>
|
|
5
|
+
#include <utility>
|
|
6
|
+
|
|
7
|
+
#include "AsyncTaskHandle.h"
|
|
8
|
+
#include "WGPULogger.h"
|
|
9
|
+
|
|
10
|
+
namespace rnwgpu::async {
|
|
11
|
+
|
|
12
|
+
namespace {
|
|
13
|
+
struct RuntimeData {
|
|
14
|
+
std::shared_ptr<AsyncRunner> runner;
|
|
15
|
+
};
|
|
16
|
+
constexpr const char *TAG = "AsyncRunner";
|
|
17
|
+
} // namespace
|
|
18
|
+
|
|
19
|
+
AsyncRunner::AsyncRunner(wgpu::Instance instance,
|
|
20
|
+
std::shared_ptr<AsyncDispatcher> dispatcher)
|
|
21
|
+
: _instance(std::move(instance)), _dispatcher(std::move(dispatcher)),
|
|
22
|
+
_pendingTasks(0), _pumpTasks(0), _tickScheduled(false),
|
|
23
|
+
_lastTickTimeNs(0) {
|
|
24
|
+
if (!_dispatcher) {
|
|
25
|
+
throw std::runtime_error("AsyncRunner requires a valid dispatcher.");
|
|
26
|
+
}
|
|
27
|
+
Logger::logToConsole("[%s] Created runner (dispatcher=%p)", TAG,
|
|
28
|
+
_dispatcher.get());
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
std::shared_ptr<AsyncRunner> AsyncRunner::get(jsi::Runtime &runtime) {
|
|
32
|
+
auto data = runtime.getRuntimeData(runtimeDataUUID());
|
|
33
|
+
if (!data) {
|
|
34
|
+
return nullptr;
|
|
35
|
+
}
|
|
36
|
+
auto stored = std::static_pointer_cast<RuntimeData>(data);
|
|
37
|
+
return stored->runner;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
std::shared_ptr<AsyncRunner>
|
|
41
|
+
AsyncRunner::getOrCreate(jsi::Runtime &runtime, wgpu::Instance instance,
|
|
42
|
+
std::shared_ptr<AsyncDispatcher> dispatcher) {
|
|
43
|
+
auto existing = get(runtime);
|
|
44
|
+
if (existing) {
|
|
45
|
+
return existing;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
auto runner =
|
|
49
|
+
std::make_shared<AsyncRunner>(std::move(instance), std::move(dispatcher));
|
|
50
|
+
auto data = std::make_shared<RuntimeData>();
|
|
51
|
+
data->runner = runner;
|
|
52
|
+
runtime.setRuntimeData(runtimeDataUUID(), data);
|
|
53
|
+
return runner;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
AsyncTaskHandle AsyncRunner::postTask(const TaskCallback &callback,
|
|
57
|
+
bool keepPumping) {
|
|
58
|
+
auto handle = AsyncTaskHandle::create(shared_from_this(), keepPumping);
|
|
59
|
+
if (!handle.valid()) {
|
|
60
|
+
throw std::runtime_error("Failed to create AsyncTaskHandle.");
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
_pendingTasks.fetch_add(1, std::memory_order_acq_rel);
|
|
64
|
+
if (keepPumping) {
|
|
65
|
+
_pumpTasks.fetch_add(1, std::memory_order_acq_rel);
|
|
66
|
+
}
|
|
67
|
+
requestTick();
|
|
68
|
+
|
|
69
|
+
Logger::logToConsole(
|
|
70
|
+
"[%s] postTask (keepPumping=%s, pending=%zu, pumping=%zu)", TAG,
|
|
71
|
+
keepPumping ? "true" : "false",
|
|
72
|
+
_pendingTasks.load(std::memory_order_acquire),
|
|
73
|
+
_pumpTasks.load(std::memory_order_acquire));
|
|
74
|
+
|
|
75
|
+
auto resolve = handle.createResolveFunction();
|
|
76
|
+
auto reject = handle.createRejectFunction();
|
|
77
|
+
|
|
78
|
+
try {
|
|
79
|
+
callback(resolve, reject);
|
|
80
|
+
} catch (const std::exception &exception) {
|
|
81
|
+
reject(exception.what());
|
|
82
|
+
} catch (...) {
|
|
83
|
+
reject("Unknown native error in AsyncRunner::postTask.");
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
return handle;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
void AsyncRunner::requestTick() {
|
|
90
|
+
bool expected = false;
|
|
91
|
+
if (!_tickScheduled.compare_exchange_strong(expected, true,
|
|
92
|
+
std::memory_order_acq_rel)) {
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
auto self = shared_from_this();
|
|
97
|
+
_dispatcher->post([self](jsi::Runtime &runtime) {
|
|
98
|
+
auto tickCallback = jsi::Function::createFromHostFunction(
|
|
99
|
+
runtime, jsi::PropNameID::forAscii(runtime, "AsyncRunnerTick"), 0,
|
|
100
|
+
[self](jsi::Runtime &runtime, const jsi::Value & /*thisValue*/,
|
|
101
|
+
const jsi::Value * /*args*/, size_t /*count*/) -> jsi::Value {
|
|
102
|
+
self->tick(runtime);
|
|
103
|
+
return jsi::Value::undefined();
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
#if defined(ANDROID) || defined(__ANDROID__)
|
|
107
|
+
auto global = runtime.global();
|
|
108
|
+
auto setImmediateValue = global.getProperty(runtime, "setImmediate");
|
|
109
|
+
constexpr auto kMinTickInterval = std::chrono::milliseconds(4);
|
|
110
|
+
const int64_t nowNs =
|
|
111
|
+
std::chrono::duration_cast<std::chrono::nanoseconds>(
|
|
112
|
+
std::chrono::steady_clock::now().time_since_epoch())
|
|
113
|
+
.count();
|
|
114
|
+
const int64_t lastNs =
|
|
115
|
+
self->_lastTickTimeNs.load(std::memory_order_acquire);
|
|
116
|
+
int delayMs = 0;
|
|
117
|
+
if (lastNs > 0) {
|
|
118
|
+
const int64_t elapsedNs = nowNs - lastNs;
|
|
119
|
+
const int64_t minIntervalNs = kMinTickInterval.count() * 1000000LL;
|
|
120
|
+
if (elapsedNs < minIntervalNs) {
|
|
121
|
+
const int64_t remainingNs = minIntervalNs - elapsedNs;
|
|
122
|
+
delayMs = static_cast<int>((remainingNs + 999999) / 1000000);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
auto tryScheduleTimeout = [&](int ms) {
|
|
127
|
+
auto setTimeoutValue = global.getProperty(runtime, "setTimeout");
|
|
128
|
+
if (!setTimeoutValue.isObject()) {
|
|
129
|
+
return false;
|
|
130
|
+
}
|
|
131
|
+
auto setTimeoutObj = setTimeoutValue.asObject(runtime);
|
|
132
|
+
if (!setTimeoutObj.isFunction(runtime)) {
|
|
133
|
+
return false;
|
|
134
|
+
}
|
|
135
|
+
Logger::logToConsole("[%s] requestTick scheduled via setTimeout(%d)", TAG,
|
|
136
|
+
ms);
|
|
137
|
+
auto setTimeoutFn = setTimeoutObj.asFunction(runtime);
|
|
138
|
+
jsi::Value callbackArg(runtime, tickCallback);
|
|
139
|
+
jsi::Value delayArg(static_cast<double>(ms));
|
|
140
|
+
setTimeoutFn.call(runtime, callbackArg, delayArg);
|
|
141
|
+
return true;
|
|
142
|
+
};
|
|
143
|
+
|
|
144
|
+
if (delayMs > 0) {
|
|
145
|
+
if (tryScheduleTimeout(delayMs)) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
// If setTimeout unavailable fall through to immediate scheduling.
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
if (setImmediateValue.isObject()) {
|
|
152
|
+
auto setImmediateObj = setImmediateValue.asObject(runtime);
|
|
153
|
+
if (setImmediateObj.isFunction(runtime)) {
|
|
154
|
+
Logger::logToConsole("[%s] requestTick scheduled via setImmediate",
|
|
155
|
+
TAG);
|
|
156
|
+
auto setImmediateFn = setImmediateObj.asFunction(runtime);
|
|
157
|
+
jsi::Value callbackArg(runtime, tickCallback);
|
|
158
|
+
setImmediateFn.call(runtime, callbackArg);
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
int timeoutDelayMs = delayMs > 0 ? delayMs : 0;
|
|
164
|
+
if (tryScheduleTimeout(timeoutDelayMs)) {
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
Logger::logToConsole("[%s] requestTick scheduled via microtask fallback",
|
|
169
|
+
TAG);
|
|
170
|
+
runtime.queueMicrotask(std::move(tickCallback));
|
|
171
|
+
#else
|
|
172
|
+
Logger::logToConsole("[%s] requestTick scheduled microtask (non-Android)",
|
|
173
|
+
TAG);
|
|
174
|
+
runtime.queueMicrotask(std::move(tickCallback));
|
|
175
|
+
#endif
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
void AsyncRunner::tick(jsi::Runtime & /*runtime*/) {
|
|
180
|
+
_tickScheduled.store(false, std::memory_order_release);
|
|
181
|
+
_instance.ProcessEvents();
|
|
182
|
+
const auto nowNs = std::chrono::duration_cast<std::chrono::nanoseconds>(
|
|
183
|
+
std::chrono::steady_clock::now().time_since_epoch())
|
|
184
|
+
.count();
|
|
185
|
+
_lastTickTimeNs.store(nowNs, std::memory_order_release);
|
|
186
|
+
Logger::logToConsole("[%s] tick processed events (pending=%zu, pumping=%zu)",
|
|
187
|
+
TAG, _pendingTasks.load(std::memory_order_acquire),
|
|
188
|
+
_pumpTasks.load(std::memory_order_acquire));
|
|
189
|
+
if (_pumpTasks.load(std::memory_order_acquire) > 0) {
|
|
190
|
+
requestTick();
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
void AsyncRunner::onTaskSettled(bool keepPumping) {
|
|
195
|
+
_pendingTasks.fetch_sub(1, std::memory_order_acq_rel);
|
|
196
|
+
if (keepPumping) {
|
|
197
|
+
_pumpTasks.fetch_sub(1, std::memory_order_acq_rel);
|
|
198
|
+
}
|
|
199
|
+
Logger::logToConsole(
|
|
200
|
+
"[%s] onTaskSettled (keepPumping=%s, pending=%zu, pumping=%zu)", TAG,
|
|
201
|
+
keepPumping ? "true" : "false",
|
|
202
|
+
_pendingTasks.load(std::memory_order_acquire),
|
|
203
|
+
_pumpTasks.load(std::memory_order_acquire));
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
std::shared_ptr<AsyncDispatcher> AsyncRunner::dispatcher() const {
|
|
207
|
+
return _dispatcher;
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
jsi::UUID AsyncRunner::runtimeDataUUID() {
|
|
211
|
+
static const auto uuid = jsi::UUID();
|
|
212
|
+
return uuid;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
} // namespace rnwgpu::async
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <atomic>
|
|
4
|
+
#include <cstdint>
|
|
5
|
+
#include <functional>
|
|
6
|
+
#include <memory>
|
|
7
|
+
|
|
8
|
+
#include <jsi/jsi.h>
|
|
9
|
+
|
|
10
|
+
#include "AsyncDispatcher.h"
|
|
11
|
+
#include "AsyncTaskHandle.h"
|
|
12
|
+
|
|
13
|
+
#include "webgpu/webgpu_cpp.h"
|
|
14
|
+
|
|
15
|
+
namespace jsi = facebook::jsi;
|
|
16
|
+
|
|
17
|
+
namespace rnwgpu::async {
|
|
18
|
+
|
|
19
|
+
class AsyncRunner : public std::enable_shared_from_this<AsyncRunner> {
|
|
20
|
+
public:
|
|
21
|
+
using TaskCallback =
|
|
22
|
+
std::function<void(const AsyncTaskHandle::ResolveFunction &,
|
|
23
|
+
const AsyncTaskHandle::RejectFunction &)>;
|
|
24
|
+
|
|
25
|
+
AsyncRunner(wgpu::Instance instance,
|
|
26
|
+
std::shared_ptr<AsyncDispatcher> dispatcher);
|
|
27
|
+
|
|
28
|
+
static std::shared_ptr<AsyncRunner> get(jsi::Runtime &runtime);
|
|
29
|
+
static std::shared_ptr<AsyncRunner>
|
|
30
|
+
getOrCreate(jsi::Runtime &runtime, wgpu::Instance instance,
|
|
31
|
+
std::shared_ptr<AsyncDispatcher> dispatcher);
|
|
32
|
+
|
|
33
|
+
AsyncTaskHandle postTask(const TaskCallback &callback,
|
|
34
|
+
bool keepPumping = true);
|
|
35
|
+
|
|
36
|
+
void requestTick();
|
|
37
|
+
void tick(jsi::Runtime &runtime);
|
|
38
|
+
void onTaskSettled(bool keepPumping);
|
|
39
|
+
|
|
40
|
+
std::shared_ptr<AsyncDispatcher> dispatcher() const;
|
|
41
|
+
|
|
42
|
+
private:
|
|
43
|
+
static jsi::UUID runtimeDataUUID();
|
|
44
|
+
|
|
45
|
+
wgpu::Instance _instance;
|
|
46
|
+
std::shared_ptr<AsyncDispatcher> _dispatcher;
|
|
47
|
+
std::atomic<size_t> _pendingTasks;
|
|
48
|
+
std::atomic<size_t> _pumpTasks;
|
|
49
|
+
std::atomic<bool> _tickScheduled;
|
|
50
|
+
std::atomic<int64_t> _lastTickTimeNs;
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
} // namespace rnwgpu::async
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
#include "AsyncTaskHandle.h"
|
|
2
|
+
|
|
3
|
+
#include <string>
|
|
4
|
+
#include <utility>
|
|
5
|
+
|
|
6
|
+
#include "RNFPromise.h"
|
|
7
|
+
|
|
8
|
+
#include "AsyncRunner.h"
|
|
9
|
+
|
|
10
|
+
namespace rnwgpu::async {
|
|
11
|
+
|
|
12
|
+
using Action = std::function<void(jsi::Runtime &, margelo::Promise &)>;
|
|
13
|
+
|
|
14
|
+
struct AsyncTaskHandle::State
|
|
15
|
+
: public std::enable_shared_from_this<AsyncTaskHandle::State> {
|
|
16
|
+
State(std::shared_ptr<AsyncRunner> runner, bool keepPumping)
|
|
17
|
+
: runner(std::move(runner)), keepPumping(keepPumping) {}
|
|
18
|
+
|
|
19
|
+
void settle(Action action);
|
|
20
|
+
void attachPromise(const std::shared_ptr<margelo::Promise> &promise);
|
|
21
|
+
void schedule(Action action);
|
|
22
|
+
|
|
23
|
+
ResolveFunction createResolveFunction();
|
|
24
|
+
RejectFunction createRejectFunction();
|
|
25
|
+
|
|
26
|
+
std::shared_ptr<margelo::Promise> currentPromise();
|
|
27
|
+
|
|
28
|
+
std::mutex mutex;
|
|
29
|
+
std::weak_ptr<AsyncRunner> runner;
|
|
30
|
+
std::shared_ptr<margelo::Promise> promise;
|
|
31
|
+
std::optional<Action> pendingAction;
|
|
32
|
+
bool settled = false;
|
|
33
|
+
std::shared_ptr<State> keepAlive;
|
|
34
|
+
bool keepPumping;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
// MARK: - State helpers
|
|
38
|
+
|
|
39
|
+
void AsyncTaskHandle::State::settle(Action action) {
|
|
40
|
+
std::optional<Action> actionToSchedule;
|
|
41
|
+
|
|
42
|
+
{
|
|
43
|
+
std::lock_guard<std::mutex> lock(mutex);
|
|
44
|
+
if (settled) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
settled = true;
|
|
48
|
+
|
|
49
|
+
if (promise) {
|
|
50
|
+
actionToSchedule = std::move(action);
|
|
51
|
+
} else {
|
|
52
|
+
pendingAction = std::move(action);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (actionToSchedule.has_value()) {
|
|
57
|
+
schedule(std::move(*actionToSchedule));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
void AsyncTaskHandle::State::attachPromise(
|
|
62
|
+
const std::shared_ptr<margelo::Promise> &newPromise) {
|
|
63
|
+
std::optional<Action> actionToSchedule;
|
|
64
|
+
{
|
|
65
|
+
std::lock_guard<std::mutex> lock(mutex);
|
|
66
|
+
promise = newPromise;
|
|
67
|
+
keepAlive = shared_from_this();
|
|
68
|
+
if (pendingAction.has_value()) {
|
|
69
|
+
actionToSchedule = std::move(pendingAction);
|
|
70
|
+
pendingAction.reset();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
if (actionToSchedule.has_value()) {
|
|
75
|
+
schedule(std::move(*actionToSchedule));
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
void AsyncTaskHandle::State::schedule(Action action) {
|
|
80
|
+
auto runnerRef = runner.lock();
|
|
81
|
+
if (!runnerRef) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
auto promiseRef = currentPromise();
|
|
86
|
+
if (!promiseRef) {
|
|
87
|
+
runnerRef->onTaskSettled(keepPumping);
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
auto dispatcherRef = runnerRef->dispatcher();
|
|
92
|
+
if (!dispatcherRef) {
|
|
93
|
+
runnerRef->onTaskSettled(keepPumping);
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
dispatcherRef->post([self = shared_from_this(), action = std::move(action),
|
|
98
|
+
runnerRef, promiseRef](jsi::Runtime &runtime) mutable {
|
|
99
|
+
runnerRef->onTaskSettled(self->keepPumping);
|
|
100
|
+
action(runtime, *promiseRef);
|
|
101
|
+
std::lock_guard<std::mutex> lock(self->mutex);
|
|
102
|
+
self->keepAlive.reset();
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
AsyncTaskHandle::ResolveFunction
|
|
107
|
+
AsyncTaskHandle::State::createResolveFunction() {
|
|
108
|
+
auto weakSelf = std::weak_ptr<State>(shared_from_this());
|
|
109
|
+
return [weakSelf](ValueFactory factory) {
|
|
110
|
+
if (auto self = weakSelf.lock()) {
|
|
111
|
+
ValueFactory resolvedFactory =
|
|
112
|
+
factory ? std::move(factory) : [](jsi::Runtime &runtime) {
|
|
113
|
+
return jsi::Value::undefined();
|
|
114
|
+
};
|
|
115
|
+
self->settle(
|
|
116
|
+
[factory = std::move(resolvedFactory)](
|
|
117
|
+
jsi::Runtime &runtime, margelo::Promise &promise) mutable {
|
|
118
|
+
auto value = factory(runtime);
|
|
119
|
+
promise.resolve(std::move(value));
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
AsyncTaskHandle::RejectFunction AsyncTaskHandle::State::createRejectFunction() {
|
|
126
|
+
auto weakSelf = std::weak_ptr<State>(shared_from_this());
|
|
127
|
+
return [weakSelf](std::string reason) {
|
|
128
|
+
if (auto self = weakSelf.lock()) {
|
|
129
|
+
self->settle([reason = std::move(reason)](jsi::Runtime & /*runtime*/,
|
|
130
|
+
margelo::Promise &promise) {
|
|
131
|
+
promise.reject(reason);
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
std::shared_ptr<margelo::Promise> AsyncTaskHandle::State::currentPromise() {
|
|
138
|
+
std::lock_guard<std::mutex> lock(mutex);
|
|
139
|
+
return promise;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
// MARK: - AsyncTaskHandle
|
|
143
|
+
|
|
144
|
+
AsyncTaskHandle::AsyncTaskHandle() = default;
|
|
145
|
+
|
|
146
|
+
AsyncTaskHandle::AsyncTaskHandle(std::shared_ptr<State> state)
|
|
147
|
+
: _state(std::move(state)) {}
|
|
148
|
+
|
|
149
|
+
bool AsyncTaskHandle::valid() const { return _state != nullptr; }
|
|
150
|
+
|
|
151
|
+
AsyncTaskHandle
|
|
152
|
+
AsyncTaskHandle::create(const std::shared_ptr<AsyncRunner> &runner,
|
|
153
|
+
bool keepPumping) {
|
|
154
|
+
auto state = std::make_shared<State>(runner, keepPumping);
|
|
155
|
+
state->keepAlive = state;
|
|
156
|
+
return AsyncTaskHandle(std::move(state));
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
AsyncTaskHandle::ResolveFunction
|
|
160
|
+
AsyncTaskHandle::createResolveFunction() const {
|
|
161
|
+
if (!_state) {
|
|
162
|
+
return [](ValueFactory) {};
|
|
163
|
+
}
|
|
164
|
+
return _state->createResolveFunction();
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
AsyncTaskHandle::RejectFunction AsyncTaskHandle::createRejectFunction() const {
|
|
168
|
+
if (!_state) {
|
|
169
|
+
return [](std::string) {};
|
|
170
|
+
}
|
|
171
|
+
return _state->createRejectFunction();
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
void AsyncTaskHandle::attachPromise(
|
|
175
|
+
const std::shared_ptr<margelo::Promise> &promise) const {
|
|
176
|
+
if (_state) {
|
|
177
|
+
_state->attachPromise(promise);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
} // namespace rnwgpu::async
|