aboutsummaryrefslogtreecommitdiff
path: root/include/mysql.h
diff options
context:
space:
mode:
authorRichard Knight <q@1bpm.net>2020-03-17 18:47:36 +0000
committerRichard Knight <q@1bpm.net>2020-03-17 18:47:36 +0000
commitc3853f6dd796615f332fefcaaaf563794d867ee4 (patch)
treebe3aa506a3631e9261a68894a9fad26ccd911f80 /include/mysql.h
downloadcsound-sqldb-c3853f6dd796615f332fefcaaaf563794d867ee4.tar.gz
csound-sqldb-c3853f6dd796615f332fefcaaaf563794d867ee4.tar.bz2
csound-sqldb-c3853f6dd796615f332fefcaaaf563794d867ee4.zip
initial
Diffstat (limited to 'include/mysql.h')
-rw-r--r--include/mysql.h48
1 files changed, 48 insertions, 0 deletions
diff --git a/include/mysql.h b/include/mysql.h
new file mode 100644
index 0000000..1abc6e3
--- /dev/null
+++ b/include/mysql.h
@@ -0,0 +1,48 @@
+/*
+ mysql.h
+ Copyright (C) 2019 Richard Knight
+
+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 3 of the License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public License
+ along with this program; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
+ */
+
+#ifndef MYSQL_H
+#define MYSQL_H
+
+#include <plugin.h>
+#include <cppconn/driver.h>
+#include <cppconn/resultset.h>
+#include "connection.h"
+
+namespace mysql = sql;
+
+struct MySQLConnection {
+ mysql::Driver* driver;
+ mysql::Connection* conn;
+ void Init(csnd::Csound* csound, LoginData* login);
+ void Close(csnd::Csound* csound);
+ void Exec(char* sql);
+ mysql::ResultSet* Query(char *sql);
+ MYFLT Scalar(char* sql, int row, int col);
+ char* ScalarString(char* sql, int row, int col);
+ void ToArray(mysql::ResultSet* result, csnd::Csound* csound, ARRAYDAT* array, bool asString);
+ void ArrayQuery(char* sql, csnd::Csound* csound, ARRAYDAT* array);
+ void ArrayQueryString(char* sql, csnd::Csound* csound, ARRAYDAT* array);
+};
+
+
+#endif /* MYSQL_H */
+