2019-10-27 23:32:15 +03:00
|
|
|
module sqlite
|
|
|
|
|
|
|
|
#flag -lsqlite3
|
2019-10-29 17:13:56 +03:00
|
|
|
#flag freebsd -I/usr/local/include
|
|
|
|
#flag freebsd -Wl,-L/usr/local/lib,-lsqlite3
|
2019-10-27 23:32:15 +03:00
|
|
|
#include "sqlite3.h"
|
|
|
|
|
|
|
|
struct C.sqlite3
|
|
|
|
struct C.sqlite3_stmt
|
|
|
|
|
|
|
|
struct DB {
|
|
|
|
mut:
|
|
|
|
conn &C.sqlite3
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Row {
|
|
|
|
pub mut:
|
|
|
|
vals []string
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn connect(path string) DB {
|
2019-12-04 13:08:28 +03:00
|
|
|
db := &C.sqlite3(0)
|
2019-10-27 23:32:15 +03:00
|
|
|
C.sqlite3_open(path.str, &db)
|
|
|
|
return DB {conn: db}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn (db DB) q_int(query string) int {
|
2019-12-04 13:08:28 +03:00
|
|
|
stmt := &C.sqlite3_stmt(0)
|
2019-10-27 23:32:15 +03:00
|
|
|
C.sqlite3_prepare_v2(db.conn, query.str, - 1, &stmt, 0)
|
|
|
|
C.sqlite3_step(stmt)
|
|
|
|
res := C.sqlite3_column_int(stmt, 0)
|
|
|
|
C.sqlite3_finalize(stmt)
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
|
|
|
fn C.sqlite3_column_text(voidptr, int) byteptr
|
2019-11-24 06:27:02 +03:00
|
|
|
fn C.sqlite3_column_int(voidptr, int) int
|
|
|
|
fn C.sqlite3_open()
|
|
|
|
fn C.sqlite3_step() int
|
|
|
|
fn C.sqlite3_prepare_v2()
|
|
|
|
fn C.sqlite3_finalize()
|
2019-10-27 23:32:15 +03:00
|
|
|
|
|
|
|
pub fn (db DB) q_string(query string) string {
|
2019-12-04 13:08:28 +03:00
|
|
|
stmt := &C.sqlite3_stmt(0)
|
2019-10-27 23:32:15 +03:00
|
|
|
C.sqlite3_prepare_v2(db.conn, query.str, - 1, &stmt, 0)
|
|
|
|
C.sqlite3_step(stmt)
|
|
|
|
f := C.sqlite3_column_text(stmt, 0)
|
|
|
|
res := tos_clone(C.sqlite3_column_text(stmt, 0))
|
|
|
|
C.sqlite3_finalize(stmt)
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
|
|
|
fn C.sqlite3_column_count(voidptr) int
|
|
|
|
|
|
|
|
pub fn (db DB) exec(query string) []Row {
|
2019-12-04 13:08:28 +03:00
|
|
|
stmt := &C.sqlite3_stmt(0)
|
2019-10-27 23:32:15 +03:00
|
|
|
C.sqlite3_prepare_v2(db.conn, query.str, - 1, &stmt, 0)
|
|
|
|
nr_cols := C.sqlite3_column_count(stmt)
|
|
|
|
//println('nr cols $nr_cols')
|
|
|
|
mut rows := []Row
|
|
|
|
for {
|
|
|
|
ret := C.sqlite3_step(stmt)
|
|
|
|
if ret != 0x64 {
|
|
|
|
break
|
2019-12-04 13:08:28 +03:00
|
|
|
}
|
2019-10-27 23:32:15 +03:00
|
|
|
mut row := Row{}
|
|
|
|
for i in 0..nr_cols {
|
|
|
|
val := tos_clone(C.sqlite3_column_text(stmt, i))
|
|
|
|
row.vals << val
|
2019-10-28 00:10:39 +03:00
|
|
|
//println(val)
|
2019-10-27 23:32:15 +03:00
|
|
|
}
|
|
|
|
rows << row
|
|
|
|
}
|
|
|
|
return rows
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn (db DB) exec_one(query string) ?Row {
|
|
|
|
rows := db.exec(query)
|
|
|
|
return rows[0]
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
pub fn (db DB) exec_param(query string, param string) []Row {
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
|