mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-07-12 08:05:53 +00:00
As the resolver currently enforces in-order declarations, this does not change the declaration order from iterating over the ast::Module::GlobalDeclarations. The MSL backend has been changed to use the sem::Module::DependencyOrderedDeclarations list instead of looping over different declaration types separately. Bug: tint:1266 Change-Id: I698d612032285311017bfceab3c42adae1928a0e Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/79767 Reviewed-by: James Price <jrprice@google.com> Kokoro: Kokoro <noreply+kokoro@google.com>
31 lines
730 B
Plaintext
31 lines
730 B
Plaintext
#include <metal_stdlib>
|
|
|
|
using namespace metal;
|
|
struct FragmentInputs {
|
|
int loc0;
|
|
uint loc1;
|
|
float loc2;
|
|
float4 loc3;
|
|
};
|
|
|
|
struct tint_symbol_2 {
|
|
int loc0 [[user(locn0)]] [[flat]];
|
|
uint loc1 [[user(locn1)]] [[flat]];
|
|
float loc2 [[user(locn2)]];
|
|
float4 loc3 [[user(locn3)]];
|
|
};
|
|
|
|
void tint_symbol_inner(FragmentInputs inputs) {
|
|
int const i = inputs.loc0;
|
|
uint const u = inputs.loc1;
|
|
float const f = inputs.loc2;
|
|
float4 const v = inputs.loc3;
|
|
}
|
|
|
|
fragment void tint_symbol(tint_symbol_2 tint_symbol_1 [[stage_in]]) {
|
|
FragmentInputs const tint_symbol_3 = {.loc0=tint_symbol_1.loc0, .loc1=tint_symbol_1.loc1, .loc2=tint_symbol_1.loc2, .loc3=tint_symbol_1.loc3};
|
|
tint_symbol_inner(tint_symbol_3);
|
|
return;
|
|
}
|
|
|