Files
clang-p2996/mlir/lib/TableGen/Property.cpp
Krzysztof Drewniak 5ce5ed4b85 [mlir] Allow using non-attribute properties in declarative rewrite patterns (#143071)
This commit adds support for non-attribute properties (such as
StringProp and I64Prop) in declarative rewrite patterns. The handling
for properties follows the handling for attributes in most cases,
including in the generation of static matchers.

Constraints that are shared between multiple types are supported by
making the constraint matcher a templated function, which is the
equivalent to passing ::mlir::Attribute for an arbitrary C++ type.
2025-06-24 00:20:27 -05:00

123 lines
4.8 KiB
C++

//===- Property.cpp - Property wrapper class ----------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
//
// Property wrapper to simplify using TableGen Record defining a MLIR
// Property.
//
//===----------------------------------------------------------------------===//
#include "mlir/TableGen/Property.h"
#include "mlir/TableGen/Format.h"
#include "mlir/TableGen/Operator.h"
#include "mlir/TableGen/Predicate.h"
#include "llvm/TableGen/Record.h"
using namespace mlir;
using namespace mlir::tblgen;
using llvm::DefInit;
using llvm::Init;
using llvm::Record;
using llvm::StringInit;
// Returns the initializer's value as string if the given TableGen initializer
// is a code or string initializer. Returns the empty StringRef otherwise.
static StringRef getValueAsString(const Init *init) {
if (const auto *str = dyn_cast<StringInit>(init))
return str->getValue().trim();
return {};
}
StringRef PropConstraint::getInterfaceType() const {
return getValueAsString(def->getValueInit("interfaceType"));
}
Property::Property(const Record *def)
: Property(
def, getValueAsString(def->getValueInit("summary")),
getValueAsString(def->getValueInit("description")),
getValueAsString(def->getValueInit("storageType")),
getValueAsString(def->getValueInit("interfaceType")),
getValueAsString(def->getValueInit("convertFromStorage")),
getValueAsString(def->getValueInit("assignToStorage")),
getValueAsString(def->getValueInit("convertToAttribute")),
getValueAsString(def->getValueInit("convertFromAttribute")),
getValueAsString(def->getValueInit("parser")),
getValueAsString(def->getValueInit("optionalParser")),
getValueAsString(def->getValueInit("printer")),
getValueAsString(def->getValueInit("readFromMlirBytecode")),
getValueAsString(def->getValueInit("writeToMlirBytecode")),
getValueAsString(def->getValueInit("hashProperty")),
getValueAsString(def->getValueInit("defaultValue")),
getValueAsString(def->getValueInit("storageTypeValueOverride"))) {
assert((def->isSubClassOf("Property") || def->isSubClassOf("Attr")) &&
"must be subclass of TableGen 'Property' class");
}
Property::Property(const DefInit *init) : Property(init->getDef()) {}
Property::Property(const llvm::Record *maybeDef, StringRef summary,
StringRef description, StringRef storageType,
StringRef interfaceType, StringRef convertFromStorageCall,
StringRef assignToStorageCall,
StringRef convertToAttributeCall,
StringRef convertFromAttributeCall, StringRef parserCall,
StringRef optionalParserCall, StringRef printerCall,
StringRef readFromMlirBytecodeCall,
StringRef writeToMlirBytecodeCall,
StringRef hashPropertyCall, StringRef defaultValue,
StringRef storageTypeValueOverride)
: PropConstraint(maybeDef, Constraint::CK_Prop), summary(summary),
description(description), storageType(storageType),
interfaceType(interfaceType),
convertFromStorageCall(convertFromStorageCall),
assignToStorageCall(assignToStorageCall),
convertToAttributeCall(convertToAttributeCall),
convertFromAttributeCall(convertFromAttributeCall),
parserCall(parserCall), optionalParserCall(optionalParserCall),
printerCall(printerCall),
readFromMlirBytecodeCall(readFromMlirBytecodeCall),
writeToMlirBytecodeCall(writeToMlirBytecodeCall),
hashPropertyCall(hashPropertyCall), defaultValue(defaultValue),
storageTypeValueOverride(storageTypeValueOverride) {
if (storageType.empty())
storageType = "Property";
}
StringRef Property::getPropertyDefName() const {
if (def->isAnonymous()) {
return getBaseProperty().def->getName();
}
return def->getName();
}
Pred Property::getPredicate() const {
if (!def)
return Pred();
const llvm::RecordVal *maybePred = def->getValue("predicate");
if (!maybePred || !maybePred->getValue())
return Pred();
return Pred(maybePred->getValue());
}
Property Property::getBaseProperty() const {
if (const auto *defInit =
llvm::dyn_cast<llvm::DefInit>(def->getValueInit("baseProperty"))) {
return Property(defInit).getBaseProperty();
}
return *this;
}
bool Property::isSubClassOf(StringRef className) const {
return def && def->isSubClassOf(className);
}
StringRef ConstantProp::getValue() const {
return def->getValueAsString("value");
}