discreteRuleConfig.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. // this file is auto create by program, don't edit manually
  2. package data
  3. import (
  4. mhayaError "github.com/mhaya/error"
  5. mhayaLogger "github.com/mhaya/logger"
  6. )
  7. type discreteRuleConfig struct {
  8. maps map[int]*DiscreteRuleConfigRow
  9. }
  10. type DiscreteRuleConfigRow struct {
  11. ID int // #离散规则信息ID
  12. Reward []ItemReward // 奖励
  13. Condition string // 条件
  14. }
  15. func (p *discreteRuleConfig) Name() string {
  16. return "discreteRuleConfig"
  17. }
  18. func (p *discreteRuleConfig) Init() {
  19. p.maps = make(map[int]*DiscreteRuleConfigRow)
  20. }
  21. func (p *discreteRuleConfig) OnLoad(maps interface{}, _ bool) (int, error) {
  22. list, ok := maps.([]interface{})
  23. if !ok {
  24. return 0, mhayaError.Error("maps convert to []interface{} error.")
  25. }
  26. loadMaps := make(map[int]*DiscreteRuleConfigRow)
  27. for index, data := range list {
  28. loadConfig := &DiscreteRuleConfigRow{}
  29. err := DecodeData(data, loadConfig)
  30. if err != nil {
  31. mhayaLogger.Warnf("decode error. [row = %d, %v], err = %s", index+1, loadConfig, err)
  32. continue
  33. }
  34. loadMaps[loadConfig.ID] = loadConfig
  35. }
  36. p.maps = loadMaps
  37. return len(list), nil
  38. }
  39. func (p *discreteRuleConfig) OnAfterLoad(_ bool) {
  40. }
  41. func (p *discreteRuleConfig) Get(pk int) (*DiscreteRuleConfigRow, bool) {
  42. i, found := p.maps[pk]
  43. return i, found
  44. }
  45. func (p *discreteRuleConfig) GetAll() map[int]*DiscreteRuleConfigRow {
  46. var ret = make(map[int]*DiscreteRuleConfigRow)
  47. for _, v := range p.maps {
  48. ret[v.ID] = v
  49. }
  50. return ret
  51. }
  52. func (p *discreteRuleConfig) Contain(pk int) bool {
  53. _, found := p.Get(pk)
  54. return found
  55. }