|
|
|
@ -57,8 +57,8 @@ std::tuple<Node, u32, u32> ShaderIR::TrackCbuf(Node tracked, const NodeBlock& co |
|
|
|
return TrackCbuf(source, code, new_cursor); |
|
|
|
} |
|
|
|
if (const auto operation = std::get_if<OperationNode>(&*tracked)) { |
|
|
|
for (std::size_t i = 0; i < operation->GetOperandsCount(); ++i) { |
|
|
|
if (auto found = TrackCbuf((*operation)[i], code, cursor); std::get<0>(found)) { |
|
|
|
for (std::size_t i = operation->GetOperandsCount(); i > 0; --i) { |
|
|
|
if (auto found = TrackCbuf((*operation)[i - 1], code, cursor); std::get<0>(found)) { |
|
|
|
// Cbuf found in operand.
|
|
|
|
return found; |
|
|
|
} |
|
|
|
|