quickludo.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. package main
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "math/rand"
  6. "time"
  7. "bet24.com/log"
  8. coreservice "bet24.com/servers/coreservice/client"
  9. "bet24.com/servers/games/quickludo/config"
  10. "bet24.com/servers/games/quickludo/gamelogic"
  11. "bet24.com/servers/insecureframe/frame"
  12. "bet24.com/servers/insecureframe/gate"
  13. robotmanager "bet24.com/servers/insecureframe/robot"
  14. "bet24.com/servers/transaction"
  15. "bet24.com/utils"
  16. )
  17. func waitInput() {
  18. for {
  19. var cmd string
  20. var param1 string
  21. var param2 string
  22. fmt.Scanf("%s %s %s", &cmd, &param1, &param2)
  23. switch cmd {
  24. case "exit":
  25. gamelogic.Stopping = true
  26. robotmanager.Exit()
  27. frame.StopServer()
  28. go transaction.DoGameRoomPing(gamelogic.GAMEID, 1, config.RoomConfigName)
  29. case "listuser":
  30. gate.DumpUsers()
  31. case "robotlist":
  32. robotmanager.Dump()
  33. case "robotWin":
  34. log.Release(config.Rooms.Dump())
  35. default:
  36. if !frame.Dump(cmd, param1, param2) {
  37. log.Release("unknown command")
  38. }
  39. }
  40. }
  41. }
  42. func startRoomPing() {
  43. if gamelogic.Stopping {
  44. return
  45. }
  46. time.AfterFunc(20*time.Second, startRoomPing)
  47. //将本server的Ip和端口写入redis
  48. for i := 0; i < len(config.Rooms.Rooms); i++ {
  49. d, _ := json.Marshal(config.Rooms.Rooms[i].RoomInfoBase)
  50. // fmt.Println(string(d))
  51. go transaction.DoGameRoomPing(gamelogic.GAMEID, 2, config.Rooms.Rooms[i].RoomName)
  52. frame.UpdateRoomList(config.Rooms.Rooms[i].RoomName, config.Rooms.Rooms[i].RoomDesc, string(d), config.Rooms.Rooms[i].RoomID-1)
  53. }
  54. }
  55. func main() {
  56. defer waitInput()
  57. rand.Seed(time.Now().UnixNano())
  58. coreservice.SetServiceAddr(config.Server.ServiceAddr)
  59. // 可以从coreservice中读取配置
  60. config.Run()
  61. utils.SetErrorFile("log/quickludo/err.log", "quickludo starting")
  62. // 把数据库链接都创建起来
  63. gamelogic.Run()
  64. //monitor.Run(config.Server.MonitorPort)
  65. startRoomPing()
  66. }