This revision adds native ODS support for VariadicOfVariadic operand groups. An example of this is the SwitchOp, which has a variadic number of nested operand ranges for each of the case statements, where the number of case statements is variadic. Builtin ODS support allows for generating proper accessors for the nested operand ranges, builder support, and declarative format support. VariadicOfVariadic operands are supported by providing a segment attribute to use to store the operand groups, mapping similarly to the AttrSizedOperand trait (but with a user defined attribute name). `build` methods for VariadicOfVariadic operand expect inputs of the form `ArrayRef<ValueRange>`. Accessors for the variadic ranges return a new `OperandRangeRange` type, which represents a contiguous range of `OperandRange`. In the declarative assembly format, VariadicOfVariadic operands and types are by default formatted as a comma delimited list of value lists: `(<value>, <value>), (), (<value>)`. Differential Revision: https://reviews.llvm.org/D107774
30 lines
1.0 KiB
C++
30 lines
1.0 KiB
C++
//===- Argument.cpp - Argument definitions --------------------------------===//
|
|
//
|
|
// 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/TableGen/Argument.h"
|
|
#include "llvm/TableGen/Record.h"
|
|
|
|
using namespace mlir;
|
|
using namespace mlir::tblgen;
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// NamedTypeConstraint
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
bool NamedTypeConstraint::hasPredicate() const {
|
|
return !constraint.getPredicate().isNull();
|
|
}
|
|
|
|
bool NamedTypeConstraint::isOptional() const { return constraint.isOptional(); }
|
|
|
|
bool NamedTypeConstraint::isVariadic() const { return constraint.isVariadic(); }
|
|
|
|
bool NamedTypeConstraint::isVariadicOfVariadic() const {
|
|
return constraint.isVariadicOfVariadic();
|
|
}
|