2018-10-26 06:46:10 +08:00
|
|
|
//===- Attributes.cpp - MLIR Affine Expr Classes --------------------------===//
|
|
|
|
//
|
2020-01-26 11:58:30 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
2019-12-24 01:35:36 +08:00
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2018-10-26 06:46:10 +08:00
|
|
|
//
|
2019-12-24 01:35:36 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2018-10-26 06:46:10 +08:00
|
|
|
|
|
|
|
#include "mlir/IR/Attributes.h"
|
2019-02-12 14:51:34 +08:00
|
|
|
#include "mlir/IR/Dialect.h"
|
2018-10-26 06:46:10 +08:00
|
|
|
|
|
|
|
using namespace mlir;
|
|
|
|
using namespace mlir::detail;
|
|
|
|
|
2019-05-03 05:02:57 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// AttributeStorage
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2019-05-23 04:41:23 +08:00
|
|
|
AttributeStorage::AttributeStorage(Type type)
|
|
|
|
: type(type.getAsOpaquePointer()) {}
|
|
|
|
AttributeStorage::AttributeStorage() : type(nullptr) {}
|
2019-05-03 05:02:57 +08:00
|
|
|
|
|
|
|
Type AttributeStorage::getType() const {
|
2019-05-23 04:41:23 +08:00
|
|
|
return Type::getFromOpaquePointer(type);
|
2019-05-03 05:02:57 +08:00
|
|
|
}
|
2019-05-23 04:41:23 +08:00
|
|
|
void AttributeStorage::setType(Type newType) {
|
|
|
|
type = newType.getAsOpaquePointer();
|
2019-05-03 05:02:57 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Attribute
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2019-05-01 05:26:04 +08:00
|
|
|
/// Return the type of this attribute.
|
2019-05-09 13:25:15 +08:00
|
|
|
Type Attribute::getType() const { return impl->getType(); }
|
2019-05-01 05:26:04 +08:00
|
|
|
|
2019-05-07 03:40:43 +08:00
|
|
|
/// Return the context this attribute belongs to.
|
2020-12-18 09:10:12 +08:00
|
|
|
MLIRContext *Attribute::getContext() const { return getDialect().getContext(); }
|
2019-05-07 03:40:43 +08:00
|
|
|
|
2019-05-11 06:14:13 +08:00
|
|
|
/// Get the dialect this attribute is registered to.
|
2020-07-01 06:42:39 +08:00
|
|
|
Dialect &Attribute::getDialect() const {
|
|
|
|
return impl->getAbstractAttribute().getDialect();
|
|
|
|
}
|
2019-05-11 06:14:13 +08:00
|
|
|
|
2019-05-16 00:10:52 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2020-12-04 09:22:57 +08:00
|
|
|
// NamedAttribute
|
2019-05-16 00:10:52 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2020-05-07 04:48:36 +08:00
|
|
|
bool mlir::operator<(const NamedAttribute &lhs, const NamedAttribute &rhs) {
|
|
|
|
return strcmp(lhs.first.data(), rhs.first.data()) < 0;
|
|
|
|
}
|
|
|
|
bool mlir::operator<(const NamedAttribute &lhs, StringRef rhs) {
|
|
|
|
// This is correct even when attr.first.data()[name.size()] is not a zero
|
|
|
|
// string terminator, because we only care about a less than comparison.
|
|
|
|
// This can't use memcmp, because it doesn't guarantee that it will stop
|
|
|
|
// reading both buffers if one is shorter than the other, even if there is
|
|
|
|
// a difference.
|
|
|
|
return strncmp(lhs.first.data(), rhs.data(), rhs.size()) < 0;
|
|
|
|
}
|