Commit 6c1f9b97 authored by gwenn's avatar gwenn

Fix ScanText and ScanBlob which don't actually return any error.

parent 909044b4
...@@ -832,7 +832,7 @@ func (s *Stmt) ScanByIndex(index int, value interface{}) (bool, error) { ...@@ -832,7 +832,7 @@ func (s *Stmt) ScanByIndex(index int, value interface{}) (bool, error) {
switch value := value.(type) { switch value := value.(type) {
case nil: case nil:
case *string: case *string:
*value, isNull, err = s.ScanText(index) *value, isNull = s.ScanText(index)
case *int: case *int:
*value, isNull, err = s.ScanInt(index) *value, isNull, err = s.ScanInt(index)
case *int64: case *int64:
...@@ -844,7 +844,7 @@ func (s *Stmt) ScanByIndex(index int, value interface{}) (bool, error) { ...@@ -844,7 +844,7 @@ func (s *Stmt) ScanByIndex(index int, value interface{}) (bool, error) {
case *float64: case *float64:
*value, isNull, err = s.ScanFloat64(index) *value, isNull, err = s.ScanFloat64(index)
case *[]byte: case *[]byte:
*value, isNull, err = s.ScanBlob(index) *value, isNull = s.ScanBlob(index)
case *interface{}: case *interface{}:
*value = s.ScanValue(index) *value = s.ScanValue(index)
isNull = *value == nil isNull = *value == nil
...@@ -891,7 +891,7 @@ func (s *Stmt) ScanValue(index int) (value interface{}) { ...@@ -891,7 +891,7 @@ func (s *Stmt) ScanValue(index int) (value interface{}) {
// Returns true when column is null. // Returns true when column is null.
// Calls sqlite3_column_text. // Calls sqlite3_column_text.
// http://sqlite.org/c3ref/column_blob.html // http://sqlite.org/c3ref/column_blob.html
func (s *Stmt) ScanText(index int) (value string, isNull bool, err error) { func (s *Stmt) ScanText(index int) (value string, isNull bool) {
p := C.sqlite3_column_text(s.stmt, C.int(index)) p := C.sqlite3_column_text(s.stmt, C.int(index))
if p == nil { if p == nil {
isNull = true isNull = true
...@@ -1006,7 +1006,7 @@ func (s *Stmt) ScanFloat64(index int) (value float64, isNull bool, err error) { ...@@ -1006,7 +1006,7 @@ func (s *Stmt) ScanFloat64(index int) (value float64, isNull bool, err error) {
// Returns true when column is null. // Returns true when column is null.
// Calls sqlite3_column_bytes. // Calls sqlite3_column_bytes.
// http://sqlite.org/c3ref/column_blob.html // http://sqlite.org/c3ref/column_blob.html
func (s *Stmt) ScanBlob(index int) (value []byte, isNull bool, err error) { func (s *Stmt) ScanBlob(index int) (value []byte, isNull bool) {
p := C.sqlite3_column_blob(s.stmt, C.int(index)) p := C.sqlite3_column_blob(s.stmt, C.int(index))
if p == nil { if p == nil {
isNull = true isNull = true
...@@ -1140,10 +1140,9 @@ func (c *Conn) IntegrityCheck(max int, quick bool) error { ...@@ -1140,10 +1140,9 @@ func (c *Conn) IntegrityCheck(max int, quick bool) error {
if !ok { if !ok {
return errors.New("Integrity check failed (no result)") return errors.New("Integrity check failed (no result)")
} }
var msg string msg, null := s.ScanText(0)
err = s.Scan(&msg) if null {
if err != nil { return errors.New("Integrity check failed (null result)")
return err
} }
if msg != "ok" { if msg != "ok" {
return errors.New(msg) return errors.New(msg)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment