This commit is contained in:
meixiongfeng 2022-10-14 15:06:33 +08:00
parent caf1b0cdc9
commit c8db8bbfe6

View File

@ -136,33 +136,35 @@ func (this *Library) QueryOneHeroFetter(uid string, cid string) *pb.DBHeroFetter
// 创建一条羁绊信息 // 创建一条羁绊信息
func (this *Library) AddHeroFetterData(uid string, heroConfId string) (code pb.ErrorCode) { func (this *Library) AddHeroFetterData(uid string, heroConfId string) (code pb.ErrorCode) {
// 推送 _conf := this.configure.GetLibraryHero(heroConfId) // 配置表中没有这个英雄数据 直接返回
if _conf == nil {
return
}
var (
objFetter *pb.DBHeroFetter // 详细羁绊信息数据
)
rsp := &pb.LibraryChangePush{} rsp := &pb.LibraryChangePush{}
_data := this.QueryOneHeroFetter(uid, heroConfId) _data := this.QueryOneHeroFetter(uid, heroConfId)
this.Debugf("%v", _data)
if _data == nil { if _data == nil {
objFetter, c := this.createHeroFetter(uid, heroConfId) objFetter, code = this.createHeroFetter(uid, heroConfId)
if c != pb.ErrorCode_Success { if code == pb.ErrorCode_Success {
code = c rsp.Fetter = append(rsp.Fetter, objFetter)
} else {
this.Errorf("createHeroFetter failed:%v,uid:%s,heroid:%s", code, uid, heroConfId) this.Errorf("createHeroFetter failed:%v,uid:%s,heroid:%s", code, uid, heroConfId)
} }
_conf := this.configure.GetLibraryHero(heroConfId) }
if _conf != nil { for _, fid := range _conf.Fid {
szFid := _conf.Fid // 查询是否存在这个羁绊对象
for _, fid := range szFid { obj := this.GetLibraryListByFid(uid, fid)
// 查询是否存在这个羁绊对象 if obj == nil { // 没有羁绊信息
obj := this.GetLibraryListByFid(uid, fid) code, obj = this.CreateLibrary(uid, fid, heroConfId)
if obj == nil { // 没有羁绊信息 if code != pb.ErrorCode_Success {
code, obj = this.CreateLibrary(uid, fid, heroConfId) this.Errorf("CreateLibrary failed: %v,uid:%s,fid:%d", code, uid, fid)
if code != pb.ErrorCode_Success { }
this.Errorf("CreateLibrary failed: %v,uid:%s,fid:%d", code, uid, fid) } else { // 羁绊信息中没有这个heroid 也需要加进来
} for k, v := range obj.Hero {
} else { // 羁绊信息中没有这个heroid 也需要加进来 if v == 0 && k == heroConfId {
for k, v := range obj.Hero { obj.Hero[k] = 1
if v == 0 && k == heroConfId {
obj.Hero[k] = 1
}
}
// 重新计算最低等级 // 重新计算最低等级
var minLv int32 var minLv int32
for _, v := range obj.Hero { for _, v := range obj.Hero {
@ -176,11 +178,13 @@ func (this *Library) AddHeroFetterData(uid string, heroConfId string) (code pb.E
mapData["hero"] = obj.Hero mapData["hero"] = obj.Hero
mapData["fetterlv"] = obj.Fetterlv mapData["fetterlv"] = obj.Fetterlv
this.modelLibrary.modifyLibraryDataByObjId(uid, obj.Id, mapData) this.modelLibrary.modifyLibraryDataByObjId(uid, obj.Id, mapData)
rsp.Data = append(rsp.Data, obj)
break
} }
rsp.Data = append(rsp.Data, obj)
} }
} }
rsp.Fetter = append(rsp.Fetter, objFetter) }
if len(rsp.Data) != 0 || len(rsp.Fetter) != 0 {
this.SendMsgToUser(string(this.GetType()), LibraryChangePush, rsp, uid) this.SendMsgToUser(string(this.GetType()), LibraryChangePush, rsp, uid)
} }