MLLIF
a MLIR-based Language to Language Interoperability Flyover
Loading...
Searching...
No Matches
Adapter.h
Go to the documentation of this file.
1/*
2 * Copyright 2025 Yeong-won Seo
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#pragma once
18
20
21namespace mllif::mlir {
22
26 class Adapter {
27 public:
28 virtual ~Adapter() = default;
29
30 virtual void handle(Tree &symbols, std::shared_ptr<::mlir::ModuleOp> module, ::mlir::Operation *op) = 0;
31 };
32
33 extern std::vector<std::shared_ptr<Adapter>> Adapters;
34
35 template <typename T>
37 public:
39 Adapters.push_back(std::make_shared<T>());
40 }
41 };
42
43} // namespace mllif::mlir
An adapter for each dialect in module. one adapter should match to one dialect, and vice versa....
Definition Adapter.h:26
virtual ~Adapter()=default
virtual void handle(Tree &symbols, std::shared_ptr<::mlir::ModuleOp > module, ::mlir::Operation *op)=0
A tree struct for symbol tree. It's just a simple wrapper for root node.
Definition Tree.h:147
std::vector< std::shared_ptr< Adapter > > Adapters
Definition Adapter.cxx:21