//===- TypeRange.cpp ------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "mlir/IR/TypeRange.h" #include "mlir/IR/Operation.h" using namespace mlir; //===----------------------------------------------------------------------===// // TypeRange TypeRange::TypeRange(ArrayRef types) : TypeRange(types.data(), types.size()) {} TypeRange::TypeRange(OperandRange values) : TypeRange(values.begin().getBase(), values.size()) {} TypeRange::TypeRange(ResultRange values) : TypeRange(values.getBase()->getResultTypes().slice(values.getStartIndex(), values.size())) {} TypeRange::TypeRange(ArrayRef values) : TypeRange(values.data(), values.size()) {} TypeRange::TypeRange(ValueRange values) : TypeRange(OwnerT(), values.size()) { detail::ValueRangeOwner owner = values.begin().getBase(); if (auto *op = reinterpret_cast(owner.ptr.dyn_cast())) this->base = op->getResultTypes().drop_front(owner.startIndex).data(); else if (auto *operand = owner.ptr.dyn_cast()) this->base = operand; else this->base = owner.ptr.get(); } /// See `llvm::detail::indexed_accessor_range_base` for details. TypeRange::OwnerT TypeRange::offset_base(OwnerT object, ptrdiff_t index) { if (const auto *value = object.dyn_cast()) return {value + index}; if (auto *operand = object.dyn_cast()) return {operand + index}; return {object.dyn_cast() + index}; } /// See `llvm::detail::indexed_accessor_range_base` for details. Type TypeRange::dereference_iterator(OwnerT object, ptrdiff_t index) { if (const auto *value = object.dyn_cast()) return (value + index)->getType(); if (auto *operand = object.dyn_cast()) return (operand + index)->get().getType(); return object.dyn_cast()[index]; }