1
0
mirror of https://github.com/exaloop/codon.git synced 2025-06-03 15:03:52 +08:00
codon/compiler/seq/revcomp.h
2021-09-27 14:02:44 -04:00

35 lines
916 B
C++

#pragma once
#include "sir/dsl/nodes.h"
#include "sir/sir.h"
#include "sir/transform/pass.h"
namespace seq {
class KmerRevcomp : public ir::AcceptorExtend<KmerRevcomp, ir::dsl::CustomInstr> {
private:
ir::Value *kmer;
public:
static const char NodeId;
using AcceptorExtend::AcceptorExtend;
explicit KmerRevcomp(ir::Value *kmer) : AcceptorExtend(), kmer(kmer) {}
std::unique_ptr<ir::dsl::codegen::ValueBuilder> getBuilder() const override;
std::unique_ptr<ir::dsl::codegen::CFBuilder> getCFBuilder() const override;
bool match(const ir::Value *v) const override;
ir::Value *doClone(ir::util::CloneVisitor &cv) const override;
std::ostream &doFormat(std::ostream &os) const override;
};
class KmerRevcompInterceptor : public ir::transform::Pass {
static const std::string KEY;
std::string getKey() const override { return KEY; }
void run(ir::Module *) override;
};
} // namespace seq