Merge branch 'dev' of github.com:go-xorm/xorm into dev

This commit is contained in:
Lunny Xiao 2014-04-17 10:13:45 +08:00
commit e53ab0f412
1 changed files with 34 additions and 22 deletions

18
xorm.go
View File

@ -4,21 +4,25 @@ import (
"database/sql" "database/sql"
"errors" "errors"
"fmt" "fmt"
"github.com/go-xorm/core"
"os" "os"
"reflect" "reflect"
"runtime" "runtime"
"sync" "sync"
"time" "time"
"github.com/go-xorm/core"
) )
const ( const (
Version string = "0.4" Version string = "0.4"
) )
func init() { // !nashtsai! implicit register drivers and dialects is no good, as init() can be called before sql driver got registered
// func init() {
// regDrvsNDialects()
// }
func regDrvsNDialects() bool {
if core.RegisteredDriverSize() == 0 {
providedDrvsNDialects := map[string]struct { providedDrvsNDialects := map[string]struct {
dbType core.DbType dbType core.DbType
getDriver func() core.Driver getDriver func() core.Driver
@ -36,10 +40,17 @@ func init() {
for driverName, v := range providedDrvsNDialects { for driverName, v := range providedDrvsNDialects {
_, err := sql.Open(driverName, "") _, err := sql.Open(driverName, "")
if err == nil { if err == nil {
// fmt.Printf("driver succeed: %v\n", driverName)
core.RegisterDriver(driverName, v.getDriver()) core.RegisterDriver(driverName, v.getDriver())
core.RegisterDialect(v.dbType, v.getDialect()) core.RegisterDialect(v.dbType, v.getDialect())
} else {
// fmt.Printf("driver failed: %v | err: %v\n", driverName, err)
} }
} }
return true
} else {
return false
}
} }
func close(engine *Engine) { func close(engine *Engine) {
@ -49,6 +60,7 @@ func close(engine *Engine) {
// new a db manager according to the parameter. Currently support four // new a db manager according to the parameter. Currently support four
// drivers // drivers
func NewEngine(driverName string, dataSourceName string) (*Engine, error) { func NewEngine(driverName string, dataSourceName string) (*Engine, error) {
regDrvsNDialects()
driver := core.QueryDriver(driverName) driver := core.QueryDriver(driverName)
if driver == nil { if driver == nil {
return nil, errors.New(fmt.Sprintf("Unsupported driver name: %v", driverName)) return nil, errors.New(fmt.Sprintf("Unsupported driver name: %v", driverName))