LLZK 2.0.0
An open-source IR for Zero Knowledge (ZK) circuits
Loading...
Searching...
No Matches
Attrs.cpp.inc
Go to the documentation of this file.
1/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
2|* *|
3|* AttrDef Definitions *|
4|* *|
5|* Automatically generated file, do not edit! *|
6|* *|
7\*===----------------------------------------------------------------------===*/
8
9#ifdef GET_ATTRDEF_LIST
10#undef GET_ATTRDEF_LIST
11
12::llzk::felt::FeltConstAttr,
13::llzk::felt::FieldSpecAttr
14
15#endif // GET_ATTRDEF_LIST
16
17#ifdef GET_ATTRDEF_CLASSES
18#undef GET_ATTRDEF_CLASSES
19
20static ::mlir::OptionalParseResult generatedAttributeParser(::mlir::AsmParser &parser, ::llvm::StringRef *mnemonic, ::mlir::Type type, ::mlir::Attribute &value) {
21 return ::mlir::AsmParser::KeywordSwitch<::mlir::OptionalParseResult>(parser)
22 .Case(::llzk::felt::FeltConstAttr::getMnemonic(), [&](llvm::StringRef, llvm::SMLoc) {
23 value = ::llzk::felt::FeltConstAttr::parse(parser, type);
24 return ::mlir::success(!!value);
25 })
26 .Case(::llzk::felt::FieldSpecAttr::getMnemonic(), [&](llvm::StringRef, llvm::SMLoc) {
27 value = ::llzk::felt::FieldSpecAttr::parse(parser, type);
28 return ::mlir::success(!!value);
29 })
30 .Default([&](llvm::StringRef keyword, llvm::SMLoc) {
31 *mnemonic = keyword;
32 return std::nullopt;
33 });
34}
35
36static ::llvm::LogicalResult generatedAttributePrinter(::mlir::Attribute def, ::mlir::AsmPrinter &printer) {
37 return ::llvm::TypeSwitch<::mlir::Attribute, ::llvm::LogicalResult>(def) .Case<::llzk::felt::FeltConstAttr>([&](auto t) {
38 printer << ::llzk::felt::FeltConstAttr::getMnemonic();
39t.print(printer);
40 return ::mlir::success();
41 })
42 .Case<::llzk::felt::FieldSpecAttr>([&](auto t) {
43 printer << ::llzk::felt::FieldSpecAttr::getMnemonic();
44t.print(printer);
45 return ::mlir::success();
46 })
47 .Default([](auto) { return ::mlir::failure(); });
48}
49
50namespace llzk {
51namespace felt {
52namespace detail {
53struct FeltConstAttrStorage : public ::mlir::AttributeStorage {
54 using KeyTy = std::tuple<::llvm::APInt, FeltType>;
55 FeltConstAttrStorage(::llvm::APInt value, FeltType type) : value(std::move(value)), type(std::move(type)) {}
56
57 KeyTy getAsKey() const {
58 return KeyTy(value, type);
59 }
60
61 bool operator==(const KeyTy &tblgenKey) const {
62 return (::llvm::APInt::isSameValue(value, std::get<0>(tblgenKey))) && (type == std::get<1>(tblgenKey));
63 }
64
65 static ::llvm::hash_code hashKey(const KeyTy &tblgenKey) {
66 return ::llvm::hash_combine(std::get<0>(tblgenKey), std::get<1>(tblgenKey));
67 }
68
69 static FeltConstAttrStorage *construct(::mlir::AttributeStorageAllocator &allocator, KeyTy &&tblgenKey) {
70 auto value = std::move(std::get<0>(tblgenKey));
71 auto type = std::move(std::get<1>(tblgenKey));
72 return new (allocator.allocate<FeltConstAttrStorage>()) FeltConstAttrStorage(std::move(value), std::move(type));
73 }
74
75 ::llvm::APInt value;
76 FeltType type;
77};
78} // namespace detail
79FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, ::llvm::APInt value, FeltType type) {
80 return Base::get(context, std::move(value), std::move(type));
81}
82
83FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, unsigned numBits, ::llvm::StringRef str, FeltType ty) {
84 return Base::get(context, ::llvm::APInt(numBits, str, 10), ty);
85}
86
87FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, unsigned numBits, ::llvm::ArrayRef<uint64_t> parts, FeltType ty) {
88 return Base::get(context, ::llvm::APInt(numBits, parts), ty);
89}
90
91FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, ::llvm::APInt value) {
92 return get(context, value, FeltType::get(context));
93}
94
95FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, unsigned numBits, ::llvm::StringRef str) {
96 return get(context, numBits, str, FeltType::get(context));
97}
98
99FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, unsigned numBits, ::llvm::ArrayRef<uint64_t> parts) {
100 return get(context, numBits, parts, FeltType::get(context));
101}
102
103FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, ::llvm::APInt value, ::llvm::StringRef fieldName) {
104 return get(context, value, FeltType::get(context, fieldName));
105}
106
107FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, unsigned numBits, ::llvm::StringRef str, ::llvm::StringRef fieldName) {
108 return get(context, numBits, str, FeltType::get(context, fieldName));
109}
110
111FeltConstAttr FeltConstAttr::get(::mlir::MLIRContext *context, unsigned numBits, ::llvm::ArrayRef<uint64_t> parts, ::llvm::StringRef fieldName) {
112 return get(context, numBits, parts, FeltType::get(context, fieldName));
113}
114
115::llvm::APInt FeltConstAttr::getValue() const {
116 return getImpl()->value;
117}
118
119FeltType FeltConstAttr::getType() const {
120 return getImpl()->type;
121}
122
123} // namespace felt
124} // namespace llzk
125MLIR_DEFINE_EXPLICIT_TYPE_ID(::llzk::felt::FeltConstAttr)
126namespace llzk {
127namespace felt {
128namespace detail {
129struct FieldSpecAttrStorage : public ::mlir::AttributeStorage {
130 using KeyTy = std::tuple<::mlir::StringAttr, ::llvm::APInt>;
131 FieldSpecAttrStorage(::mlir::StringAttr fieldName, ::llvm::APInt prime) : fieldName(std::move(fieldName)), prime(std::move(prime)) {}
132
133 KeyTy getAsKey() const {
134 return KeyTy(fieldName, prime);
135 }
136
137 bool operator==(const KeyTy &tblgenKey) const {
138 return (fieldName == std::get<0>(tblgenKey)) && (::llvm::APInt::isSameValue(prime, std::get<1>(tblgenKey)));
139 }
140
141 static ::llvm::hash_code hashKey(const KeyTy &tblgenKey) {
142 return ::llvm::hash_combine(std::get<0>(tblgenKey), std::get<1>(tblgenKey));
143 }
144
145 static FieldSpecAttrStorage *construct(::mlir::AttributeStorageAllocator &allocator, KeyTy &&tblgenKey) {
146 auto fieldName = std::move(std::get<0>(tblgenKey));
147 auto prime = std::move(std::get<1>(tblgenKey));
148 return new (allocator.allocate<FieldSpecAttrStorage>()) FieldSpecAttrStorage(std::move(fieldName), std::move(prime));
149 }
150
151 ::mlir::StringAttr fieldName;
152 ::llvm::APInt prime;
153};
154} // namespace detail
155FieldSpecAttr FieldSpecAttr::get(::mlir::MLIRContext *context, ::mlir::StringAttr fieldName, ::llvm::APInt prime) {
156 return Base::get(context, std::move(fieldName), std::move(prime));
157}
158
159FieldSpecAttr FieldSpecAttr::get(::mlir::MLIRContext *context, ::llvm::StringRef fieldName, unsigned numBits, ::llvm::StringRef primeStr) {
160 return Base::get(context, ::mlir::StringAttr::get(context, fieldName), ::llvm::APInt(numBits, primeStr, 10));
161}
162
163FieldSpecAttr FieldSpecAttr::get(::mlir::MLIRContext *context, ::llvm::StringRef fieldName, unsigned numBits, ::llvm::ArrayRef<uint64_t> parts) {
164 return Base::get(context, ::mlir::StringAttr::get(context, fieldName), ::llvm::APInt(numBits, parts));
165}
166
167::mlir::StringAttr FieldSpecAttr::getFieldName() const {
168 return getImpl()->fieldName;
169}
170
171::llvm::APInt FieldSpecAttr::getPrime() const {
172 return getImpl()->prime;
173}
174
175} // namespace felt
176} // namespace llzk
177MLIR_DEFINE_EXPLICIT_TYPE_ID(::llzk::felt::FieldSpecAttr)
178namespace llzk {
179namespace felt {
180
182::mlir::Attribute FeltDialect::parseAttribute(::mlir::DialectAsmParser &parser,
183 ::mlir::Type type) const {
184 ::llvm::SMLoc typeLoc = parser.getCurrentLocation();
185 ::llvm::StringRef attrTag;
186 {
187 ::mlir::Attribute attr;
188 auto parseResult = generatedAttributeParser(parser, &attrTag, type, attr);
189 if (parseResult.has_value())
190 return attr;
191 }
192
193 parser.emitError(typeLoc) << "unknown attribute `"
194 << attrTag << "` in dialect `" << getNamespace() << "`";
195 return {};
196}
198void FeltDialect::printAttribute(::mlir::Attribute attr,
199 ::mlir::DialectAsmPrinter &printer) const {
200 if (::mlir::succeeded(generatedAttributePrinter(attr, printer)))
201 return;
202
203}
204} // namespace felt
205} // namespace llzk
206
207#endif // GET_ATTRDEF_CLASSES
208
::mlir::Attribute parseAttribute(::mlir::DialectAsmParser &parser, ::mlir::Type type) const override
Parse an attribute registered to this dialect.
void printAttribute(::mlir::Attribute attr, ::mlir::DialectAsmPrinter &os) const override
Print an attribute registered to this dialect.
static FeltType get(::mlir::MLIRContext *context, ::mlir::StringAttr fieldName)
Definition Types.cpp.inc:67