diff options
author | Attila Tajti <attila.tajti@gmail.com> | 2015-01-26 16:50:50 +0100 |
---|---|---|
committer | Attila Tajti <attila.tajti@gmail.com> | 2015-01-26 16:50:50 +0100 |
commit | 0486deea0daf3e1ba737b158c6f7ee7f2a74b7cb (patch) | |
tree | 9938264bb612eab06ef7647d475322ec5ee35239 | |
parent | Fix test (diff) | |
download | golite-0486deea0daf3e1ba737b158c6f7ee7f2a74b7cb.tar.gz golite-0486deea0daf3e1ba737b158c6f7ee7f2a74b7cb.tar.xz |
load extensions using the C API instead of SQL
This fixes the problem of loading ICU, which needs to replace existing
functions. Replacing existing functions are prohibited when a VM
is running.
-rw-r--r-- | sqlite3.go | 16 |
1 files changed, 5 insertions, 11 deletions
@@ -287,21 +287,15 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) { return nil, errors.New(C.GoString(C.sqlite3_errmsg(db))) } - stmt, err := conn.Prepare("SELECT load_extension(?);") - if err != nil { - return nil, err - } - for _, extension := range d.Extensions { - if _, err = stmt.Exec([]driver.Value{extension}); err != nil { - return nil, err + cext := C.CString(extension) + defer C.free(unsafe.Pointer(cext)) + rv = C.sqlite3_load_extension(db, cext, nil, nil) + if rv != C.SQLITE_OK { + return nil, errors.New(C.GoString(C.sqlite3_errmsg(db))) } } - if err = stmt.Close(); err != nil { - return nil, err - } - rv = C.sqlite3_enable_load_extension(db, 0) if rv != C.SQLITE_OK { return nil, errors.New(C.GoString(C.sqlite3_errmsg(db))) |