|
|
@@ -12,7 +12,7 @@ import (
|
|
|
|
|
|
type Migrator struct {
|
|
|
x *xorm.Engine
|
|
|
- dialect Dialect
|
|
|
+ Dialect Dialect
|
|
|
migrations []Migration
|
|
|
Logger log.Logger
|
|
|
}
|
|
|
@@ -31,7 +31,7 @@ func NewMigrator(engine *xorm.Engine) *Migrator {
|
|
|
mg.x = engine
|
|
|
mg.Logger = log.New("migrator")
|
|
|
mg.migrations = make([]Migration, 0)
|
|
|
- mg.dialect = NewDialect(mg.x)
|
|
|
+ mg.Dialect = NewDialect(mg.x)
|
|
|
return mg
|
|
|
}
|
|
|
|
|
|
@@ -86,7 +86,7 @@ func (mg *Migrator) Start() error {
|
|
|
continue
|
|
|
}
|
|
|
|
|
|
- sql := m.Sql(mg.dialect)
|
|
|
+ sql := m.Sql(mg.Dialect)
|
|
|
|
|
|
record := MigrationLog{
|
|
|
MigrationId: m.Id(),
|
|
|
@@ -122,7 +122,7 @@ func (mg *Migrator) exec(m Migration, sess *xorm.Session) error {
|
|
|
|
|
|
condition := m.GetCondition()
|
|
|
if condition != nil {
|
|
|
- sql, args := condition.Sql(mg.dialect)
|
|
|
+ sql, args := condition.Sql(mg.Dialect)
|
|
|
results, err := sess.SQL(sql).Query(args...)
|
|
|
if err != nil || len(results) == 0 {
|
|
|
mg.Logger.Debug("Skipping migration condition not fulfilled", "id", m.Id())
|
|
|
@@ -130,7 +130,13 @@ func (mg *Migrator) exec(m Migration, sess *xorm.Session) error {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- _, err := sess.Exec(m.Sql(mg.dialect))
|
|
|
+ var err error
|
|
|
+ if codeMigration, ok := m.(CodeMigration); ok {
|
|
|
+ err = codeMigration.Exec(sess, mg)
|
|
|
+ } else {
|
|
|
+ _, err = sess.Exec(m.Sql(mg.Dialect))
|
|
|
+ }
|
|
|
+
|
|
|
if err != nil {
|
|
|
mg.Logger.Error("Executing migration failed", "id", m.Id(), "error", err)
|
|
|
return err
|