llvm-project/mlir/lib/IR/Attributes.cpp
River Riddle 03d136cf5f [mlir] Promote the SubElementInterfaces to a core Attribute/Type construct
This commit restructures the sub element infrastructure to be a core part
of attributes and types, instead of being relegated to an interface. This
establishes sub element walking/replacement as something "always there",
which makes it easier to rely on for correctness/etc (which various bits of
infrastructure want, such as Symbols).

Attribute/Type now have `walk` and `replace` methods directly
accessible, which provide power API for interacting with sub elements. As
part of this, a new AttrTypeWalker class is introduced that supports caching
walked attributes/types, and a friendlier API (see the simplification of symbol
walking in SymbolTable.cpp).

Differential Revision: https://reviews.llvm.org/D142272
2023-01-27 15:28:03 -08:00

67 lines
2.4 KiB
C++

//===- Attributes.cpp - MLIR Affine Expr Classes --------------------------===//
//
// 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/Attributes.h"
#include "mlir/IR/Dialect.h"
using namespace mlir;
using namespace mlir::detail;
//===----------------------------------------------------------------------===//
// AbstractAttribute
//===----------------------------------------------------------------------===//
void AbstractAttribute::walkImmediateSubElements(
Attribute attr, function_ref<void(Attribute)> walkAttrsFn,
function_ref<void(Type)> walkTypesFn) const {
walkImmediateSubElementsFn(attr, walkAttrsFn, walkTypesFn);
}
Attribute
AbstractAttribute::replaceImmediateSubElements(Attribute attr,
ArrayRef<Attribute> replAttrs,
ArrayRef<Type> replTypes) const {
return replaceImmediateSubElementsFn(attr, replAttrs, replTypes);
}
//===----------------------------------------------------------------------===//
// Attribute
//===----------------------------------------------------------------------===//
/// Return the context this attribute belongs to.
MLIRContext *Attribute::getContext() const { return getDialect().getContext(); }
//===----------------------------------------------------------------------===//
// NamedAttribute
//===----------------------------------------------------------------------===//
NamedAttribute::NamedAttribute(StringAttr name, Attribute value)
: name(name), value(value) {
assert(name && value && "expected valid attribute name and value");
assert(name.size() != 0 && "expected valid attribute name");
}
StringAttr NamedAttribute::getName() const { return name.cast<StringAttr>(); }
Dialect *NamedAttribute::getNameDialect() const {
return getName().getReferencedDialect();
}
void NamedAttribute::setName(StringAttr newName) {
assert(name && "expected valid attribute name");
name = newName;
}
bool NamedAttribute::operator<(const NamedAttribute &rhs) const {
return getName().compare(rhs.getName()) < 0;
}
bool NamedAttribute::operator<(StringRef rhs) const {
return getName().getValue().compare(rhs) < 0;
}