diff options
author | Jessica Frazelle <acidburn@docker.com> | 2015-09-04 11:16:27 -0700 |
---|---|---|
committer | Jessica Frazelle <acidburn@docker.com> | 2015-09-04 14:46:16 -0700 |
commit | e37121d4ea9b7f071a2ae681dd64b4fdfcda0987 (patch) | |
tree | d47cdd208b7f9f7c76c5a8b49f58f0d21edd4b8d /sqlite3.go | |
parent | Merge pull request #231 from marccampbell/master (diff) | |
download | golite-e37121d4ea9b7f071a2ae681dd64b4fdfcda0987.tar.gz golite-e37121d4ea9b7f071a2ae681dd64b4fdfcda0987.tar.xz |
introduce ability to pass sqlite_omit_load_extension
sqlite_omit_load_extension is a go build tag which behaves much like its
C counterpart SQLITE_OMIT_LOAD_EXTENSION
Signed-off-by: Jessica Frazelle <acidburn@docker.com>
Diffstat (limited to 'sqlite3.go')
-rw-r--r-- | sqlite3.go | 19 |
1 files changed, 2 insertions, 17 deletions
@@ -355,23 +355,8 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) { conn := &SQLiteConn{db: db, loc: loc, txlock: txlock} if len(d.Extensions) > 0 { - rv = C.sqlite3_enable_load_extension(db, 1) - if rv != C.SQLITE_OK { - return nil, errors.New(C.GoString(C.sqlite3_errmsg(db))) - } - - for _, extension := range d.Extensions { - 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))) - } - } - - rv = C.sqlite3_enable_load_extension(db, 0) - if rv != C.SQLITE_OK { - return nil, errors.New(C.GoString(C.sqlite3_errmsg(db))) + if err := conn.loadExtensions(d.Extensions); err != nil { + return nil, err } } |