Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update gpuweb: replace requestAdapterInfo() with info #148

Merged
merged 2 commits into from
May 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
131 changes: 91 additions & 40 deletions dist/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -458,6 +458,9 @@ interface GPUBindGroupEntry {

interface GPUBindGroupLayoutDescriptor
extends GPUObjectDescriptorBase {
/**
* A list of entries describing the shader resource bindings for a bind group.
*/
entries: Iterable<GPUBindGroupLayoutEntry>;
}

Expand Down Expand Up @@ -809,9 +812,16 @@ interface GPUExternalTextureBindingLayout {}

interface GPUExternalTextureDescriptor
extends GPUObjectDescriptorBase {
/**
* The video source to import the external texture from.
*/
source:
| HTMLVideoElement
| VideoFrame;
/**
* The color space the image contents of {@link GPUExternalTextureDescriptor#source} will be
* converted into when reading.
*/
colorSpace?: PredefinedColorSpace;
}

Expand All @@ -838,35 +848,46 @@ interface GPUImageCopyExternalImage {
* The source of the image copy. The copy source data is captured at the moment that
* {@link GPUQueue#copyExternalImageToTexture} is issued. Source size is defined by source
* type, given by this table:
*
* <table class=data>
* <thead>
* <tr>
* <th>Source type
* <th>Width
* <th>Height
* <th>Dimensions
* </thead>
* <tbody>
* <tr>
* <td>{@link ImageBitmap}
* <td>{@link ImageBitmap#width|ImageBitmap.width}
* <td>{@link ImageBitmap#height|ImageBitmap.height}
* <td>{@link ImageBitmap#width|ImageBitmap.width},
* {@link ImageBitmap#height|ImageBitmap.height}
* <tr>
* <td>{@link HTMLImageElement}
* <td>{@link HTMLImageElement#naturalWidth|HTMLImageElement.naturalWidth},
* {@link HTMLImageElement#naturalHeight|HTMLImageElement.naturalHeight}
* <tr>
* <td>{@link HTMLVideoElement}
* <td>video/intrinsic width|intrinsic width of the frame
* <td>video/intrinsic height|intrinsic height of the frame
* <td>video/intrinsic width|intrinsic width of the frame,
* video/intrinsic height|intrinsic height of the frame
* <tr>
* <td>{@link VideoFrame}
* <td>{@link VideoFrame#codedWidth|VideoFrame.codedWidth}
* <td>{@link VideoFrame#codedHeight|VideoFrame.codedHeight}
* <td>{@link VideoFrame#codedWidth|VideoFrame.codedWidth},
* {@link VideoFrame#codedHeight|VideoFrame.codedHeight}
* <tr>
* <td>{@link ImageData}
* <td>{@link ImageData#width|ImageData.width},
* {@link ImageData#height|ImageData.height}
* <tr>
* <td>{@link HTMLCanvasElement} or {@link OffscreenCanvas} with {@link CanvasRenderingContext2D} or {@link GPUCanvasContext}
* <td>{@link HTMLCanvasElement#width|HTMLCanvasElement.width},
* {@link HTMLCanvasElement#height|HTMLCanvasElement.height}
* <tr>
* <td>{@link HTMLCanvasElement}
* <td>{@link HTMLCanvasElement#width|HTMLCanvasElement.width}
* <td>{@link HTMLCanvasElement#height|HTMLCanvasElement.height}
* <td>{@link HTMLCanvasElement} or {@link OffscreenCanvas} with {@link WebGLRenderingContextBase}
* <td>{@link WebGLRenderingContextBase#drawingBufferWidth|WebGLRenderingContextBase.drawingBufferWidth},
* {@link WebGLRenderingContextBase#drawingBufferHeight|WebGLRenderingContextBase.drawingBufferHeight}
* <tr>
* <td>{@link OffscreenCanvas}
* <td>{@link OffscreenCanvas#width|OffscreenCanvas.width}
* <td>{@link OffscreenCanvas#height|OffscreenCanvas.height}
* <td>{@link HTMLCanvasElement} or {@link OffscreenCanvas} with {@link ImageBitmapRenderingContext}
* <td>{@link ImageBitmapRenderingContext}'s internal output bitmap
* {@link ImageBitmap#width|ImageBitmap.width},
* {@link ImageBitmap#height|ImageBitmap.height}
* </tbody>
* </table>
*/
Expand Down Expand Up @@ -1059,16 +1080,23 @@ interface GPUProgrammableStage {
/**
* The name of the function in {@link GPUProgrammableStage#module} that this stage will use to
* perform its work.
* NOTE: Since the {@link GPUProgrammableStage#entryPoint} dictionary member is
* not required, methods which consume a {@link GPUProgrammableStage} must use the
* "[$get the entry point$]" algorithm to determine which entry point
* it refers to.
*/
entryPoint?: string;
/**
* Specifies the values of pipeline-overridable constants in the shader module
* {@link GPUProgrammableStage#module}.
* Each such pipeline-overridable constant is uniquely identified by a single
* pipeline-overridable constant identifier string (representing the numeric ID of the
* constant, if one is specified, and otherwise the constant's identifier name).
* WGSL names (identifiers) in source maps follow the rules defined in WGSL identifier comparison.
* The key of each key-value pair must equal the identifier string of one such constant.
* pipeline-overridable constant identifier string, representing the pipeline
* constant ID of the constant if its declaration specifies one, and otherwise the
* constant's identifier name.
* The key of each key-value pair must equal the
* pipeline-overridable constant identifier string|identifier string
* of one such constant, with the comparison performed
* according to the rules for WGSL identifier comparison.
* When the pipeline is executed, that constant will have the specified value.
* Values are specified as <dfn typedef for="">GPUPipelineConstantValue</dfn>, which is a {@link double}.
* They are converted [$to WGSL type$] of the pipeline-overridable constant (`bool`/`i32`/`u32`/`f32`/`f16`).
Expand Down Expand Up @@ -1186,7 +1214,7 @@ interface GPURenderPassDepthStencilAttachment {
* to prior to executing the render pass. Ignored if {@link GPURenderPassDepthStencilAttachment#stencilLoadOp}
* is not {@link GPULoadOp#"clear"}.
* The value will be converted to the type of the stencil aspect of `view` by taking the same
* number of LSBs as the number of bits in the stencil aspect of one texel block of `view`.
* number of LSBs as the number of bits in the stencil aspect of one texel block|texel of `view`.
*/
stencilClearValue?: GPUStencilValue;
/**
Expand Down Expand Up @@ -1381,10 +1409,17 @@ interface GPUSamplerDescriptor
*/
compare?: GPUCompareFunction;
/**
* Specifies the maximum anisotropy value clamp used by the sampler.
* Note: Most implementations support {@link GPUSamplerDescriptor#maxAnisotropy} values in range
* between 1 and 16, inclusive. The used value of {@link GPUSamplerDescriptor#maxAnisotropy} will
* be clamped to the maximum value that the platform supports.
* Specifies the maximum anisotropy value clamp used by the sampler. Anisotropic filtering is
* enabled when {@link GPUSamplerDescriptor#maxAnisotropy} is &gt; 1 and the implementation supports it.
* Anisotropic filtering improves the image quality of textures sampled at oblique viewing
* angles. Higher {@link GPUSamplerDescriptor#maxAnisotropy} values indicate the maximum ratio of
* anisotropy supported when filtering.
* <div class=note heading>
* Most implementations support {@link GPUSamplerDescriptor#maxAnisotropy} values in range
* between 1 and 16, inclusive. The used value of {@link GPUSamplerDescriptor#maxAnisotropy}
* will be clamped to the maximum value that the platform supports.
* The precise filtering behavior is implementation-dependent.
* </div>
*/
maxAnisotropy?: number;
}
Expand All @@ -1410,9 +1445,13 @@ interface GPUShaderModuleDescriptor
*/
code: string;
/**
* If defined MAY be interpreted as a source-map-v3 format.
* Source maps are optional, but serve as a standardized way to support dev-tool
* integration such as source-language debugging [[SourceMap]].
* If defined, **may** be interpreted in the [[!SourceMap]] v3 format.
* If an implementation supports this option but is unable to process the provided value,
* it should show a developer-visible warning but must not produce any application-observable
* error.
* Note:
* Source map support is optional, but serves as a semi-standardized way to support dev-tool
* integration such as source-language debugging.
* WGSL names (identifiers) in source maps follow the rules defined in WGSL identifier
* comparison.
*/
Expand All @@ -1428,12 +1467,14 @@ interface GPUShaderModuleDescriptor
* Supplying information in {@link GPUShaderModuleDescriptor#compilationHints} does not have any
* observable effect, other than performance. It may be detrimental to performance to
* provide hints for pipelines that never end up being created.
* Because a single shader module can hold
* multiple entry points, and multiple pipelines can be created from a single shader
* module, it can be more performant for an implementation to do as much compilation as
* possible once in {@link GPUDevice#createShaderModule} rather than multiple times in
* the multiple calls to {@link GPUDevice#createComputePipeline} or
* {@link GPUDevice#createRenderPipeline}.
* Because a single shader module can hold multiple entry points, and multiple pipelines
* can be created from a single shader module, it can be more performant for an
* implementation to do as much compilation as possible once in
* {@link GPUDevice#createShaderModule} rather than multiple times in the multiple calls to
* {@link GPUDevice#createComputePipeline()} or {@link GPUDevice#createRenderPipeline}.
* Hints are only applied to the entry points they explicitly name.
* Unlike {@link GPUProgrammableStage#entryPoint|GPUProgrammableStage.entryPoint},
* there is no default, even if only one entry point is present in the module.
* </div>
* Note:
* Hints are not validated in an observable way, but user agents **may** surface identifiable
Expand Down Expand Up @@ -1541,7 +1582,7 @@ interface GPUTextureDescriptor
* Similar caveats exist for other formats and pairs of formats on other systems.
* </div>
* Formats in this list must be texture view format compatible with the texture format.
* <div algorithm>
* <div algorithm data-timeline=const>
* Two {@link GPUTextureFormat}s `format` and `viewFormat` are <dfn dfn for="">texture view format compatible</dfn> if:
* - `format` equals `viewFormat`, or
* - `format` and `viewFormat` differ only in whether they are `srgb` formats (have the `-srgb` suffix).
Expand Down Expand Up @@ -1857,24 +1898,34 @@ interface GPUAdapter {
* The limits in `this`.{@link GPUAdapter#[[adapter]]}.{@link adapter#[[limits]]}.
*/
readonly limits: GPUSupportedLimits;
/**
* Information about the physical adapter underlying this {@link GPUAdapter}.
* For a given {@link GPUAdapter}, the {@link GPUAdapterInfo} values exposed are constant over time.
* The same object is returned each time. To create that object for the first time:
* <div algorithm=GPUAdapter.info>
* <div data-timeline=content>
* **Called on:** {@link GPUAdapter} `this`.
* **Returns:** {@link GPUAdapterInfo}
* Content timeline steps:
* 1. Return a [$new adapter info$] for `this.adapter`.
* </div>
* </div>
*/
readonly info: GPUAdapterInfo;
/**
* Returns the value of {@link GPUAdapter#[[adapter]]}.{@link adapter#[[fallback]]}.
*/
readonly isFallbackAdapter: boolean;
/**
* Requests a device from the adapter.
* This is a one-time action: if a device is returned successfully,
* the adapter becomes invalid.
* the adapter [$expires$].
* @param descriptor - Description of the {@link GPUDevice} to request.
*/
requestDevice(
descriptor?: GPUDeviceDescriptor
): Promise<GPUDevice>;
kainino0x marked this conversation as resolved.
Show resolved Hide resolved
/**
* Requests the {@link GPUAdapterInfo} for this {@link GPUAdapter}.
* Note: Adapter info values are returned with a Promise to give user agents an
* opportunity to perform potentially long-running checks in the future.
*/
/** @deprecated Use `adapter.info` instead (once available in browsers). */
requestAdapterInfo(): Promise<GPUAdapterInfo>;
}

Expand Down
Loading
Loading