// Code generated by cmd/cgo; DO NOT EDIT. //line /Users/win/go/pkg/mod/github.com/mattn/go-sqlite3@v1.14.15/sqlite3_type.go:1:1 // Copyright (C) 2019 Yasuhiro Matsumoto . // Use of this source code is governed by an MIT-style // license that can be found in the LICENSE file. package sqlite3 /* #ifndef USE_LIBSQLITE3 #include "sqlite3-binding.h" #else #include #endif */ import _ "unsafe" import ( "database/sql" "reflect" "strings" ) // ColumnTypeDatabaseTypeName implement RowsColumnTypeDatabaseTypeName. func (rc *SQLiteRows) ColumnTypeDatabaseTypeName(i int) string { return ( /*line :23:9*/_Cfunc_GoString /*line :23:18*/)(func() *_Ctype_char{ _cgo0 := /*line :23:46*/rc.s.s; var _cgo1 _Ctype_int = _Ctype_int /*line :23:59*/(i); _cgoCheckPointer(_cgo0, nil); return /*line :23:63*/_Cfunc_sqlite3_column_decltype(_cgo0, _cgo1); }()) } /* func (rc *SQLiteRows) ColumnTypeLength(index int) (length int64, ok bool) { return 0, false } func (rc *SQLiteRows) ColumnTypePrecisionScale(index int) (precision, scale int64, ok bool) { return 0, 0, false } */ // ColumnTypeNullable implement RowsColumnTypeNullable. func (rc *SQLiteRows) ColumnTypeNullable(i int) (nullable, ok bool) { return true, true } // ColumnTypeScanType implement RowsColumnTypeScanType. func (rc *SQLiteRows) ColumnTypeScanType(i int) reflect.Type { //ct := C.sqlite3_column_type(rc.s.s, C.int(i)) // Always returns 5 return scanType(( /*line :44:18*/_Cfunc_GoString /*line :44:27*/)(func() *_Ctype_char{ _cgo0 := /*line :44:55*/rc.s.s; var _cgo1 _Ctype_int = _Ctype_int /*line :44:68*/(i); _cgoCheckPointer(_cgo0, nil); return /*line :44:72*/_Cfunc_sqlite3_column_decltype(_cgo0, _cgo1); }())) } const ( SQLITE_INTEGER = iota SQLITE_TEXT SQLITE_BLOB SQLITE_REAL SQLITE_NUMERIC SQLITE_TIME SQLITE_BOOL SQLITE_NULL ) func scanType(cdt string) reflect.Type { t := strings.ToUpper(cdt) i := databaseTypeConvSqlite(t) switch i { case SQLITE_INTEGER: return reflect.TypeOf(sql.NullInt64{}) case SQLITE_TEXT: return reflect.TypeOf(sql.NullString{}) case SQLITE_BLOB: return reflect.TypeOf(sql.RawBytes{}) case SQLITE_REAL: return reflect.TypeOf(sql.NullFloat64{}) case SQLITE_NUMERIC: return reflect.TypeOf(sql.NullFloat64{}) case SQLITE_BOOL: return reflect.TypeOf(sql.NullBool{}) case SQLITE_TIME: return reflect.TypeOf(sql.NullTime{}) } return reflect.TypeOf(new(interface{})) } func databaseTypeConvSqlite(t string) int { if strings.Contains(t, "INT") { return SQLITE_INTEGER } if t == "CLOB" || t == "TEXT" || strings.Contains(t, "CHAR") { return SQLITE_TEXT } if t == "BLOB" { return SQLITE_BLOB } if t == "REAL" || t == "FLOAT" || strings.Contains(t, "DOUBLE") { return SQLITE_REAL } if t == "DATE" || t == "DATETIME" || t == "TIMESTAMP" { return SQLITE_TIME } if t == "NUMERIC" || strings.Contains(t, "DECIMAL") { return SQLITE_NUMERIC } if t == "BOOLEAN" { return SQLITE_BOOL } return SQLITE_NULL }