diff options
| -rw-r--r-- | generator/form.cpp | 4 | ||||
| -rw-r--r-- | generator/form.h | 6 | ||||
| -rw-r--r-- | generator/schema.sql | 3 | ||||
| -rw-r--r-- | lib/form.cpp | 4 | ||||
| -rw-r--r-- | lib/form.h | 14 |
5 files changed, 27 insertions, 4 deletions
| diff --git a/generator/form.cpp b/generator/form.cpp index 6be9d47..f616344 100644 --- a/generator/form.cpp +++ b/generator/form.cpp | |||
| @@ -14,7 +14,8 @@ namespace verbly { | |||
| 14 | id_(nextId_++), | 14 | id_(nextId_++), |
| 15 | text_(text), | 15 | text_(text), |
| 16 | complexity_(std::count(std::begin(text), std::end(text), ' ') + 1), | 16 | complexity_(std::count(std::begin(text), std::end(text), ' ') + 1), |
| 17 | proper_(std::any_of(std::begin(text), std::end(text), std::isupper)) | 17 | proper_(std::any_of(std::begin(text), std::end(text), std::isupper)), |
| 18 | length_(text.length()) | ||
| 18 | { | 19 | { |
| 19 | } | 20 | } |
| 20 | 21 | ||
| @@ -32,6 +33,7 @@ namespace verbly { | |||
| 32 | fields.emplace_back("form", arg.getText()); | 33 | fields.emplace_back("form", arg.getText()); |
| 33 | fields.emplace_back("complexity", arg.getComplexity()); | 34 | fields.emplace_back("complexity", arg.getComplexity()); |
| 34 | fields.emplace_back("proper", arg.isProper()); | 35 | fields.emplace_back("proper", arg.isProper()); |
| 36 | fields.emplace_back("length", arg.getLength()); | ||
| 35 | 37 | ||
| 36 | db.insertIntoTable("forms", std::move(fields)); | 38 | db.insertIntoTable("forms", std::move(fields)); |
| 37 | } | 39 | } |
| diff --git a/generator/form.h b/generator/form.h index 5576035..5a2de30 100644 --- a/generator/form.h +++ b/generator/form.h | |||
| @@ -43,6 +43,11 @@ namespace verbly { | |||
| 43 | return proper_; | 43 | return proper_; |
| 44 | } | 44 | } |
| 45 | 45 | ||
| 46 | int getLength() const | ||
| 47 | { | ||
| 48 | return length_; | ||
| 49 | } | ||
| 50 | |||
| 46 | std::set<const pronunciation*> getPronunciations() const | 51 | std::set<const pronunciation*> getPronunciations() const |
| 47 | { | 52 | { |
| 48 | return pronunciations_; | 53 | return pronunciations_; |
| @@ -56,6 +61,7 @@ namespace verbly { | |||
| 56 | const std::string text_; | 61 | const std::string text_; |
| 57 | const int complexity_; | 62 | const int complexity_; |
| 58 | const bool proper_; | 63 | const bool proper_; |
| 64 | const int length_; | ||
| 59 | 65 | ||
| 60 | std::set<const pronunciation*> pronunciations_; | 66 | std::set<const pronunciation*> pronunciations_; |
| 61 | 67 | ||
| diff --git a/generator/schema.sql b/generator/schema.sql index a49a853..c0f2bcb 100644 --- a/generator/schema.sql +++ b/generator/schema.sql | |||
| @@ -155,7 +155,8 @@ CREATE TABLE `forms` ( | |||
| 155 | `form_id` INTEGER PRIMARY KEY, | 155 | `form_id` INTEGER PRIMARY KEY, |
| 156 | `form` VARCHAR(32) NOT NULL, | 156 | `form` VARCHAR(32) NOT NULL, |
| 157 | `complexity` SMALLINT NOT NULL, | 157 | `complexity` SMALLINT NOT NULL, |
| 158 | `proper` SMALLINT NOT NULL | 158 | `proper` SMALLINT NOT NULL, |
| 159 | `length` SMALLINT NOT NULL | ||
| 159 | ); | 160 | ); |
| 160 | 161 | ||
| 161 | CREATE UNIQUE INDEX `form_by_string` ON `forms`(`form`); | 162 | CREATE UNIQUE INDEX `form_by_string` ON `forms`(`form`); |
| diff --git a/lib/form.cpp b/lib/form.cpp index 2f9509f..feaf765 100644 --- a/lib/form.cpp +++ b/lib/form.cpp | |||
| @@ -10,12 +10,13 @@ namespace verbly { | |||
| 10 | 10 | ||
| 11 | const object form::objectType = object::form; | 11 | const object form::objectType = object::form; |
| 12 | 12 | ||
| 13 | const std::list<std::string> form::select = {"form_id", "form", "complexity", "proper"}; | 13 | const std::list<std::string> form::select = {"form_id", "form", "complexity", "proper", "length"}; |
| 14 | 14 | ||
| 15 | const field form::id = field::integerField(object::form, "form_id"); | 15 | const field form::id = field::integerField(object::form, "form_id"); |
| 16 | const field form::text = field::stringField(object::form, "form"); | 16 | const field form::text = field::stringField(object::form, "form"); |
| 17 | const field form::complexity = field::integerField(object::form, "complexity"); | 17 | const field form::complexity = field::integerField(object::form, "complexity"); |
| 18 | const field form::proper = field::booleanField(object::form, "proper"); | 18 | const field form::proper = field::booleanField(object::form, "proper"); |
| 19 | const field form::length = field::integerField(object::form, "length"); | ||
| 19 | 20 | ||
| 20 | const field form::pronunciations = field::joinThrough(object::form, "form_id", object::pronunciation, "forms_pronunciations", "pronunciation_id"); | 21 | const field form::pronunciations = field::joinThrough(object::form, "form_id", object::pronunciation, "forms_pronunciations", "pronunciation_id"); |
| 21 | 22 | ||
| @@ -30,6 +31,7 @@ namespace verbly { | |||
| 30 | text_ = std::string(reinterpret_cast<const char*>(sqlite3_column_text(row, 1))); | 31 | text_ = std::string(reinterpret_cast<const char*>(sqlite3_column_text(row, 1))); |
| 31 | complexity_ = sqlite3_column_int(row, 2); | 32 | complexity_ = sqlite3_column_int(row, 2); |
| 32 | proper_ = (sqlite3_column_int(row, 3) == 1); | 33 | proper_ = (sqlite3_column_int(row, 3) == 1); |
| 34 | length_ = sqlite3_column_int(row, 4); | ||
| 33 | } | 35 | } |
| 34 | 36 | ||
| 35 | const std::vector<pronunciation>& form::getPronunciations() const | 37 | const std::vector<pronunciation>& form::getPronunciations() const |
| diff --git a/lib/form.h b/lib/form.h index e3e1185..479672f 100644 --- a/lib/form.h +++ b/lib/form.h | |||
| @@ -73,6 +73,16 @@ namespace verbly { | |||
| 73 | return proper_; | 73 | return proper_; |
| 74 | } | 74 | } |
| 75 | 75 | ||
| 76 | int getLength() const | ||
| 77 | { | ||
| 78 | if (!valid_) | ||
| 79 | { | ||
| 80 | throw std::domain_error("Bad access to uninitialized form"); | ||
| 81 | } | ||
| 82 | |||
| 83 | return length_; | ||
| 84 | } | ||
| 85 | |||
| 76 | const std::vector<pronunciation>& getPronunciations() const; | 86 | const std::vector<pronunciation>& getPronunciations() const; |
| 77 | 87 | ||
| 78 | // Convenience | 88 | // Convenience |
| @@ -91,6 +101,7 @@ namespace verbly { | |||
| 91 | static const field text; | 101 | static const field text; |
| 92 | static const field complexity; | 102 | static const field complexity; |
| 93 | static const field proper; | 103 | static const field proper; |
| 104 | static const field length; | ||
| 94 | 105 | ||
| 95 | operator filter() const | 106 | operator filter() const |
| 96 | { | 107 | { |
| @@ -123,8 +134,9 @@ namespace verbly { | |||
| 123 | 134 | ||
| 124 | int id_; | 135 | int id_; |
| 125 | std::string text_; | 136 | std::string text_; |
| 126 | int complexity_ ; | 137 | int complexity_; |
| 127 | bool proper_; | 138 | bool proper_; |
| 139 | int length_; | ||
| 128 | 140 | ||
| 129 | const database* db_; | 141 | const database* db_; |
| 130 | 142 | ||
