From 02c187fd3141203024b6f359ec714c0b804583c0 Mon Sep 17 00:00:00 2001 From: Kelly Rauchenberger Date: Sat, 19 Mar 2016 14:40:21 -0400 Subject: Nouns with any uppercase letters are now considered proper --- generator/generator.cpp | 12 +++++++++--- generator/schema.sql | 3 ++- 2 files changed, 11 insertions(+), 4 deletions(-) (limited to 'generator') diff --git a/generator/generator.cpp b/generator/generator.cpp index faef5f7..de369a4 100644 --- a/generator/generator.cpp +++ b/generator/generator.cpp @@ -10,6 +10,7 @@ #include #include #include +#include #include "progress.h" struct verb { @@ -525,9 +526,9 @@ int main(int argc, char** argv) { if (nouns.count(word) == 1) { - query = "INSERT INTO nouns (singular, plural) VALUES (?, ?)"; + query = "INSERT INTO nouns (singular, proper, plural) VALUES (?, ?, ?)"; } else { - query = "INSERT INTO nouns (singular) VALUES (?)"; + query = "INSERT INTO nouns (singular, proper) VALUES (?, ?)"; } break; @@ -576,9 +577,14 @@ int main(int argc, char** argv) { case 1: // Noun { + auto sing = nouns[word].singular; + sqlite3_bind_int(ppstmt, 2, (std::any_of(std::begin(sing), std::end(sing), [] (char ch) { + return isupper(ch); + }) ? 1 : 0)); + if (nouns.count(word) == 1) { - sqlite3_bind_text(ppstmt, 2, nouns[word].plural.c_str(), nouns[word].plural.length(), SQLITE_STATIC); + sqlite3_bind_text(ppstmt, 3, nouns[word].plural.c_str(), nouns[word].plural.length(), SQLITE_STATIC); } break; diff --git a/generator/schema.sql b/generator/schema.sql index b4efe0a..8e1e822 100644 --- a/generator/schema.sql +++ b/generator/schema.sql @@ -52,7 +52,8 @@ DROP TABLE IF EXISTS `nouns`; CREATE TABLE `nouns` ( `noun_id` INTEGER PRIMARY KEY, `singular` VARCHAR(32) NOT NULL, - `plural` VARCHAR(32) + `plural` VARCHAR(32), + `proper` INTEGER(1) NOT NULL ); DROP TABLE IF EXISTS `hypernymy`; -- cgit 1.4.1