a geicko-2 based round robin ranking system designed to test c++ battleship submissions
battleship.dunkirk.sh
1/*
2Package sqlite3 provides interface to SQLite3 databases.
3
4This works as a driver for database/sql.
5
6Installation
7
8 go get github.com/mattn/go-sqlite3
9
10# Supported Types
11
12Currently, go-sqlite3 supports the following data types.
13
14 +------------------------------+
15 |go | sqlite3 |
16 |----------|-------------------|
17 |nil | null |
18 |int | integer |
19 |int64 | integer |
20 |float64 | float |
21 |bool | integer |
22 |[]byte | blob |
23 |string | text |
24 |time.Time | timestamp/datetime|
25 +------------------------------+
26
27# SQLite3 Extension
28
29You can write your own extension module for sqlite3. For example, below is an
30extension for a Regexp matcher operation.
31
32 #include <pcre.h>
33 #include <string.h>
34 #include <stdio.h>
35 #include <sqlite3ext.h>
36
37 SQLITE_EXTENSION_INIT1
38 static void regexp_func(sqlite3_context *context, int argc, sqlite3_value **argv) {
39 if (argc >= 2) {
40 const char *target = (const char *)sqlite3_value_text(argv[1]);
41 const char *pattern = (const char *)sqlite3_value_text(argv[0]);
42 const char* errstr = NULL;
43 int erroff = 0;
44 int vec[500];
45 int n, rc;
46 pcre* re = pcre_compile(pattern, 0, &errstr, &erroff, NULL);
47 rc = pcre_exec(re, NULL, target, strlen(target), 0, 0, vec, 500);
48 if (rc <= 0) {
49 sqlite3_result_error(context, errstr, 0);
50 return;
51 }
52 sqlite3_result_int(context, 1);
53 }
54 }
55
56 #ifdef _WIN32
57 __declspec(dllexport)
58 #endif
59 int sqlite3_extension_init(sqlite3 *db, char **errmsg,
60 const sqlite3_api_routines *api) {
61 SQLITE_EXTENSION_INIT2(api);
62 return sqlite3_create_function(db, "regexp", 2, SQLITE_UTF8,
63 (void*)db, regexp_func, NULL, NULL);
64 }
65
66It needs to be built as a so/dll shared library. And you need to register
67the extension module like below.
68
69 sql.Register("sqlite3_with_extensions",
70 &sqlite3.SQLiteDriver{
71 Extensions: []string{
72 "sqlite3_mod_regexp",
73 },
74 })
75
76Then, you can use this extension.
77
78 rows, err := db.Query("select text from mytable where name regexp '^golang'")
79
80# Connection Hook
81
82You can hook and inject your code when the connection is established by setting
83ConnectHook to get the SQLiteConn.
84
85 sql.Register("sqlite3_with_hook_example",
86 &sqlite3.SQLiteDriver{
87 ConnectHook: func(conn *sqlite3.SQLiteConn) error {
88 sqlite3conn = append(sqlite3conn, conn)
89 return nil
90 },
91 })
92
93You can also use database/sql.Conn.Raw (Go >= 1.13):
94
95 conn, err := db.Conn(context.Background())
96 // if err != nil { ... }
97 defer conn.Close()
98 err = conn.Raw(func (driverConn any) error {
99 sqliteConn := driverConn.(*sqlite3.SQLiteConn)
100 // ... use sqliteConn
101 })
102 // if err != nil { ... }
103
104# Go SQlite3 Extensions
105
106If you want to register Go functions as SQLite extension functions
107you can make a custom driver by calling RegisterFunction from
108ConnectHook.
109
110 regex = func(re, s string) (bool, error) {
111 return regexp.MatchString(re, s)
112 }
113 sql.Register("sqlite3_extended",
114 &sqlite3.SQLiteDriver{
115 ConnectHook: func(conn *sqlite3.SQLiteConn) error {
116 return conn.RegisterFunc("regexp", regex, true)
117 },
118 })
119
120You can then use the custom driver by passing its name to sql.Open.
121
122 var i int
123 conn, err := sql.Open("sqlite3_extended", "./foo.db")
124 if err != nil {
125 panic(err)
126 }
127 err = db.QueryRow(`SELECT regexp("foo.*", "seafood")`).Scan(&i)
128 if err != nil {
129 panic(err)
130 }
131
132See the documentation of RegisterFunc for more details.
133*/
134package sqlite3