aboutsummaryrefslogtreecommitdiff
path: root/sqlite3.go
diff options
context:
space:
mode:
authormattn <mattn.jp@gmail.com>2014-11-14 17:13:35 +0900
committermattn <mattn.jp@gmail.com>2014-11-14 17:13:35 +0900
commite63d2546a03e8591c61871c4e494587cc28bdd79 (patch)
treea21f64fc83ff95dcb5f7cb84addbbd3e03ceeb10 /sqlite3.go
parentMerge pull request #159 from michael-k/go-cover (diff)
downloadgolite-e63d2546a03e8591c61871c4e494587cc28bdd79.tar.gz
golite-e63d2546a03e8591c61871c4e494587cc28bdd79.tar.xz
set/reset finalizer to free SQLite3 handles
Diffstat (limited to 'sqlite3.go')
-rw-r--r--sqlite3.go9
1 files changed, 7 insertions, 2 deletions
diff --git a/sqlite3.go b/sqlite3.go
index abfc2fe..de1cc16 100644
--- a/sqlite3.go
+++ b/sqlite3.go
@@ -61,6 +61,7 @@ import (
"database/sql/driver"
"errors"
"io"
+ "runtime"
"strings"
"time"
"unsafe"
@@ -306,7 +307,7 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) {
return nil, err
}
}
-
+ runtime.SetFinalizer(conn, (*SQLiteConn).Close)
return conn, nil
}
@@ -317,6 +318,7 @@ func (c *SQLiteConn) Close() error {
return c.lastError()
}
c.db = nil
+ runtime.SetFinalizer(c, nil)
return nil
}
@@ -334,7 +336,9 @@ func (c *SQLiteConn) Prepare(query string) (driver.Stmt, error) {
if tail != nil && C.strlen(tail) > 0 {
t = strings.TrimSpace(C.GoString(tail))
}
- return &SQLiteStmt{c: c, s: s, t: t}, nil
+ ss := &SQLiteStmt{c: c, s: s, t: t}
+ runtime.SetFinalizer(ss, (*SQLiteStmt).Close)
+ return ss, nil
}
// Close the statement.
@@ -350,6 +354,7 @@ func (s *SQLiteStmt) Close() error {
if rv != C.SQLITE_OK {
return s.c.lastError()
}
+ runtime.SetFinalizer(s, nil)
return nil
}