2013-05-03 07:26:51 +00:00
|
|
|
package xorm
|
|
|
|
|
|
|
|
import (
|
2013-06-16 03:05:16 +00:00
|
|
|
//"database/sql"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
2013-05-08 14:50:19 +00:00
|
|
|
"reflect"
|
2013-06-16 03:05:16 +00:00
|
|
|
"sync"
|
|
|
|
//"time"
|
2013-05-03 07:26:51 +00:00
|
|
|
)
|
|
|
|
|
2013-06-16 03:05:16 +00:00
|
|
|
func NewEngine(driverName string, dataSourceName string) (*Engine, error) {
|
2013-06-12 13:51:39 +00:00
|
|
|
engine := &Engine{ShowSQL: false, DriverName: driverName, Mapper: SnakeMapper{},
|
2013-05-09 01:56:58 +00:00
|
|
|
DataSourceName: dataSourceName}
|
|
|
|
|
2013-06-16 03:05:16 +00:00
|
|
|
engine.Tables = make(map[reflect.Type]*Table)
|
|
|
|
engine.mutex = &sync.Mutex{}
|
2013-05-12 13:37:10 +00:00
|
|
|
engine.InsertMany = true
|
2013-05-19 05:25:52 +00:00
|
|
|
engine.TagIdentifier = "xorm"
|
2013-06-16 03:05:16 +00:00
|
|
|
engine.QuoteIdentifier = "`"
|
2013-05-09 01:56:58 +00:00
|
|
|
if driverName == SQLITE {
|
2013-06-04 08:56:59 +00:00
|
|
|
engine.Dialect = sqlite3{}
|
2013-05-09 01:56:58 +00:00
|
|
|
engine.AutoIncrement = "AUTOINCREMENT"
|
2013-06-16 03:05:16 +00:00
|
|
|
//engine.Pool = NoneConnectPool{}
|
|
|
|
} else if driverName == MYSQL {
|
2013-06-04 08:56:59 +00:00
|
|
|
engine.Dialect = mysql{}
|
2013-05-09 01:56:58 +00:00
|
|
|
engine.AutoIncrement = "AUTO_INCREMENT"
|
2013-06-16 03:05:16 +00:00
|
|
|
} else {
|
|
|
|
return nil, errors.New(fmt.Sprintf("Unsupported driver name: %v", driverName))
|
2013-05-03 07:26:51 +00:00
|
|
|
}
|
|
|
|
|
2013-06-21 04:33:54 +00:00
|
|
|
/*engine.Pool = &SimpleConnectPool{
|
2013-06-16 03:05:16 +00:00
|
|
|
releasedSessions: make([]*sql.DB, 30),
|
|
|
|
usingSessions: map[*sql.DB]time.Time{},
|
|
|
|
cur: -1,
|
|
|
|
maxWaitTimeOut: 14400,
|
|
|
|
mutex: &sync.Mutex{},
|
|
|
|
}*/
|
2013-06-21 04:33:54 +00:00
|
|
|
engine.Pool = &NoneConnectPool{}
|
2013-06-04 08:56:59 +00:00
|
|
|
|
2013-06-16 03:05:16 +00:00
|
|
|
return engine, nil
|
2013-05-03 07:26:51 +00:00
|
|
|
}
|