#include "item.h" #include "grammar.h" #include "rule_transitions.h" using std::string; using std::ostream; namespace tree_sitter { namespace build_tables { Item::Item(const string &rule_name, const rules::rule_ptr rule) : rule_name(rule_name), rule(rule) {}; bool Item::is_done() const { for (auto pair : rule_transitions(rule)) if (*pair.first == rules::Blank()) return true; return false; } ostream& operator<<(ostream &stream, const Item &item) { return stream << string("#"); } bool Item::operator<(const Item &other) const { return rule_name < other.rule_name; } LexItem::LexItem(const std::string &rule_name, const rules::rule_ptr rule) : Item(rule_name, rule) {} bool LexItem::operator==(const LexItem &other) const { bool rule_names_eq = other.rule_name == rule_name; bool rules_eq = (*other.rule == *rule); return rule_names_eq && rules_eq; } ParseItem::ParseItem(const std::string &rule_name, const rules::rule_ptr rule, int consumed_sym_count) : Item(rule_name, rule), consumed_sym_count(consumed_sym_count), lookahead_sym_name("") {} bool ParseItem::operator==(const ParseItem &other) const { bool rule_names_eq = other.rule_name == rule_name; bool rules_eq = (*other.rule == *rule); bool consumed_sym_counts_eq = (other.consumed_sym_count == consumed_sym_count); return rule_names_eq && rules_eq && consumed_sym_counts_eq; } } }