Fully cleaned and added the sqlite database backend to the build.

This commit is contained in:
Relintai 2022-07-06 22:14:37 +02:00
parent 2a5e0ae0f8
commit d02d86aedc
18 changed files with 446 additions and 381 deletions

View File

@ -5,9 +5,6 @@
#include "core/reference.h" #include "core/reference.h"
class QueryBuilder;
class TableBuilder;
class QueryResult;
class DatabaseConnection; class DatabaseConnection;
class Database : public Reference { class Database : public Reference {

View File

@ -2,6 +2,13 @@
#include "query_result.h" #include "query_result.h"
String QueryBuilder::get_result() {
return query_result;
}
void QueryBuilder::set_result(const String &val) {
query_result = val;
}
QueryBuilder *QueryBuilder::select() { QueryBuilder *QueryBuilder::select() {
return this; return this;
} }
@ -280,12 +287,6 @@ Ref<QueryResult> QueryBuilder::run() {
void QueryBuilder::run_query() { void QueryBuilder::run_query() {
} }
String QueryBuilder::get_result() {
end_command();
return query_result;
}
void QueryBuilder::print() { void QueryBuilder::print() {
//printf("%s\n", query_result.c_str()); //printf("%s\n", query_result.c_str());
ERR_PRINT(query_result); ERR_PRINT(query_result);
@ -298,6 +299,10 @@ QueryBuilder::~QueryBuilder() {
} }
void QueryBuilder::_bind_methods() { void QueryBuilder::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_result"), &QueryBuilder::get_result);
ClassDB::bind_method(D_METHOD("set_result", "value"), &QueryBuilder::set_result);
ADD_PROPERTY(PropertyInfo(Variant::STRING, "result"), "set_result", "get_result");
ClassDB::bind_method(D_METHOD("cvalues"), &QueryBuilder::_cvalues_bind); ClassDB::bind_method(D_METHOD("cvalues"), &QueryBuilder::_cvalues_bind);
ClassDB::bind_method(D_METHOD("next_value"), &QueryBuilder::_next_value_bind); ClassDB::bind_method(D_METHOD("next_value"), &QueryBuilder::_next_value_bind);
@ -381,6 +386,9 @@ void QueryBuilder::_bind_methods() {
ClassDB::bind_method(D_METHOD("end_command"), &QueryBuilder::_end_command_bind); ClassDB::bind_method(D_METHOD("end_command"), &QueryBuilder::_end_command_bind);
ClassDB::bind_method(D_METHOD("reset"), &QueryBuilder::_reset_bind); ClassDB::bind_method(D_METHOD("reset"), &QueryBuilder::_reset_bind);
ClassDB::bind_method(D_METHOD("run"), &QueryBuilder::run);
ClassDB::bind_method(D_METHOD("run_query"), &QueryBuilder::run_query);
} }
Ref<QueryBuilder> QueryBuilder::_cvalues_bind() { Ref<QueryBuilder> QueryBuilder::_cvalues_bind() {
@ -409,26 +417,26 @@ Ref<QueryBuilder> QueryBuilder::_cstr_bind() {
} }
Ref<QueryBuilder> QueryBuilder::_select_bind(const String &params) { Ref<QueryBuilder> QueryBuilder::_select_bind(const String &params) {
return Ref<QueryBuilder>(select()); return Ref<QueryBuilder>(select(params));
} }
Ref<QueryBuilder> QueryBuilder::_update_bind(const String &params) { Ref<QueryBuilder> QueryBuilder::_update_bind(const String &params) {
return Ref<QueryBuilder>(update()); return Ref<QueryBuilder>(update(params));
} }
Ref<QueryBuilder> QueryBuilder::_del_bind(const String &params) { Ref<QueryBuilder> QueryBuilder::_del_bind(const String &params) {
return Ref<QueryBuilder>(del()); return Ref<QueryBuilder>(del(params));
} }
Ref<QueryBuilder> QueryBuilder::_where_bind(const String &params) { Ref<QueryBuilder> QueryBuilder::_where_bind(const String &params) {
return Ref<QueryBuilder>(where()); return Ref<QueryBuilder>(where(params));
} }
Ref<QueryBuilder> QueryBuilder::_from_bind(const String &params) { Ref<QueryBuilder> QueryBuilder::_from_bind(const String &params) {
return Ref<QueryBuilder>(from()); return Ref<QueryBuilder>(from(params));
} }
Ref<QueryBuilder> QueryBuilder::_insert_bind(const String &table_name, const String &columns) { Ref<QueryBuilder> QueryBuilder::_insert_bind(const String &table_name, const String &columns) {
return Ref<QueryBuilder>(insert()); return Ref<QueryBuilder>(insert(table_name, columns));
} }
Ref<QueryBuilder> QueryBuilder::_values_bind(const String &params_str) { Ref<QueryBuilder> QueryBuilder::_values_bind(const String &params_str) {
return Ref<QueryBuilder>(values()); return Ref<QueryBuilder>(values(params_str));
} }
Ref<QueryBuilder> QueryBuilder::_val_bind() { Ref<QueryBuilder> QueryBuilder::_val_bind() {
return Ref<QueryBuilder>(val()); return Ref<QueryBuilder>(val());
@ -450,7 +458,7 @@ Ref<QueryBuilder> QueryBuilder::_vald_bind(const double param) {
} }
Ref<QueryBuilder> QueryBuilder::_like_bind(const String &str) { Ref<QueryBuilder> QueryBuilder::_like_bind(const String &str) {
return Ref<QueryBuilder>(like()); return Ref<QueryBuilder>(like(str));
} }
Ref<QueryBuilder> QueryBuilder::_sets_bind() { Ref<QueryBuilder> QueryBuilder::_sets_bind() {

View File

@ -13,6 +13,9 @@ class QueryBuilder : public Reference {
GDCLASS(QueryBuilder, Reference); GDCLASS(QueryBuilder, Reference);
public: public:
String get_result();
void set_result(const String &val);
virtual QueryBuilder *select(); virtual QueryBuilder *select();
virtual QueryBuilder *update(); virtual QueryBuilder *update();
virtual QueryBuilder *del(); virtual QueryBuilder *del();
@ -113,8 +116,6 @@ public:
virtual Ref<QueryResult> run(); virtual Ref<QueryResult> run();
virtual void run_query(); virtual void run_query();
String get_result();
void print(); void print();
QueryBuilder(); QueryBuilder();

View File

@ -6,12 +6,8 @@ bool QueryResult::next_row() {
return false; return false;
} }
const char *QueryResult::get_cell_chr(const int index) {
return "";
}
String QueryResult::get_cell(const int index) { String QueryResult::get_cell(const int index) {
return String(get_cell_chr(index)); return String();
} }
bool QueryResult::get_cell_bool(const int index) { bool QueryResult::get_cell_bool(const int index) {
@ -49,6 +45,10 @@ int QueryResult::get_last_insert_rowid() {
return 0; return 0;
} }
String QueryResult::get_error_message() {
return "";
}
QueryResult::QueryResult() { QueryResult::QueryResult() {
} }
@ -67,4 +67,6 @@ void QueryResult::_bind_methods() {
ClassDB::bind_method(D_METHOD("is_cell_null", "index"), &QueryResult::is_cell_null); ClassDB::bind_method(D_METHOD("is_cell_null", "index"), &QueryResult::is_cell_null);
ClassDB::bind_method(D_METHOD("get_last_insert_rowid"), &QueryResult::get_last_insert_rowid); ClassDB::bind_method(D_METHOD("get_last_insert_rowid"), &QueryResult::get_last_insert_rowid);
ClassDB::bind_method(D_METHOD("get_error_message"), &QueryResult::get_error_message);
} }

View File

@ -10,7 +10,6 @@ class QueryResult : public Reference {
public: public:
virtual bool next_row(); virtual bool next_row();
virtual const char *get_cell_chr(const int index);
virtual String get_cell(const int index); virtual String get_cell(const int index);
virtual bool get_cell_bool(const int index); virtual bool get_cell_bool(const int index);
virtual int get_cell_int(const int index); virtual int get_cell_int(const int index);
@ -21,6 +20,8 @@ public:
virtual int get_last_insert_rowid(); virtual int get_last_insert_rowid();
virtual String get_error_message();
QueryResult(); QueryResult();
virtual ~QueryResult(); virtual ~QueryResult();

View File

@ -143,6 +143,9 @@ void TableBuilder::_bind_methods() {
ClassDB::bind_method(D_METHOD("foreign_key", "name"), &TableBuilder::_foreign_key_bind); ClassDB::bind_method(D_METHOD("foreign_key", "name"), &TableBuilder::_foreign_key_bind);
ClassDB::bind_method(D_METHOD("references", "table", "name"), &TableBuilder::_references_bind); ClassDB::bind_method(D_METHOD("references", "table", "name"), &TableBuilder::_references_bind);
ClassDB::bind_method(D_METHOD("run"), &TableBuilder::run);
ClassDB::bind_method(D_METHOD("run_query"), &TableBuilder::run_query);
} }
Ref<TableBuilder> TableBuilder::_create_table_bind(const String &name) { Ref<TableBuilder> TableBuilder::_create_table_bind(const String &name) {
@ -170,7 +173,7 @@ Ref<TableBuilder> TableBuilder::_date_bind(const String &name) {
} }
Ref<TableBuilder> TableBuilder::_varchar_bind(const String &name, const int length) { Ref<TableBuilder> TableBuilder::_varchar_bind(const String &name, const int length) {
return Ref<TableBuilder>(varchar(name)); return Ref<TableBuilder>(varchar(name, length));
} }
Ref<TableBuilder> TableBuilder::_text_bind(const String &name) { Ref<TableBuilder> TableBuilder::_text_bind(const String &name) {
return Ref<TableBuilder>(text(name)); return Ref<TableBuilder>(text(name));

View File

@ -22,16 +22,20 @@ module_env = env.Clone()
sources = [ sources = [
"register_types.cpp", "register_types.cpp",
"sqlite/sqlite3.c" "sqlite/sqlite3.c",
"sqlite3_database.cpp", "sqlite3_database.cpp",
"sqlite3_database_connection.cpp", "sqlite3_connection.cpp",
"sqlite3_database_manager.cpp",
"sqlite3_query_builder.cpp", "sqlite3_query_builder.cpp",
"sqlite3_query_result.cpp", "sqlite3_query_result.cpp",
"sqlite3_table_builder.cpp", "sqlite3_table_builder.cpp",
] ]
# sqlite has a few warnings, disable werrors for this module for now
# it should be patched later.
if module_env["werror"]:
module_env["werror"] = False
if ARGUMENTS.get('custom_modules_shared', 'no') == 'yes': if ARGUMENTS.get('custom_modules_shared', 'no') == 'yes':
# Shared lib compilation # Shared lib compilation
module_env.Append(CCFLAGS=['-fPIC']) module_env.Append(CCFLAGS=['-fPIC'])

View File

@ -4,7 +4,7 @@ import sys
def can_build(env, platform): def can_build(env, platform):
return False return True
def _can_build(): def _can_build():
@ -26,8 +26,6 @@ def _can_build():
# #todo # #todo
# return False # return False
#print("sqlite3 built in!")
return True return True
@ -48,8 +46,7 @@ def _configure(env):
def get_doc_classes(): def get_doc_classes():
return [ return [
#"", "SQLite3Database ",
"Sqlite3Database",
] ]
def get_doc_path(): def get_doc_path():

View File

@ -0,0 +1,100 @@
#include "sqlite3_connection.h"
#include "core/print_string.h"
#include "core/ustring.h"
#include "sqlite3_query_builder.h"
#include "sqlite3_query_result.h"
#include "sqlite3_table_builder.h"
#include "./sqlite/sqlite3.h"
#include <cstdio>
Ref<QueryBuilder> SQLite3DatabaseConnection::get_query_builder() {
Ref<SQLite3QueryBuilder> b;
b.instance();
b->_connection.reference_ptr(this);
return b;
}
Ref<TableBuilder> SQLite3DatabaseConnection::get_table_builder() {
Ref<SQLite3TableBuilder> b;
b.instance();
b->_connection.reference_ptr(this);
return b;
}
void SQLite3DatabaseConnection::database_connect(const String &connection_str) {
int ret = sqlite3_config(SQLITE_CONFIG_MULTITHREAD);
if (ret != SQLITE_OK) {
ERR_PRINT("SQLITE3 multithreading is not supported!\n");
}
//CharString cstr = connection_str.ascii();
CharString cstr = connection_str.utf8();
ret = sqlite3_open(cstr.get_data(), &conn);
}
Ref<QueryResult> SQLite3DatabaseConnection::query(const String &query) {
Ref<Sqlite3QueryResult> res;
res.instance();
res->query(query, conn);
return res;
}
void SQLite3DatabaseConnection::query_run(const String &query) {
char *err_msg;
CharString q = query.utf8();
if (sqlite3_exec(conn, q.get_data(), NULL, NULL, &err_msg) != SQLITE_OK) {
ERR_PRINT("SQLite3Database::query_run error:");
ERR_PRINT("Query: " + query);
ERR_PRINT("Error: " + String(err_msg));
sqlite3_free(err_msg);
}
}
String SQLite3DatabaseConnection::escape(const String &str) {
char *ret;
CharString q = str.utf8();
ret = sqlite3_mprintf("%q", q.get_data());
if (ret) {
String res(ret);
sqlite3_free(ret);
return res;
}
return "";
}
void SQLite3DatabaseConnection::escape_to(const String &str, String *to) {
char *ret;
ret = sqlite3_mprintf("%q", str.c_str());
if (ret) {
to->operator=(ret);
sqlite3_free(ret);
}
}
SQLite3DatabaseConnection::SQLite3DatabaseConnection() {
conn = nullptr;
}
SQLite3DatabaseConnection::~SQLite3DatabaseConnection() {
if (conn) {
sqlite3_close(conn);
}
}

View File

@ -0,0 +1,33 @@
#ifndef SQLITE3_DATABASE_CONNECTION_H
#define SQLITE3_DATABASE_CONNECTION_H
#include "../database/database_connection.h"
#include "./sqlite/sqlite3.h"
class QueryBuilder;
class TableBuilder;
class QueryResult;
class Database;
struct sqlite3;
class SQLite3DatabaseConnection : public DatabaseConnection {
public:
void database_connect(const String &connection_str);
Ref<QueryResult> query(const String &query);
void query_run(const String &query);
Ref<QueryBuilder> get_query_builder();
Ref<TableBuilder> get_table_builder();
String escape(const String &str);
void escape_to(const String &str, String *to);
SQLite3DatabaseConnection();
~SQLite3DatabaseConnection();
protected:
sqlite3 *conn;
};
#endif

View File

@ -1,95 +1,17 @@
#include "sqlite3_database.h" #include "sqlite3_database.h"
#include "database/database_manager.h" #include "sqlite3_connection.h"
#include "sqlite3_query_builder.h" Ref<DatabaseConnection> SQLite3Database::_allocate_connection() {
#include "sqlite3_query_result.h" Ref<SQLite3DatabaseConnection> dbc;
#include "sqlite3_table_builder.h" dbc.instance();
dbc->set_owner(this);
Database *SQLite3Database::_creation_func() { dbc->database_connect(_connection_string);
return new SQLite3Database(); return dbc;
} }
void SQLite3Database::_register() { SQLite3Database::SQLite3Database() {
DatabaseManager::_register_db_creation_func("sqlite", SQLite3Database::_creation_func);
}
void SQLite3Database::_unregister() {
DatabaseManager::_unregister_db_creation_func("sqlite");
}
Ref<QueryBuilder> SQLite3Database::get_query_builder() {
SQLite3QueryBuilder *b = new SQLite3QueryBuilder();
b->_db = this;
return b;
}
Ref<TableBuilder> SQLite3Database::get_table_builder() {
SQLite3TableBuilder *b = new SQLite3TableBuilder();
b->_db = this;
return b;
}
void SQLite3Database::connect(const String &connection_str) {
int ret = sqlite3_config(SQLITE_CONFIG_MULTITHREAD);
if (ret != SQLITE_OK) {
printf("SQLITE3 multithreading is not supported!\n");
}
ret = sqlite3_open(connection_str.c_str(), &conn);
}
Ref<QueryResult> SQLite3Database::query(const String &query) {
Sqlite3QueryResult *res = new Sqlite3QueryResult();
res->query(query, conn);
return res;
}
void SQLite3Database::query_run(const String &query) {
char *err_msg;
if (sqlite3_exec(conn, query.c_str(), NULL, NULL, &err_msg) != SQLITE_OK) {
printf("SQLite3Database::query_run error: \nQuery: %s \n Error:\n %s\n", query.c_str(), err_msg);
sqlite3_free(err_msg);
}
}
String SQLite3Database::escape(const String str) {
char *ret;
ret = sqlite3_mprintf("%q", str.c_str());
if (ret) {
String res(ret);
sqlite3_free(ret);
return res;
}
return "";
}
void SQLite3Database::escape(const String str, String *to) {
char *ret;
ret = sqlite3_mprintf("%q", str.c_str());
if (ret) {
to->operator=(ret);
sqlite3_free(ret);
}
}
SQLite3Database::SQLite3Database() :
Database() {
} }
SQLite3Database::~SQLite3Database() { SQLite3Database::~SQLite3Database() {
if (conn)
sqlite3_close(conn);
} }

View File

@ -1,40 +1,17 @@
#ifndef SQLITE3_CONNECTION #ifndef SQLITE3_DATABASE_H
#define SQLITE3_CONNECTION #define SQLITE3_DATABASE_H
#include "database/database.h" #include "../database/database_single_threaded.h"
//Brynet has it aswell, and because of using namespace it is defined here aswell class SQLite3Database : public DatabaseSingleThreaded {
//later this will be fixed better GDCLASS(SQLite3Database, DatabaseSingleThreaded);
//#ifdef IS_NUM
//#undef IS_NUM
//#endif
#include <cstdio>
#include "./sqlite/sqlite3.h"
class SQLite3Database : public Database {
public: public:
static Database *_creation_func();
static void _register();
static void _unregister();
Ref<QueryBuilder> get_query_builder();
Ref<TableBuilder> get_table_builder();
void connect(const String &connection_str);
Ref<QueryResult> query(const String &query);
void query_run(const String &query);
String escape(const String str);
void escape(const String str, String *to);
SQLite3Database(); SQLite3Database();
~SQLite3Database(); ~SQLite3Database();
sqlite3 *conn; protected:
Ref<DatabaseConnection> _allocate_connection();
}; };
//#undef IS_NUM
#endif #endif

View File

@ -1,10 +1,9 @@
#include "sqlite3_query_builder.h" #include "sqlite3_query_builder.h"
#include "sqlite3_connection.h"
#include "sqlite3_database.h" #include "sqlite3_database.h"
#include "sqlite3_query_result.h" #include "sqlite3_query_result.h"
#include <sstream>
QueryBuilder *SQLite3QueryBuilder::select() { QueryBuilder *SQLite3QueryBuilder::select() {
query_result += "SELECT "; query_result += "SELECT ";
@ -21,34 +20,14 @@ QueryBuilder *SQLite3QueryBuilder::del() {
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::where() {
query_result += "WHERE ";
return this;
}
QueryBuilder *SQLite3QueryBuilder::from() {
query_result += "FROM ";
return this;
}
QueryBuilder *SQLite3QueryBuilder::insert() {
query_result += "INSERT INTO ";
return this;
}
QueryBuilder *SQLite3QueryBuilder::values() {
query_result += "VALUES(";
return this;
}
QueryBuilder *SQLite3QueryBuilder::cvalues() { QueryBuilder *SQLite3QueryBuilder::cvalues() {
query_result[query_result.size() - 2] = ' '; query_result[query_result.length() - 2] = ' ';
query_result += ") "; query_result += ") ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::next_value() { QueryBuilder *SQLite3QueryBuilder::next_value() {
query_result[query_result.size() - 2] = ' '; query_result[query_result.length() - 2] = ' ';
query_result += "), ("; query_result += "), (";
return this; return this;
@ -76,52 +55,83 @@ QueryBuilder *SQLite3QueryBuilder::cstr() {
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::like() { QueryBuilder *SQLite3QueryBuilder::like(const String &str) {
query_result += "LIKE "; if (str == "") {
query_result += "LIKE ";
} else {
nlike(escape(str));
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nselect(const String &params) { QueryBuilder *SQLite3QueryBuilder::nselect(const String &params) {
query_result += "SELECT " + params + " "; query_result += "SELECT ";
query_result += params;
query_result += " ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nupdate(const String &params) { QueryBuilder *SQLite3QueryBuilder::nupdate(const String &params) {
query_result += "UPDATE " + params + " "; query_result += "UPDATE ";
query_result += params;
query_result += " ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::ndel(const String &params) { QueryBuilder *SQLite3QueryBuilder::ndel(const String &params) {
query_result += "DELETE FROM " + params + " "; query_result += "DELETE FROM ";
query_result += params;
query_result += " ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nwhere(const String &params) { QueryBuilder *SQLite3QueryBuilder::nwhere(const String &params) {
query_result += "WHERE " + params + " "; query_result += "WHERE ";
if (params != "") {
query_result += params;
query_result += " ";
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nfrom(const String &params) { QueryBuilder *SQLite3QueryBuilder::nfrom(const String &params) {
query_result += "FROM " + params + " "; query_result += "FROM ";
if (params != "") {
query_result += params;
query_result += " ";
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::insert(const String &table_name) {
query_result += "INSERT INTO " + table_name + " ";
return this;
}
QueryBuilder *SQLite3QueryBuilder::insert(const String &table_name, const String &columns) { QueryBuilder *SQLite3QueryBuilder::insert(const String &table_name, const String &columns) {
query_result += "INSERT INTO " + table_name + "(" + columns + ") "; query_result += "INSERT INTO ";
if (table_name != "") {
query_result += table_name;
query_result += " ";
}
if (columns != "") {
query_result += "(";
query_result += columns;
query_result += ") ";
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nvalues(const String &params_str) { QueryBuilder *SQLite3QueryBuilder::nvalues(const String &params_str) {
query_result += "VALUES(" + params_str + ") "; query_result += "VALUES(";
if (params_str != "") {
query_result += params_str;
query_result += ") ";
}
return this; return this;
} }
@ -133,160 +143,174 @@ QueryBuilder *SQLite3QueryBuilder::val() {
} }
QueryBuilder *SQLite3QueryBuilder::nval(const String &param) { QueryBuilder *SQLite3QueryBuilder::nval(const String &param) {
query_result += "'" + param + "', "; query_result += "'";
query_result += param;
query_result += "', ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::val(const char *param) { QueryBuilder *SQLite3QueryBuilder::vals(const String &param) {
query_result += "'" + String(param) + "', "; query_result += "'";
query_result += param;
query_result += "', ";
return this;
}
QueryBuilder *SQLite3QueryBuilder::vals(const char *param) {
query_result += "'";
query_result += String(param);
query_result += "', ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::val(const int param) { QueryBuilder *SQLite3QueryBuilder::vali(const int param) {
//todo add a better way query_result += itos(param);
std::stringstream ss; query_result += ", ";
ss << param;
query_result += ss.str() + ", ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::val(const bool param) { QueryBuilder *SQLite3QueryBuilder::valb(const bool param) {
if (param) if (param) {
query_result += "1, "; query_result += "1, ";
else } else {
query_result += "0, "; query_result += "0, ";
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::valf(const float param) { QueryBuilder *SQLite3QueryBuilder::valf(const float param) {
//todo add a better way query_result += String::num(param);
std::stringstream ss; query_result += ", ";
ss << param;
query_result += ss.str() + ", ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::vald(const double param) { QueryBuilder *SQLite3QueryBuilder::vald(const double param) {
//todo add a better way query_result += String::num(param);
std::stringstream ss; query_result += ", ";
ss << param;
query_result += ss.str() + ", ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nlike(const String &str) { QueryBuilder *SQLite3QueryBuilder::nlike(const String &str) {
query_result += "LIKE '" + str + "' "; query_result += "LIKE '";
query_result += str;
query_result += "' ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::set() { QueryBuilder *SQLite3QueryBuilder::sets() {
query_result += "SET "; query_result += "SET ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::cset() { QueryBuilder *SQLite3QueryBuilder::cset() {
query_result[query_result.size() - 2] = ' '; query_result[query_result.length() - 2] = ' ';
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nsetp(const String &col, const String &param) { QueryBuilder *SQLite3QueryBuilder::nsetp(const String &col, const String &param) {
query_result += col + "='" + param + "', "; query_result += col + "='";
query_result += col + param;
query_result += col + "', ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::setp(const String &col, const char *param) { QueryBuilder *SQLite3QueryBuilder::setps(const String &col, const char *param) {
query_result += col + "='" + String(param) + "', "; query_result += col;
query_result += "='";
query_result += String(param);
query_result += "', ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::setp(const String &col, const int param) { QueryBuilder *SQLite3QueryBuilder::setpi(const String &col, const int param) {
//todo add a better way query_result += col;
std::stringstream ss; query_result += "=";
ss << param; query_result += itos(param);
query_result += ", ";
query_result += col + "=" + ss.str() + ", ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::setp(const String &col, const bool param) { QueryBuilder *SQLite3QueryBuilder::setpb(const String &col, const bool param) {
if (param) if (param) {
query_result += col + "=1, "; query_result += col;
else query_result += "=1, ";
query_result += col + "=0, "; } else {
query_result += col;
query_result += "=0, ";
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::setpf(const String &col, const float param) { QueryBuilder *SQLite3QueryBuilder::setpf(const String &col, const float param) {
//todo add a better way query_result += col;
std::stringstream ss; query_result += "=";
ss << param; query_result += String::num(param);
query_result += ", ";
query_result += col + "=" + ss.str() + ", ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::setpd(const String &col, const double param) { QueryBuilder *SQLite3QueryBuilder::setpd(const String &col, const double param) {
//todo add a better way query_result += col;
std::stringstream ss; query_result += "=";
ss << param; query_result += String::num(param);
query_result += ", ";
query_result += col + "=" + ss.str() + ", ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::nwp(const String &col, const String &param) { QueryBuilder *SQLite3QueryBuilder::nwp(const String &col, const String &param) {
query_result += col + "='" + param + "' "; query_result += col;
query_result += "='";
query_result += param;
query_result += "' ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::wp(const String &col, const char *param) { QueryBuilder *SQLite3QueryBuilder::wps(const String &col, const char *param) {
query_result += col + "='" + String(param) + "' "; query_result += col;
query_result += "='";
query_result += String(param);
query_result += "' ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::wp(const String &col, const int param) { QueryBuilder *SQLite3QueryBuilder::wpi(const String &col, const int param) {
//todo add a better way query_result += col;
std::stringstream ss; query_result += "=";
ss << param; query_result += itos(param);
query_result += " ";
query_result += col + "=" + ss.str() + " ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::wp(const String &col, const bool param) { QueryBuilder *SQLite3QueryBuilder::wpb(const String &col, const bool param) {
if (param) if (param) {
query_result += col + "=1 "; query_result += col;
else query_result += "=1 ";
query_result += col + "=0 "; } else {
query_result += col;
query_result += "=0 ";
}
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::limit(const int num) { QueryBuilder *SQLite3QueryBuilder::limit(const int num) {
//todo better way query_result += "LIMIT ";
std::stringstream ss; query_result += itos(num);
ss << num; query_result += " ";
query_result += "LIMIT " + ss.str() + " ";
return this; return this;
} }
QueryBuilder *SQLite3QueryBuilder::offset(const int num) { QueryBuilder *SQLite3QueryBuilder::offset(const int num) {
//todo better way query_result += "OFFSET ";
std::stringstream ss; query_result += itos(num);
ss << num; query_result += " ";
query_result += "OFFSET " + ss.str() + " ";
return this; return this;
} }
@ -309,13 +333,13 @@ QueryBuilder *SQLite3QueryBuilder::wildcard() {
} }
String SQLite3QueryBuilder::escape(const String &params) { String SQLite3QueryBuilder::escape(const String &params) {
if (!_db) { if (!_connection.is_valid()) {
printf("SQLite3QueryBuilder::escape !db!\n"); printf("SQLite3QueryBuilder::escape !db!\n");
return ""; return "";
} }
return _db->escape(params); return _connection->escape(params);
} }
QueryBuilder *SQLite3QueryBuilder::prepare() { QueryBuilder *SQLite3QueryBuilder::prepare() {
@ -339,23 +363,23 @@ QueryBuilder *SQLite3QueryBuilder::end_command() {
} }
Ref<QueryResult> SQLite3QueryBuilder::run() { Ref<QueryResult> SQLite3QueryBuilder::run() {
if (!_db) { if (!_connection.is_valid()) {
printf("SQLite3QueryBuilder::run !db!\n"); printf("SQLite3QueryBuilder::run !db!\n");
return nullptr; return nullptr;
} }
return _db->query(query_result); return _connection->query(query_result);
} }
void SQLite3QueryBuilder::run_query() { void SQLite3QueryBuilder::run_query() {
if (!_db) { if (!_connection.is_valid()) {
printf("SQLite3QueryBuilder::run_query !db!\n"); printf("SQLite3QueryBuilder::run_query !db!\n");
return; return;
} }
_db->query_run(query_result); _connection->query_run(query_result);
} }
QueryBuilder *SQLite3QueryBuilder::select_last_insert_id() { QueryBuilder *SQLite3QueryBuilder::select_last_insert_id() {

View File

@ -1,25 +1,20 @@
#ifndef SQLITE3_QUERY_BUILDER_H #ifndef SQLITE3_QUERY_BUILDER_H
#define SQLITE3_QUERY_BUILDER_H #define SQLITE3_QUERY_BUILDER_H
#include <memory> #include "core/ustring.h"
#include <string>
#include "database/query_builder.h" #include "../database/query_builder.h"
class SQLite3Database; class SQLite3DatabaseConnection;
class SQLite3QueryBuilder : public QueryBuilder { class SQLite3QueryBuilder : public QueryBuilder {
RCPP_OBJECT(SQLite3QueryBuilder, QueryBuilder); GDCLASS(SQLite3QueryBuilder, QueryBuilder);
public: public:
QueryBuilder *select(); QueryBuilder *select();
QueryBuilder *update(); QueryBuilder *update();
QueryBuilder *del(); QueryBuilder *del();
QueryBuilder *where();
QueryBuilder *from();
QueryBuilder *insert();
QueryBuilder *values();
QueryBuilder *cvalues(); QueryBuilder *cvalues();
QueryBuilder *next_value(); QueryBuilder *next_value();
@ -29,7 +24,7 @@ public:
QueryBuilder *str(); QueryBuilder *str();
QueryBuilder *cstr(); QueryBuilder *cstr();
QueryBuilder *like(); QueryBuilder *like(const String &str = "");
QueryBuilder *nselect(const String &params); QueryBuilder *nselect(const String &params);
QueryBuilder *nupdate(const String &params); QueryBuilder *nupdate(const String &params);
@ -37,32 +32,37 @@ public:
QueryBuilder *nwhere(const String &params); QueryBuilder *nwhere(const String &params);
QueryBuilder *nfrom(const String &params); QueryBuilder *nfrom(const String &params);
QueryBuilder *insert(const String &table_name);
QueryBuilder *insert(const String &table_name, const String &columns); QueryBuilder *insert(const String &table_name = "", const String &columns = "");
QueryBuilder *nvalues(const String &params_str); QueryBuilder *nvalues(const String &params_str);
QueryBuilder *val(); QueryBuilder *val();
QueryBuilder *nval(const String &param); QueryBuilder *nval(const String &param);
QueryBuilder *val(const char *param);
QueryBuilder *val(const int param); QueryBuilder *vals(const String &param);
QueryBuilder *val(const bool param); QueryBuilder *vals(const char *param);
QueryBuilder *vali(const int param);
QueryBuilder *valb(const bool param);
QueryBuilder *valf(const float param); QueryBuilder *valf(const float param);
QueryBuilder *vald(const double param); QueryBuilder *vald(const double param);
QueryBuilder *nlike(const String &str); QueryBuilder *nlike(const String &str);
QueryBuilder *set(); QueryBuilder *sets();
QueryBuilder *cset(); QueryBuilder *cset();
QueryBuilder *nsetp(const String &col, const String &param); QueryBuilder *nsetp(const String &col, const String &param);
QueryBuilder *setp(const String &col, const char *param);
QueryBuilder *setp(const String &col, const int param); QueryBuilder *setps(const String &col, const char *param);
QueryBuilder *setp(const String &col, const bool param); QueryBuilder *setpi(const String &col, const int param);
QueryBuilder *setpb(const String &col, const bool param);
QueryBuilder *setpf(const String &col, const float param); QueryBuilder *setpf(const String &col, const float param);
QueryBuilder *setpd(const String &col, const double param); QueryBuilder *setpd(const String &col, const double param);
QueryBuilder *nwp(const String &col, const String &param); QueryBuilder *nwp(const String &col, const String &param);
QueryBuilder *wp(const String &col, const char *param);
QueryBuilder *wp(const String &col, const int param); QueryBuilder *wps(const String &col, const char *param);
QueryBuilder *wp(const String &col, const bool param); QueryBuilder *wpi(const String &col, const int param);
QueryBuilder *wpb(const String &col, const bool param);
QueryBuilder *limit(const int num); QueryBuilder *limit(const int num);
QueryBuilder *offset(const int num); QueryBuilder *offset(const int num);
@ -90,7 +90,7 @@ public:
SQLite3QueryBuilder(); SQLite3QueryBuilder();
~SQLite3QueryBuilder(); ~SQLite3QueryBuilder();
SQLite3Database *_db; Ref<SQLite3DatabaseConnection> _connection;
}; };
#endif #endif

View File

@ -1,13 +1,16 @@
#include "sqlite3_query_result.h" #include "sqlite3_query_result.h"
#include "./sqlite/sqlite3.h"
#include "core/print_string.h"
#include "core/ustring.h"
#include <cstdio> #include <cstdio>
bool Sqlite3QueryResult::next_row() { bool Sqlite3QueryResult::next_row() {
return ++current_row < rows.size(); return ++current_row < rows.size();
} }
const char *Sqlite3QueryResult::get_cell(const int index) { String Sqlite3QueryResult::get_cell(const int index) {
return rows[current_row]->cells[index].data.c_str(); return rows[current_row]->cells[index].data;
} }
bool Sqlite3QueryResult::is_cell_null(const int index) { bool Sqlite3QueryResult::is_cell_null(const int index) {
@ -18,11 +21,19 @@ int Sqlite3QueryResult::get_last_insert_rowid() {
return sqlite3_last_insert_rowid(_connection); return sqlite3_last_insert_rowid(_connection);
} }
String Sqlite3QueryResult::get_error_message() {
return String(err_msg);
}
void Sqlite3QueryResult::query(const String &query, sqlite3 *conn) { void Sqlite3QueryResult::query(const String &query, sqlite3 *conn) {
_connection = conn; _connection = conn;
if (sqlite3_exec(conn, query.c_str(), Sqlite3QueryResult::run_query_finished, this, &err_msg) != SQLITE_OK) { CharString q = query.utf8();
printf("SQLite3Database::query error: \nQuery: %s \n Error:\n %s\n", query.c_str(), err_msg);
if (sqlite3_exec(conn, q.get_data(), Sqlite3QueryResult::run_query_finished, this, &err_msg) != SQLITE_OK) {
ERR_PRINT("SQLite3Database::query error: ");
ERR_PRINT("Query: " + query);
ERR_PRINT("Error: " + String(err_msg));
sqlite3_free(err_msg); sqlite3_free(err_msg);
} }
} }
@ -32,7 +43,7 @@ int Sqlite3QueryResult::run_query_finished(void *data, int argc, char **argv, ch
//res->col_names = col_names; //res->col_names = col_names;
Sqlite3QueryResultRow *r = new Sqlite3QueryResultRow(); Sqlite3QueryResultRow *r = memnew(Sqlite3QueryResultRow);
for (int i = 0; i < argc; ++i) { for (int i = 0; i < argc; ++i) {
Cell c; Cell c;
@ -51,14 +62,13 @@ int Sqlite3QueryResult::run_query_finished(void *data, int argc, char **argv, ch
return 0; return 0;
} }
Sqlite3QueryResult::Sqlite3QueryResult() : Sqlite3QueryResult::Sqlite3QueryResult() {
QueryResult() {
err_msg = nullptr; err_msg = nullptr;
current_row = -1; current_row = -1;
} }
Sqlite3QueryResult::~Sqlite3QueryResult() { Sqlite3QueryResult::~Sqlite3QueryResult() {
for (int i = 0; i < rows.size(); ++i) { for (int i = 0; i < rows.size(); ++i) {
delete rows[i]; memdelete(rows[i]);
} }
} }

View File

@ -1,23 +1,22 @@
#ifndef MYSQL_QUERY_RESULT_H #ifndef SQLITE3_QUERY_RESULT_H
#define MYSQL_QUERY_RESULT_H #define SQLITE3_QUERY_RESULT_H
#include "core/string.h" #include "core/ustring.h"
#include <vector> #include "core/vector.h"
#include "database/query_result.h" #include "../database/query_result.h"
#include "./sqlite/sqlite3.h" struct sqlite3;
class Sqlite3QueryResult : public QueryResult { class Sqlite3QueryResult : public QueryResult {
RCPP_OBJECT(Sqlite3QueryResult, QueryResult); GDCLASS(Sqlite3QueryResult, QueryResult);
public: public:
bool next_row(); bool next_row();
const char* get_cell(const int index); String get_cell(const int index);
bool is_cell_null(const int index); bool is_cell_null(const int index);
int get_last_insert_rowid(); int get_last_insert_rowid();
String get_error_message();
void query(const String &query, sqlite3 *conn); void query(const String &query, sqlite3 *conn);
@ -26,9 +25,7 @@ public:
Sqlite3QueryResult(); Sqlite3QueryResult();
~Sqlite3QueryResult(); ~Sqlite3QueryResult();
char* err_msg; protected:
public:
struct Cell { struct Cell {
bool null; bool null;
String data; String data;
@ -39,12 +36,13 @@ public:
}; };
struct Sqlite3QueryResultRow { struct Sqlite3QueryResultRow {
std::vector<Cell> cells; Vector<Cell> cells;
}; };
char **col_names; char **col_names;
std::vector<Sqlite3QueryResultRow *> rows; Vector<Sqlite3QueryResultRow *> rows;
int current_row; int current_row;
char *err_msg;
sqlite3 *_connection; sqlite3 *_connection;
}; };

View File

@ -1,8 +1,8 @@
#include "sqlite3_table_builder.h" #include "sqlite3_table_builder.h"
#include "database/query_result.h" #include "../database/query_result.h"
#include "sqlite3_database.h" #include "sqlite3_connection.h"
TableBuilder *SQLite3TableBuilder::create_table(const String &name) { TableBuilder *SQLite3TableBuilder::create_table(const String &name) {
result += "CREATE TABLE " + name + " ( "; result += "CREATE TABLE " + name + " ( ";
@ -10,61 +10,52 @@ TableBuilder *SQLite3TableBuilder::create_table(const String &name) {
return this; return this;
} }
TableBuilder *SQLite3TableBuilder::integer(const String &name) { TableBuilder *SQLite3TableBuilder::integer(const String &name, const int length) {
result += name + " INTEGER "; result += name + " INTEGER ";
return this; if (length != -1) {
} result += "(";
TableBuilder *SQLite3TableBuilder::integer(const String &name, const int length) { result += itos(length);
result += name + " INTEGER("; result += ") ";
result += String::num(length); }
result += ") ";
return this; return this;
} }
TableBuilder *SQLite3TableBuilder::tiny_integer(const String &name) {
result += name + " INTEGER(4) ";
return this;
}
TableBuilder *SQLite3TableBuilder::tiny_integer(const String &name, const int length) { TableBuilder *SQLite3TableBuilder::tiny_integer(const String &name, const int length) {
result += name + " INTEGER("; result += name + " INTEGER(";
result += String::num(length);
if (length == -1) {
result += "4";
} else {
result += itos(length);
}
result += ") "; result += ") ";
return this; return this;
} }
TableBuilder *SQLite3TableBuilder::small_integer(const String &name) {
result += name + " INTEGER(6) ";
return this;
}
TableBuilder *SQLite3TableBuilder::small_integer(const String &name, const int length) { TableBuilder *SQLite3TableBuilder::small_integer(const String &name, const int length) {
result += name + " INTEGER("; result += name + " INTEGER(";
result += String::num(length);
if (length == -1) {
result += "6";
} else {
result += itos(length);
}
result += ") "; result += ") ";
return this; return this;
} }
TableBuilder *SQLite3TableBuilder::real_float(const String &name) {
result += name + " FLOAT ";
return this;
}
TableBuilder *SQLite3TableBuilder::real_float(const String &name, const int size, const int d) { TableBuilder *SQLite3TableBuilder::real_float(const String &name, const int size, const int d) {
result += name + " FLOAT "; result += name + " FLOAT ";
return this; return this;
} }
TableBuilder *SQLite3TableBuilder::real_double(const String &name) {
result += name + " DOUBLE ";
return this;
}
TableBuilder *SQLite3TableBuilder::real_double(const String &name, const int size, const int d) { TableBuilder *SQLite3TableBuilder::real_double(const String &name, const int size, const int d) {
result += name + " DOUBLE "; result += name + " DOUBLE ";
@ -78,7 +69,13 @@ TableBuilder *SQLite3TableBuilder::date(const String &name) {
} }
TableBuilder *SQLite3TableBuilder::varchar(const String &name, const int length) { TableBuilder *SQLite3TableBuilder::varchar(const String &name, const int length) {
result += name + " VARCHAR(" + std::to_string(length) + ") "; result += name + " VARCHAR ";
if (length != -1) {
result += "(";
result += itos(length);
result += ") ";
}
return this; return this;
} }
@ -177,23 +174,23 @@ TableBuilder *SQLite3TableBuilder::references(const String &table, const String
} }
Ref<QueryResult> SQLite3TableBuilder::run() { Ref<QueryResult> SQLite3TableBuilder::run() {
if (!_db) { if (!_connection.is_valid()) {
printf("SQLite3TableBuilder::run !db!\n"); printf("SQLite3TableBuilder::run !db!\n");
return nullptr; return nullptr;
} }
return _db->query(result); return _connection->query(result);
} }
void SQLite3TableBuilder::run_query() { void SQLite3TableBuilder::run_query() {
if (!_db) { if (!_connection.is_valid()) {
printf("SQLite3TableBuilder::run_query !db!\n"); printf("SQLite3TableBuilder::run_query !db!\n");
return; return;
} }
_db->query_run(result); _connection->query_run(result);
} }
SQLite3TableBuilder::SQLite3TableBuilder() { SQLite3TableBuilder::SQLite3TableBuilder() {

View File

@ -1,63 +1,54 @@
#ifndef SQLITE3_TABLE_BUILDER_H #ifndef SQLITE3_TABLE_BUILDER_H
#define SQLITE3_TABLE_BUILDER_H #define SQLITE3_TABLE_BUILDER_H
#include "core/string.h" #include "core/ustring.h"
#include "database/table_builder.h" #include "../database/table_builder.h"
class SQLite3Database; class SQLite3DatabaseConnection;
class SQLite3TableBuilder : public TableBuilder { class SQLite3TableBuilder : public TableBuilder {
RCPP_OBJECT(SQLite3TableBuilder, TableBuilder); GDCLASS(SQLite3TableBuilder, TableBuilder);
public: public:
TableBuilder *create_table(const String &name); TableBuilder *create_table(const String &name);
TableBuilder *integer(const String &name); TableBuilder *integer(const String &name, const int length = -1);
TableBuilder *integer(const String &name, const int length); TableBuilder *tiny_integer(const String &name, const int length = -1);
TableBuilder *small_integer(const String &name, const int length = -1);
TableBuilder *tiny_integer(const String &name); TableBuilder *real_float(const String &name, const int size = -1, const int d = -1);
TableBuilder *tiny_integer(const String &name, const int length); TableBuilder *real_double(const String &name, const int size = -1, const int d = -1);
TableBuilder *small_integer(const String &name);
TableBuilder *small_integer(const String &name, const int length);
TableBuilder *real_float(const String &name);
TableBuilder *real_float(const String &name, const int size, const int d);
TableBuilder *real_double(const String &name);
TableBuilder *real_double(const String &name, const int size, const int d);
TableBuilder *date(const String &name); TableBuilder *date(const String &name);
TableBuilder *varchar(const String &name, const int length); TableBuilder *varchar(const String &name, const int length = -1);
TableBuilder *text(const String &name); TableBuilder *text(const String &name);
TableBuilder *not_null(); TableBuilder *not_null();
TableBuilder *null(); TableBuilder *null();
TableBuilder *defval(const String &val); TableBuilder *defval(const String &val);
TableBuilder *auto_increment(); TableBuilder *auto_increment();
TableBuilder *primary_key(const String &name); TableBuilder *primary_key(const String &name = "");
TableBuilder *primary_key(); TableBuilder *primary_key();
TableBuilder *next_row(); TableBuilder *next_row();
TableBuilder *ccreate_table(); TableBuilder *ccreate_table();
TableBuilder *drop_table(); TableBuilder *drop_table();
TableBuilder *drop_table_if_exists(); TableBuilder *drop_table_if_exists();
TableBuilder *drop_table(const String &name); TableBuilder *drop_table(const String &name = "");
TableBuilder *drop_table_if_exists(const String &name); TableBuilder *drop_table_if_exists(const String &name);
TableBuilder *cdrop_table(); TableBuilder *cdrop_table();
TableBuilder *foreign_key(const String &name); TableBuilder *foreign_key(const String &name);
TableBuilder *references(const String &table, const String &name); TableBuilder *references(const String &table, const String &name);
virtual Ref<QueryResult> run(); Ref<QueryResult> run();
virtual void run_query(); void run_query();
SQLite3TableBuilder(); SQLite3TableBuilder();
virtual ~SQLite3TableBuilder(); ~SQLite3TableBuilder();
SQLite3Database *_db; Ref<SQLite3DatabaseConnection> _connection;
}; };
#endif #endif