//
// fragment_main
//
#include <metal_stdlib>
using namespace metal;

struct tint_module_vars_struct {
  device float* prevent_dce;
  depth2d_array<float, access::sample> arg_0;
};

float textureLoad_7b63e0(tint_module_vars_struct tint_module_vars) {
  uint2 arg_1 = uint2(1u);
  uint arg_2 = 1u;
  uint arg_3 = 1u;
  uint2 const v = arg_1;
  uint const v_1 = min(arg_2, (tint_module_vars.arg_0.get_array_size() - 1u));
  uint const v_2 = min(arg_3, (tint_module_vars.arg_0.get_num_mip_levels() - 1u));
  float res = tint_module_vars.arg_0.read(min(v, (uint2(tint_module_vars.arg_0.get_width(v_2), tint_module_vars.arg_0.get_height(v_2)) - uint2(1u))), v_1, v_2);
  return res;
}

fragment void fragment_main(device float* prevent_dce [[buffer(0)]], depth2d_array<float, access::sample> arg_0 [[texture(0)]]) {
  tint_module_vars_struct const tint_module_vars = tint_module_vars_struct{.prevent_dce=prevent_dce, .arg_0=arg_0};
  (*tint_module_vars.prevent_dce) = textureLoad_7b63e0(tint_module_vars);
}
//
// compute_main
//
#include <metal_stdlib>
using namespace metal;

struct tint_module_vars_struct {
  device float* prevent_dce;
  depth2d_array<float, access::sample> arg_0;
};

float textureLoad_7b63e0(tint_module_vars_struct tint_module_vars) {
  uint2 arg_1 = uint2(1u);
  uint arg_2 = 1u;
  uint arg_3 = 1u;
  uint2 const v = arg_1;
  uint const v_1 = min(arg_2, (tint_module_vars.arg_0.get_array_size() - 1u));
  uint const v_2 = min(arg_3, (tint_module_vars.arg_0.get_num_mip_levels() - 1u));
  float res = tint_module_vars.arg_0.read(min(v, (uint2(tint_module_vars.arg_0.get_width(v_2), tint_module_vars.arg_0.get_height(v_2)) - uint2(1u))), v_1, v_2);
  return res;
}

kernel void compute_main(device float* prevent_dce [[buffer(0)]], depth2d_array<float, access::sample> arg_0 [[texture(0)]]) {
  tint_module_vars_struct const tint_module_vars = tint_module_vars_struct{.prevent_dce=prevent_dce, .arg_0=arg_0};
  (*tint_module_vars.prevent_dce) = textureLoad_7b63e0(tint_module_vars);
}
//
// vertex_main
//
#include <metal_stdlib>
using namespace metal;

struct tint_module_vars_struct {
  depth2d_array<float, access::sample> arg_0;
};

struct VertexOutput {
  float4 pos;
  float prevent_dce;
};

struct vertex_main_outputs {
  float4 VertexOutput_pos [[position]];
  float VertexOutput_prevent_dce [[user(locn0)]] [[flat]];
};

float textureLoad_7b63e0(tint_module_vars_struct tint_module_vars) {
  uint2 arg_1 = uint2(1u);
  uint arg_2 = 1u;
  uint arg_3 = 1u;
  uint2 const v = arg_1;
  uint const v_1 = min(arg_2, (tint_module_vars.arg_0.get_array_size() - 1u));
  uint const v_2 = min(arg_3, (tint_module_vars.arg_0.get_num_mip_levels() - 1u));
  float res = tint_module_vars.arg_0.read(min(v, (uint2(tint_module_vars.arg_0.get_width(v_2), tint_module_vars.arg_0.get_height(v_2)) - uint2(1u))), v_1, v_2);
  return res;
}

VertexOutput vertex_main_inner(tint_module_vars_struct tint_module_vars) {
  VertexOutput out = {};
  out.pos = float4(0.0f);
  out.prevent_dce = textureLoad_7b63e0(tint_module_vars);
  return out;
}

vertex vertex_main_outputs vertex_main(depth2d_array<float, access::sample> arg_0 [[texture(0)]]) {
  tint_module_vars_struct const tint_module_vars = tint_module_vars_struct{.arg_0=arg_0};
  VertexOutput const v_3 = vertex_main_inner(tint_module_vars);
  vertex_main_outputs tint_wrapper_result = {};
  tint_wrapper_result.VertexOutput_pos = v_3.pos;
  tint_wrapper_result.VertexOutput_prevent_dce = v_3.prevent_dce;
  return tint_wrapper_result;
}
