diff options
author | Richard Knight <q@1bpm.net> | 2020-03-17 18:47:36 +0000 |
---|---|---|
committer | Richard Knight <q@1bpm.net> | 2020-03-17 18:47:36 +0000 |
commit | c3853f6dd796615f332fefcaaaf563794d867ee4 (patch) | |
tree | be3aa506a3631e9261a68894a9fad26ccd911f80 /include/connection.h | |
download | csound-sqldb-c3853f6dd796615f332fefcaaaf563794d867ee4.tar.gz csound-sqldb-c3853f6dd796615f332fefcaaaf563794d867ee4.tar.bz2 csound-sqldb-c3853f6dd796615f332fefcaaaf563794d867ee4.zip |
initial
Diffstat (limited to 'include/connection.h')
-rw-r--r-- | include/connection.h | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/include/connection.h b/include/connection.h new file mode 100644 index 0000000..e67ea27 --- /dev/null +++ b/include/connection.h @@ -0,0 +1,90 @@ +/* + connection.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 CONNECTION_H +#define CONNECTION_H +#include <plugin.h> +#include "logindata.h" + +#define EXEC 0 +#define SCALAR 1 +#define SCALARSTRING 2 +#define ARRAY 3 +#define ARRAYSTRING 4 + +#define POSTGRES 0 +#define SQLITE 1 +#define MYSQL 2 + +#ifdef BUILD_SQLITE +#include "sqlite.h" +#endif + +#ifdef BUILD_POSTGRES +#include "postgresql.h" +#endif + +#ifdef BUILD_MYSQL +#include "mysql.h" +#endif + + +// tried to do this with templates and inheritance, failed with various approaches + + + +struct ConnectionData { + void* mutex; +#ifdef BUILD_SQLITE + SqliteConnection* sqlite; +#endif +#ifdef BUILD_POSTGRES + PostgresConnection* postgres; +#endif +#ifdef BUILD_MYSQL + MySQLConnection* mysql; +#endif + int type; + bool open; + void Init(csnd::Csound* csound, LoginData* login); + void Close(csnd::Csound* csound); + void Exec(char* sql); + MYFLT Scalar(char* sql, int row, int col); + char* ScalarString(char* sql, int row=0, int col=0); + void ArrayQuery(char* sql, csnd::Csound* csound, ARRAYDAT* array); + void ArrayQueryString(char* sql, csnd::Csound* csound, ARRAYDAT* array); +}; + +struct QueryData { + ConnectionData* connection; + char* sql; + int queryType; + int row; + int col; + ARRAYDAT* array; +}; + + + +ConnectionData* getConnection(csnd::Csound* csound, MYFLT handle); + +#endif /* CONNECTION_H */ + |