tree-sitter/src/compiler/lr/item.h

46 lines
1.2 KiB
C
Raw Normal View History

#ifndef __TreeSitter__item__
#define __TreeSitter__item__
#include <string>
#include "rule.h"
#include "transition_map.h"
namespace tree_sitter {
class Grammar;
namespace lr {
class Item {
public:
2013-11-12 08:17:19 -08:00
Item(const std::string &rule_name, const rules::rule_ptr rule, int consumed_sym_count);
2013-11-20 19:00:20 -08:00
static Item at_beginning_of_rule(const std::string &rule_name, const Grammar &grammar);
TransitionMap<Item> transitions() const;
std::vector<rules::sym_ptr> next_symbols() const;
2013-11-12 08:17:19 -08:00
bool operator==(const Item &other) const;
2013-12-15 14:41:51 -08:00
bool is_done() const;
2013-11-12 08:17:19 -08:00
const std::string rule_name;
const rules::rule_ptr rule;
const int consumed_sym_count;
};
typedef std::shared_ptr<const Item> item_ptr;
2013-11-12 08:17:19 -08:00
std::ostream& operator<<(std::ostream &stream, const Item &item);
2013-12-15 14:41:51 -08:00
}
}
2013-12-15 14:41:51 -08:00
namespace std {
template<>
struct hash<tree_sitter::lr::Item> {
size_t operator()(const tree_sitter::lr::Item &item) {
return
hash<std::string>()(item.rule_name) ^
hash<tree_sitter::rules::Rule>()(*item.rule) ^
hash<int>()(item.consumed_sym_count);
}
};
}
2013-11-12 08:17:19 -08:00
#endif