optimize Parse
This commit is contained in:
parent
b79bf9f463
commit
aa2271c65e
@ -71,6 +71,11 @@ type Tabler interface {
|
||||
TableName() string
|
||||
}
|
||||
|
||||
var callbackActions = []string{
|
||||
"BeforeCreate", "AfterCreate", "BeforeUpdate", "AfterUpdate",
|
||||
"BeforeSave", "AfterSave", "BeforeDelete", "AfterDelete", "AfterFind",
|
||||
}
|
||||
|
||||
// Parse get data type from dialector
|
||||
func Parse(dest interface{}, cacheStore *sync.Map, namer Namer) (*Schema, error) {
|
||||
if dest == nil {
|
||||
@ -221,14 +226,13 @@ func Parse(dest interface{}, cacheStore *sync.Map, namer Namer) (*Schema, error)
|
||||
}
|
||||
}
|
||||
|
||||
callbacks := []string{"BeforeCreate", "AfterCreate", "BeforeUpdate", "AfterUpdate", "BeforeSave", "AfterSave", "BeforeDelete", "AfterDelete", "AfterFind"}
|
||||
for _, name := range callbacks {
|
||||
for _, name := range callbackActions {
|
||||
if methodValue := modelValue.MethodByName(name); methodValue.IsValid() {
|
||||
switch methodValue.Type().String() {
|
||||
case "func(*gorm.DB) error": // TODO hack
|
||||
reflect.Indirect(reflect.ValueOf(schema)).FieldByName(name).SetBool(true)
|
||||
default:
|
||||
logger.Default.Warn(context.Background(), "Model %v don't match %vInterface, should be %v(*gorm.DB)", schema, name, name)
|
||||
logger.Default.Warn(context.Background(), "Model %v don't match %sInterface, should be %s(*gorm.DB)", schema, name, name)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user