#ifndef MARISA_QUERY_H_ #define MARISA_QUERY_H_ #include <string> #include "base.h" namespace marisa { class Query { public: Query(const char *ptr, std::size_t length) : ptr_(ptr), length_(length) {} Query(const Query &query) : ptr_(query.ptr_), length_(query.length_) {} void insert(std::string *str) const { str->insert(0, ptr_, length_); } UInt8 operator[](std::size_t i) const { MARISA_DEBUG_IF(i >= length_, MARISA_PARAM_ERROR); return ptr_[i]; } bool ends_at(std::size_t i) const { MARISA_DEBUG_IF(i > length_, MARISA_PARAM_ERROR); return i == length_; } private: const char *ptr_; std::size_t length_; // Disallows assignment. Query &operator=(const Query &query); }; class CQuery { public: explicit CQuery(const char *str) : str_(str) {} CQuery(const CQuery &query) : str_(query.str_) {} void insert(std::string *str) const { str->insert(0, str_); } UInt8 operator[](std::size_t i) const { return str_[i]; } bool ends_at(std::size_t i) const { return str_[i] == '\0'; } private: const char *str_; // Disallows assignment. CQuery &operator=(const CQuery &); }; } // namespace marisa #endif // MARISA_QUERY_H_