ExternalTextureTransform: Fix undefined behavior

WGSL now supports type inferencing with `let` declarations, so `var->type()` may return nullptr.
Calling a method (`Is<T>()`) on a nullptr object is UB. Instead used the free-function form which can handle nullptr objects.

Change-Id: I8faf875e1550eac1306ad731a65f3662bc4e5b43
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/50307
Auto-Submit: Ben Clayton <bclayton@google.com>
Kokoro: Kokoro <noreply+kokoro@google.com>
Reviewed-by: Brandon Jones <brandon1.jones@intel.com>
Commit-Queue: Ben Clayton <bclayton@google.com>
This commit is contained in:
Ben Clayton 2021-05-10 16:06:51 +00:00 committed by Commit Bot service account
parent 1f68519dee
commit 8f96595540
1 changed files with 1 additions and 1 deletions

View File

@ -28,7 +28,7 @@ Output ExternalTextureTransform::Run(const Program* in, const DataMap&) {
// Scan the AST nodes for external texture declarations. // Scan the AST nodes for external texture declarations.
for (auto* node : ctx.src->ASTNodes().Objects()) { for (auto* node : ctx.src->ASTNodes().Objects()) {
if (auto* var = node->As<ast::Variable>()) { if (auto* var = node->As<ast::Variable>()) {
if (var->type()->Is<ast::ExternalTexture>()) { if (Is<ast::ExternalTexture>(var->type())) {
// Replace a single-plane external texture with a 2D, f32 sampled // Replace a single-plane external texture with a 2D, f32 sampled
// texture. // texture.
auto newType = ctx.dst->ty.sampled_texture(ast::TextureDimension::k2d, auto newType = ctx.dst->ty.sampled_texture(ast::TextureDimension::k2d,