worldtask npc配置校验
This commit is contained in:
parent
81c17bf1ec
commit
23f1bee9fc
File diff suppressed because it is too large
Load Diff
@ -4878,5 +4878,425 @@
|
|||||||
10030
|
10030
|
||||||
],
|
],
|
||||||
"goto": 0
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11100,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔4",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10031
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11104,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔5",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10032
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11108,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔6",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10033
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11110,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔7",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10034
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11114,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔8",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10035
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11118,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔9",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10036
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11120,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔10",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10037
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11124,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔11",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10038
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11128,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔12",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10039
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11130,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔13",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10040
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11134,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔14",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10041
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11138,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔15",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10042
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11140,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔16",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10043
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11144,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔17",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10044
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11148,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔18",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10045
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11150,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔19",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10046
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11154,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔20",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10047
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11158,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔21",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10048
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11160,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔22",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10049
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11164,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔23",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10050
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11168,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔24",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10051
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11170,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔25",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10052
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11174,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔26",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10053
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11178,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔27",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10054
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11180,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔28",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10055
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11184,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔29",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10056
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11188,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔30",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10057
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11190,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔31",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10058
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11194,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔32",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10059
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 11198,
|
||||||
|
"heroid": 25001,
|
||||||
|
"datas": [
|
||||||
|
"GameMain",
|
||||||
|
"20030_邦尼兔33",
|
||||||
|
"901"
|
||||||
|
],
|
||||||
|
"event": [
|
||||||
|
2,
|
||||||
|
10060
|
||||||
|
],
|
||||||
|
"goto": 0
|
||||||
}
|
}
|
||||||
]
|
]
|
@ -15,6 +15,7 @@ const (
|
|||||||
gameWorldtaskBattle = "game_worldbattle.json"
|
gameWorldtaskBattle = "game_worldbattle.json"
|
||||||
gameWorldAll = "game_worldall.json"
|
gameWorldAll = "game_worldall.json"
|
||||||
gameburiedCond = "game_buriedcondi.json"
|
gameburiedCond = "game_buriedcondi.json"
|
||||||
|
gamerdtasknpc = "game_rdtasknpc.json"
|
||||||
)
|
)
|
||||||
|
|
||||||
type configureComp struct {
|
type configureComp struct {
|
||||||
@ -30,6 +31,7 @@ func (this *configureComp) Init(service core.IService, module core.IModule, comp
|
|||||||
gameWorldtaskBattle: cfg.NewGameWorldBattle,
|
gameWorldtaskBattle: cfg.NewGameWorldBattle,
|
||||||
gameWorldAll: cfg.NewGameWorldAll,
|
gameWorldAll: cfg.NewGameWorldAll,
|
||||||
gameburiedCond: cfg.NewGameBuriedCondi,
|
gameburiedCond: cfg.NewGameBuriedCondi,
|
||||||
|
gamerdtasknpc: cfg.NewGameRdtaskNpc,
|
||||||
})
|
})
|
||||||
this.worldtaskConf = make(map[int32]*cfg.GameWorldTaskData)
|
this.worldtaskConf = make(map[int32]*cfg.GameWorldTaskData)
|
||||||
configure.RegisterConfigure(gameWorldTask, cfg.NewGameBuriedCondi, this.updateconfigure)
|
configure.RegisterConfigure(gameWorldTask, cfg.NewGameBuriedCondi, this.updateconfigure)
|
||||||
@ -90,6 +92,26 @@ func (this *configureComp) getWorldtaskById(taskId int32) (*cfg.GameWorldTaskDat
|
|||||||
return nil, comm.NewNotFoundConfErr(moduleName_cn, gameWorldTask, taskId)
|
return nil, comm.NewNotFoundConfErr(moduleName_cn, gameWorldTask, taskId)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (this *configureComp) getNPCById(npcId int32) (npc *cfg.GameRdtaskNpcData, err error) {
|
||||||
|
var (
|
||||||
|
v interface{}
|
||||||
|
)
|
||||||
|
if v, err = this.GetConfigure(gamerdtasknpc); err != nil {
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
data, ok := v.(*cfg.GameRdtaskNpc)
|
||||||
|
if !ok {
|
||||||
|
err = fmt.Errorf("%T is *cfg.GameRdtaskNpc", v)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if npc, ok = data.GetDataMap()[npcId]; ok {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
err = comm.NewNotFoundConfErr(moduleName_cn, gamerdtasknpc, npc)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
func (this *configureComp) getWorldtaskBattleCfg() (data *cfg.GameWorldBattle, err error) {
|
func (this *configureComp) getWorldtaskBattleCfg() (data *cfg.GameWorldBattle, err error) {
|
||||||
var (
|
var (
|
||||||
v interface{}
|
v interface{}
|
||||||
|
@ -11,6 +11,7 @@ import (
|
|||||||
"go_dreamfactory/pb"
|
"go_dreamfactory/pb"
|
||||||
cfg "go_dreamfactory/sys/configure/structs"
|
cfg "go_dreamfactory/sys/configure/structs"
|
||||||
"go_dreamfactory/utils"
|
"go_dreamfactory/utils"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
var _ comm.IWorldtask = (*Worldtask)(nil)
|
var _ comm.IWorldtask = (*Worldtask)(nil)
|
||||||
@ -60,6 +61,8 @@ func (this *Worldtask) Start() (err error) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var errs []string
|
||||||
|
|
||||||
// 配置文件校验
|
// 配置文件校验
|
||||||
func (this *Worldtask) checkWorldtaskConf() (err error) {
|
func (this *Worldtask) checkWorldtaskConf() (err error) {
|
||||||
worldtaskConf, err := this.configure.getWorldtaskCfg()
|
worldtaskConf, err := this.configure.getWorldtaskCfg()
|
||||||
@ -73,26 +76,49 @@ func (this *Worldtask) checkWorldtaskConf() (err error) {
|
|||||||
for _, data := range worldtaskConf.GetDataList() {
|
for _, data := range worldtaskConf.GetDataList() {
|
||||||
// 检查 lock
|
// 检查 lock
|
||||||
if data.Lock < 1 {
|
if data.Lock < 1 {
|
||||||
return fmt.Errorf("taskId:%v lock:%v可能存在问题", data.Key, data.Lock)
|
errs = append(errs, fmt.Sprintf("taskId:%v lock:%v可能存在问题", data.Key, data.Lock))
|
||||||
}
|
}
|
||||||
//检查group
|
//检查group
|
||||||
if data.Group <= 0 {
|
if data.Group <= 0 {
|
||||||
return fmt.Errorf("taskId:%v group:%v可能存在问题", data.Key, data.Group)
|
errs = append(errs, fmt.Sprintf("taskId:%v group:%v可能存在问题", data.Key, data.Group))
|
||||||
}
|
}
|
||||||
//检查des
|
//检查des
|
||||||
if data.Des < 1 || data.Des > 5 {
|
if data.Des < 1 || data.Des > 5 {
|
||||||
return fmt.Errorf("taskId:%v des:%v可能存在问题", data.Key, data.Des)
|
errs = append(errs, fmt.Sprintf("taskId:%v des:%v可能存在问题", data.Key, data.Des))
|
||||||
}
|
}
|
||||||
// 检查completetask 是否有效
|
// 检查completetask 是否有效
|
||||||
for _, condId := range data.Completetask {
|
for _, condId := range data.Completetask {
|
||||||
if condId == 0 {
|
if condId > 0 {
|
||||||
continue
|
|
||||||
}
|
|
||||||
if _, ok := buriedCondConf.GetDataMap()[condId]; !ok {
|
if _, ok := buriedCondConf.GetDataMap()[condId]; !ok {
|
||||||
return fmt.Errorf("taskId:%v completetask:%v可能是无效的ID", data.Key, condId)
|
errs = append(errs, fmt.Sprintf("taskId:%v completetask:%v可能是无效的ID", data.Key, condId))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//检查NPC
|
||||||
|
if data.Npc > 0 {
|
||||||
|
if _, err := this.configure.getNPCById(data.Npc); err != nil {
|
||||||
|
errs = append(errs, fmt.Sprintf("npcId:%v 可能无效,检查world_task表字段Npc值是否存在于buried/rdtasknpc", data.Npc))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if data.DeliverNpc > 0 {
|
||||||
|
if _, err := this.configure.getNPCById(data.Npc); err != nil {
|
||||||
|
errs = append(errs, fmt.Sprintf("npcId:%v 可能无效,检查world_task表字段deliver_npc值是否存在于buried/rdtasknpc", data.Npc))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, data := range buriedCondConf.GetDataList() {
|
||||||
|
if data.NPC > 0 {
|
||||||
|
if _, err := this.configure.getNPCById(data.NPC); err != nil {
|
||||||
|
errs = append(errs, fmt.Sprintf("npcId:%v 可能无效,检查buried_condi表字段NPC值是否存在于buried/rdtasknpc", data.NPC))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(errs) > 0 {
|
||||||
|
return fmt.Errorf("%s", strings.Join(errs, "|"))
|
||||||
|
}
|
||||||
|
|
||||||
this.Debug("check worldtask conf completed")
|
this.Debug("check worldtask conf completed")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user