當前位置: 首頁>>代碼示例>>Golang>>正文


Golang NetCore.Client類代碼示例

本文整理匯總了Golang中NetCore.Client的典型用法代碼示例。如果您正苦於以下問題:Golang Client類的具體用法?Golang Client怎麽用?Golang Client使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了Client類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: handleClientLeaveRoom

func handleClientLeaveRoom(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	client.RemoveCloseCB("leaveRoom")

	msg.Buf = ErrConf.GetEmptyRspBuffer(ErrConf.NO_ERR)
	client.SendMsg(msg)

	if room, ok := idRoomMap[client.Id]; ok {
		Logger.Info(LogConf.WorkerClientJob, client.Idx, "client leave room id: %d RoomId: %d", client.Id, room.Id)

		notify := &LeaveRoomNotify{
			Id: NetCore.ClientIDType(client.Id),
		}
		msg.Cmd = MsgConf.ClientLeaveRoomNotify
		if buf, err := json.Marshal(notify); err == nil {
			msg.Buf = buf
		} else {
			return false
		}

		delete(room.Guests, client.Id)

		if len(room.Guests) > 0 {
			for _, v := range room.Guests {
				v.SendMsg(msg)
			}
		} else {
			delete(rooms, room.Id)
		}
	}

	Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientLeaveRoom client Idx: %d id: %d", client.Idx, client.Id)

	return true
}
開發者ID:cokeboL,項目名稱:ZIM,代碼行數:34,代碼來源:Room.go

示例2: handleRegist

func handleRegist(client *NetCore.Client, msg *NetCore.NetMsg) {
	stype := binary.LittleEndian.Uint32(msg.Buf)
	NetCore.MarkServer(client, stype)
	addServerToMap(client)
	client.AddCloseCB("removeServer", removeServerFromMap)

	Logger.Info(LogConf.CourierServerJob, LogConf.SERVER, "Server Regist client idx: %d buf len: %d %d", client.GetIdx(), len(msg.Buf), stype)

	binary.LittleEndian.PutUint32(msg.Buf[0:4], NetConf.Courier)
	client.SendMsg(msg)
}
開發者ID:cokeboL,項目名稱:GoWorld,代碼行數:11,代碼來源:handler.go

示例3: handleServerRegist

func handleServerRegist(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	if client != courier {
		Logger.Warn(LogConf.Admin, LogConf.SERVER, "handleServerRegist error, %v %d!", courier, client.Idx)
		return false
	}
	client.CancelWaitRegist()

	Logger.Info(LogConf.Admin, LogConf.SERVER, "handleServerRegist OK, %v %d!", courier, client.Idx)

	NetCore.MarkServer(client, NetConf.Courier)

	return true
}
開發者ID:ccppluagopy,項目名稱:Zebra,代碼行數:13,代碼來源:Handlers.go

示例4: handleClientRegist

func handleClientRegist(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	var (
		req ClientRegistReq
	)

	if err := json.Unmarshal([]byte(msg.Buf), &req); err != nil {
		return false
	}

	id := req.Id

	client.CancelWaitRegist()

	msg.Buf = ErrConf.GetEmptyRspBuffer(ErrConf.NO_ERR)
	client.SendMsg(msg)

	NetCore.AddClientToManager(client, NetCore.ClientIDType(id))

	Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientRegist client Idx: %d id: %d", client.Idx, id)

	return true
}
開發者ID:cokeboL,項目名稱:ZIM,代碼行數:22,代碼來源:Regist.go

示例5: handleRegist

func handleRegist(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	var ctype = binary.LittleEndian.Uint32(msg.Buf)
	client.CancelWaitRegist()

	if ctype == NetConf.Client {
		binary.LittleEndian.PutUint32(msg.Buf[0:4], NetConf.Worker)
		client.SendMsg(msg)
	} else {
		if client != courier {
			Logger.Warn(LogConf.WorkerServerJob, LogConf.SERVER, "handleServerRegist error, %v %d!", courier, client.Idx)
			return false
		}

		Logger.Info(LogConf.WorkerServerJob, LogConf.SERVER, "handleServerRegist OK, %v %d!", courier, client.Idx)

		NetCore.MarkServer(client, ctype)
	}

	Logger.Info(LogConf.WorkerServerJob, LogConf.SERVER, "handleRegist, type: %d %d!", ctype, client.Idx)

	return true
}
開發者ID:ccppluagopy,項目名稱:Zebra,代碼行數:22,代碼來源:Handlers.go

