Files

57 lines
1.7 KiB
Go

package masterdata
import (
"fmt"
"lunar-tear/server/internal/model"
"lunar-tear/server/internal/utils"
)
const defaultGroupIndex = 1
type ConditionResolver struct {
requiredQuestByCondId map[int32]int32
}
func LoadConditionResolver() (*ConditionResolver, error) {
conditions, err := utils.ReadTable[EntityMEvaluateCondition]("m_evaluate_condition")
if err != nil {
return nil, fmt.Errorf("load evaluate condition table: %w", err)
}
valueGroups, err := utils.ReadTable[EntityMEvaluateConditionValueGroup]("m_evaluate_condition_value_group")
if err != nil {
return nil, fmt.Errorf("load evaluate condition value group table: %w", err)
}
condById := make(map[int32]EntityMEvaluateCondition, len(conditions))
for _, c := range conditions {
condById[c.EvaluateConditionId] = c
}
type vgKey struct {
GroupId int32
GroupIndex int32
}
vgByKey := make(map[vgKey]int64, len(valueGroups))
for _, vg := range valueGroups {
vgByKey[vgKey{vg.EvaluateConditionValueGroupId, vg.GroupIndex}] = vg.Value
}
resolved := make(map[int32]int32)
for _, c := range conditions {
if model.EvaluateConditionFunctionType(c.EvaluateConditionFunctionType) == model.EvaluateConditionFunctionTypeQuestClear &&
model.EvaluateConditionEvaluateType(c.EvaluateConditionEvaluateType) == model.EvaluateConditionEvaluateTypeIdContain {
if questId, ok := vgByKey[vgKey{c.EvaluateConditionValueGroupId, defaultGroupIndex}]; ok {
resolved[c.EvaluateConditionId] = int32(questId)
}
}
}
return &ConditionResolver{requiredQuestByCondId: resolved}, nil
}
func (r *ConditionResolver) RequiredQuestId(conditionId int32) (int32, bool) {
qid, ok := r.requiredQuestByCondId[conditionId]
return qid, ok
}