diff --git a/runtime/cudaq/builder/QuakeValue.cpp b/runtime/cudaq/builder/QuakeValue.cpp index ea2261651e..f2c58fbfe6 100644 --- a/runtime/cudaq/builder/QuakeValue.cpp +++ b/runtime/cudaq/builder/QuakeValue.cpp @@ -190,7 +190,8 @@ QuakeValue QuakeValue::size() { std::optional QuakeValue::constantSize() { if (auto qvecTy = dyn_cast(getValue().getType())) - return qvecTy.getSize(); + if (qvecTy.hasSpecifiedSize()) + return qvecTy.getSize(); return std::nullopt; } diff --git a/unittests/Optimizer/QuakeSynthTester.cpp b/unittests/Optimizer/QuakeSynthTester.cpp index 5c2e324cab..ceb3184183 100644 --- a/unittests/Optimizer/QuakeSynthTester.cpp +++ b/unittests/Optimizer/QuakeSynthTester.cpp @@ -283,7 +283,10 @@ TEST(QuakeSynthTests, checkVectorOfInt) { kernel.h(aq); kernel.z(aq); kernel.h(q); - for (std::size_t i = 0; i < *q.constantSize(); ++i) { + // FIXME: This test never really tested the c_if in this loop. The call to + // constantSize just returned 0. + std::size_t unrollBy = q.constantSize().has_value() ? *q.constantSize() : 0; + for (std::size_t i = 0; i < unrollBy; ++i) { kernel.c_if(hiddenBits[i], [&]() { kernel.x(aq, q[i]); }); } kernel.h(q);