28 std::optional<uint64_t> maxNumRewrites)
const {
37 std::deque<OperatorT> inputs(operators.begin(), operators.end());
40 uint64_t numRewrites = 0;
41 while (!inputs.empty() &&
42 (!maxNumRewrites || numRewrites < *maxNumRewrites)) {
43 bool foundMatch =
false;
44 for (
const std::unique_ptr<ExprRewritePattern> &pattern : patterns) {
46 if (matchEnd == inputs.begin())
51 pattern->replace(llvm::make_range(inputs.cbegin(), matchEnd));
52 inputs.erase(inputs.begin(), matchEnd);
60 result.push_back(inputs.front());
65 if (maxNumRewrites && numRewrites >= *maxNumRewrites) {
66 LDBG() <<
"LLVMDIExpressionSimplifier exceeded max num rewrites ("
67 << maxNumRewrites <<
")";
69 result.append(inputs.begin(), inputs.end());
72 return LLVM::DIExpressionAttr::get(expr.getContext(),
result);