aboutsummaryrefslogtreecommitdiff
path: root/sqlite3_load_extension.go
diff options
context:
space:
mode:
authorZbigniew Mandziejewicz <shaxbee@gmail.com>2016-04-18 17:05:24 +0800
committerZbigniew Mandziejewicz <shaxbee@gmail.com>2016-04-18 17:05:50 +0800
commitda9decb965f9e3c0cf528b5c6bc0896d27896d44 (patch)
tree2ab111107631ee2c6ce96f1dd92fdbac663a99dd /sqlite3_load_extension.go
parentdelete needless files (diff)
downloadgolite-da9decb965f9e3c0cf528b5c6bc0896d27896d44.tar.gz
golite-da9decb965f9e3c0cf528b5c6bc0896d27896d44.tar.xz
Expose LoadExtension with entry point
Diffstat (limited to 'sqlite3_load_extension.go')
-rw-r--r--sqlite3_load_extension.go24
1 files changed, 24 insertions, 0 deletions
diff --git a/sqlite3_load_extension.go b/sqlite3_load_extension.go
index 0251016..55c8ad7 100644
--- a/sqlite3_load_extension.go
+++ b/sqlite3_load_extension.go
@@ -37,3 +37,27 @@ func (c *SQLiteConn) loadExtensions(extensions []string) error {
}
return nil
}
+
+func (c *SQLiteConn) LoadExtension(lib string, entry string) error {
+ rv := C.sqlite3_enable_load_extension(c.db, 1)
+ if rv != C.SQLITE_OK {
+ return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
+ }
+
+ clib := C.CString(lib)
+ defer C.free(unsafe.Pointer(clib))
+ centry := C.CString(entry)
+ defer C.free(unsafe.Pointer(centry))
+
+ rv = C.sqlite3_load_extension(c.db, clib, centry, nil)
+ if rv != C.SQLITE_OK {
+ return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
+ }
+
+ rv = C.sqlite3_enable_load_extension(c.db, 0)
+ if rv != C.SQLITE_OK {
+ return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
+ }
+
+ return nil
+}