optimize Parse

This commit is contained in:
daheige 2021-06-14 22:26:23 +08:00
parent b79bf9f463
commit aa2271c65e

View File

@ -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)
}
}
}