memgraph/cypher/ast/tree.hpp

51 lines
1023 B
C++
Raw Normal View History

#ifndef MEMGRAPH_CYPHER_AST_TREE_HPP
#define MEMGRAPH_CYPHER_AST_TREE_HPP
#include <vector>
#include "ast_node.hpp"
namespace ast
{
class Ast
{
public:
2015-10-19 01:44:00 +08:00
Ast() = default;
Ast(const Ast&) = delete;
Ast(Ast&& other)
{
this->root = other.root;
other.root = nullptr;
this->items = std::move(other.items);
}
AstVisitable* root;
void traverse(AstVisitor& visitor)
{
root->accept(visitor);
}
template <class T, typename... Args>
T* create(Args&&... args)
{
auto node = new T(std::forward<Args>(args)...);
items.push_back(std::unique_ptr<AstVisitable>(node));
return node;
}
private:
// basically a gc vector that destroys all ast nodes once this object is
// destroyed. parser generator is written in c and works only with raw
// pointers so this is what makes it leak free after the parser finishes
// parsing without using shared pointers
std::vector<AstVisitable::uptr> items;
};
}
#endif