MLIR 22.0.0git
Attributes.cpp
Go to the documentation of this file.
1//===- Attributes.cpp - MLIR Affine Expr Classes --------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
10#include "mlir/IR/Dialect.h"
11
12using namespace mlir;
13using namespace mlir::detail;
14
15//===----------------------------------------------------------------------===//
16// AbstractAttribute
17//===----------------------------------------------------------------------===//
18
20 Attribute attr, function_ref<void(Attribute)> walkAttrsFn,
21 function_ref<void(Type)> walkTypesFn) const {
22 walkImmediateSubElementsFn(attr, walkAttrsFn, walkTypesFn);
23}
24
27 ArrayRef<Attribute> replAttrs,
28 ArrayRef<Type> replTypes) const {
29 return replaceImmediateSubElementsFn(attr, replAttrs, replTypes);
30}
31
32//===----------------------------------------------------------------------===//
33// Attribute
34//===----------------------------------------------------------------------===//
35
36/// Return the context this attribute belongs to.
38
39//===----------------------------------------------------------------------===//
40// NamedAttribute
41//===----------------------------------------------------------------------===//
42
44 : name(name), value(value) {
45 assert(name && value && "expected valid attribute name and value");
46 assert(!name.empty() && "expected valid attribute name");
47}
48
49NamedAttribute::NamedAttribute(StringRef name, Attribute value) : value(value) {
50 assert(value && "expected valid attribute value");
51 assert(!name.empty() && "expected valid attribute name");
52 this->name = StringAttr::get(value.getContext(), name);
53}
54
55StringAttr NamedAttribute::getName() const {
56 return llvm::cast<StringAttr>(name);
57}
58
60 return getName().getReferencedDialect();
61}
62
63void NamedAttribute::setName(StringAttr newName) {
64 assert(name && "expected valid attribute name");
65 name = newName;
66}
67
69 return getName().compare(rhs.getName()) < 0;
70}
71
72bool NamedAttribute::operator<(StringRef rhs) const {
73 return getName().getValue().compare(rhs) < 0;
74}
void walkImmediateSubElements(Attribute attr, function_ref< void(Attribute)> walkAttrsFn, function_ref< void(Type)> walkTypesFn) const
Walk the immediate sub-elements of this attribute.
Attribute replaceImmediateSubElements(Attribute attr, ArrayRef< Attribute > replAttrs, ArrayRef< Type > replTypes) const
Replace the immediate sub-elements of this attribute.
Attributes are known-constant values of operations.
Definition Attributes.h:25
Dialect & getDialect() const
Get the dialect this attribute is registered to.
Definition Attributes.h:58
MLIRContext * getContext() const
Return the context this attribute belongs to.
Dialects are groups of MLIR operations, types and attributes, as well as behavior associated with the...
Definition Dialect.h:38
MLIRContext * getContext() const
Definition Dialect.h:52
MLIRContext is the top-level object for a collection of MLIR operations.
Definition MLIRContext.h:63
StringAttr getName() const
Return the name of the attribute.
void setName(StringAttr newName)
Set the name of this attribute.
bool operator<(const NamedAttribute &rhs) const
Compare this attribute to the provided attribute, ordering by name.
NamedAttribute(StringAttr name, Attribute value)
Dialect * getNameDialect() const
Return the dialect of the name of this attribute, if the name is prefixed by a dialect namespace.
Instances of the Type class are uniqued, have an immutable identifier and an optional mutable compone...
Definition Types.h:74
AttrTypeReplacer.
Include the generated interface declarations.
llvm::function_ref< Fn > function_ref
Definition LLVM.h:152