示例6: handleClientEnterRoom

//要把房間user列表回複給它
func handleClientEnterRoom(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	var (
		req  EnterRoomReq
		rsp  = &EnterRoomRsp{Ret: 0}
		room *Room
		ok   bool
	)
	Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 000")

	enterRoomRsp := func() {
		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom aaa %d", rsp.Ret)
		if rsp.Ret == 0 {
			rsp.Guests = make([]NetCore.ClientIDType, len(room.Guests)+1)
			rsp.Guests[0] = NetCore.ClientIDType(client.Id)
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom bbb")

			n := 1
			for id, _ := range room.Guests {
				Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom ccc %d %d", id, n)
				rsp.Guests[n] = NetCore.ClientIDType(id)
				n = n + 1
				Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom ddd %d %d", id, len(rsp.Guests))
			}
		}
		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom ddd")
		if buf, err := json.Marshal(rsp); err == nil {
			rspMsg := &NetCore.NetMsg{
				Cmd: msg.Cmd,
				Buf: buf,
			}
			client.SendMsg(rspMsg)

			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom client Idx: %d id: %d RoomId: %d", client.Idx, client.Id, req.RoomId)
		} else {
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom xxxx")
		}
	}

	if err := json.Unmarshal([]byte(msg.Buf), &req); err != nil {
		rsp.Ret = ErrConf.INVALID_JSON
		enterRoomRsp()
		return false
	}

	if room, ok = rooms[req.RoomId]; ok {
		if _, ok2 := room.Guests[client.Id]; ok2 {
			rsp.Ret = ErrConf.ID_HAS_BEEN_IN_ROOM
			enterRoomRsp()
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 111")
			return true
		}

		if req.Passwd != room.Passwd {
			rsp.Ret = ErrConf.ERROR_PASSWD_FOR_ROOM
			enterRoomRsp()
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 111")
			return true
		}

		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 222")
		notify := &EnterRoomNotify{
			Id: NetCore.ClientIDType(client.Id),
		}
		notifyMsg := &NetCore.NetMsg{
			Cmd: MsgConf.ClientEnterRoomNotify,
		}
		if buf, err := json.Marshal(notify); err == nil {
			notifyMsg.Buf = buf
		} else {
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 333")
			return false
		}

		for _, v := range room.Guests {
			v.SendMsg(notifyMsg)
		}

		enterRoomRsp()

		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 444")
		room.Guests[client.Id] = client
		idRoomMap[client.Id] = room

	} else {
		room = &Room{
			Id:     req.RoomId,
			Passwd: req.Passwd,
			Guests: make(map[NetCore.ClientIDType]*NetCore.Client),
		}

		enterRoomRsp()

		room.Guests[client.Id] = client
		idRoomMap[client.Id] = room

		rooms[req.RoomId] = room

		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 555")
	}
//.........這裏部分代碼省略.........
開發者ID:cokeboL,項目名稱:ZIM,代碼行數:101,代碼來源:Room.go

示例7: handleRegist

func handleRegist(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	client.CancelWaitRegist()
	client.HeartBeat()
	return true
}
開發者ID:ccppluagopy,項目名稱:Zebra,代碼行數:5,代碼來源:main.go

示例8: handleHeartBeat2

func handleHeartBeat2(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	Logger.Info(LogConf.NetCoreCommen, client.Idx, "handleHeartBeat xx client Idx: %d cmd: %d", client.Idx, msg.Cmd)
	client.HeartBeat()
	return true
}
開發者ID:ccppluagopy,項目名稱:Zebra,代碼行數:5,代碼來源:main.go

示例9: handleCourier

func handleCourier(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	client.EchoMsg(msg)

	return true
}
開發者ID:cokeboL,項目名稱:ZIM,代碼行數:5,代碼來源:handler.go

示例10: handleCourier

func handleCourier(client *NetCore.Client, msg *NetCore.NetMsg) {
	client.EchoMsg(msg)
}
開發者ID:cokeboL,項目名稱:GoWorld,代碼行數:3,代碼來源:handler.go


注:本文中的NetCore.Client類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。