2014-10-02 12:05:27 -04:00
|
|
|
/*!
|
|
|
|
* \file language_base.h
|
|
|
|
*
|
|
|
|
* \brief Language Base class for Polymorphism.
|
|
|
|
*/
|
|
|
|
|
2014-10-02 11:44:29 -04:00
|
|
|
#ifndef LANGUAGE_BASE_H
|
|
|
|
#define LANGUAGE_BASE_H
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include <unordered_map>
|
|
|
|
#include <string>
|
|
|
|
|
2014-10-02 12:05:27 -04:00
|
|
|
/*!
|
|
|
|
* \namespace Language
|
|
|
|
* \brief Mnemonic language related namespace.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
namespace Language
|
|
|
|
{
|
2014-10-02 12:05:27 -04:00
|
|
|
const int unique_prefix_length = 4; /*!< Length of the prefix of all words guaranteed to be unique */
|
|
|
|
/*!
|
|
|
|
* \class Base
|
|
|
|
* \brief A base language class which all languages have to inherit from for
|
|
|
|
* Polymorphism.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
class Base
|
|
|
|
{
|
|
|
|
protected:
|
2014-10-02 12:05:27 -04:00
|
|
|
std::vector<std::string> *word_list; /*!< A pointer to the array of words */
|
|
|
|
std::unordered_map<std::string, uint32_t> *word_map; /*!< hash table to find word's index */
|
|
|
|
std::unordered_map<std::string, uint32_t> *trimmed_word_map; /*!< hash table to find word's trimmed index */
|
|
|
|
std::string language_name; /*!< Name of language */
|
|
|
|
/*!
|
|
|
|
* \brief Populates the word maps after the list is ready.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
void populate_maps()
|
|
|
|
{
|
|
|
|
int ii;
|
|
|
|
std::vector<std::string>::iterator it;
|
|
|
|
for (it = word_list->begin(), ii = 0; it != word_list->end(); it++, ii++)
|
|
|
|
{
|
|
|
|
(*word_map)[*it] = ii;
|
2014-10-02 12:05:27 -04:00
|
|
|
if (it->length() > unique_prefix_length)
|
2014-10-02 11:44:29 -04:00
|
|
|
{
|
2014-10-02 12:05:27 -04:00
|
|
|
(*trimmed_word_map)[it->substr(0, unique_prefix_length)] = ii;
|
2014-10-02 11:44:29 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
(*trimmed_word_map)[*it] = ii;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public:
|
|
|
|
Base()
|
|
|
|
{
|
|
|
|
word_list = new std::vector<std::string>;
|
|
|
|
word_map = new std::unordered_map<std::string, uint32_t>;
|
|
|
|
trimmed_word_map = new std::unordered_map<std::string, uint32_t>;
|
|
|
|
}
|
2014-10-02 12:05:27 -04:00
|
|
|
/*!
|
|
|
|
* \brief Returns a pointer to the word list.
|
|
|
|
* \return A pointer to the word list.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
const std::vector<std::string>& get_word_list() const
|
|
|
|
{
|
|
|
|
return *word_list;
|
|
|
|
}
|
2014-10-02 12:05:27 -04:00
|
|
|
/*!
|
|
|
|
* \brief Returns a pointer to the word map.
|
|
|
|
* \return A pointer to the word map.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
const std::unordered_map<std::string, uint32_t>& get_word_map() const
|
|
|
|
{
|
|
|
|
return *word_map;
|
|
|
|
}
|
2014-10-02 12:05:27 -04:00
|
|
|
/*!
|
|
|
|
* \brief Returns a pointer to the trimmed word map.
|
|
|
|
* \return A pointer to the trimmed word map.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
const std::unordered_map<std::string, uint32_t>& get_trimmed_word_map() const
|
|
|
|
{
|
|
|
|
return *trimmed_word_map;
|
|
|
|
}
|
2014-10-02 12:05:27 -04:00
|
|
|
/*!
|
|
|
|
* \brief Returns the name of the language.
|
|
|
|
* \return Name of the language.
|
|
|
|
*/
|
2014-10-02 11:44:29 -04:00
|
|
|
std::string get_language_name() const
|
|
|
|
{
|
|
|
|
return language_name;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|