mirror of
				https://github.com/genxium/DelayNoMore
				synced 2025-10-22 06:56:54 +00:00 
			
		
		
		
	Fixed frontend compilation.
This commit is contained in:
		| @@ -38,6 +38,7 @@ type Player struct { | |||||||
| 	Name           string  `json:"name,omitempty" db:"name"` | 	Name           string  `json:"name,omitempty" db:"name"` | ||||||
| 	DisplayName    string  `json:"displayName,omitempty" db:"display_name"` | 	DisplayName    string  `json:"displayName,omitempty" db:"display_name"` | ||||||
| 	Avatar         string  `json:"avatar,omitempty"` | 	Avatar         string  `json:"avatar,omitempty"` | ||||||
|  | 	ColliderRadius float64 `json:"-"` | ||||||
|  |  | ||||||
| 	// DB only fields | 	// DB only fields | ||||||
| 	CreatedAt     int64     `db:"created_at"` | 	CreatedAt     int64     `db:"created_at"` | ||||||
|   | |||||||
| @@ -130,7 +130,6 @@ func calRoomScore(inRoomPlayerCount int32, roomPlayerCnt int, currentRoomBattleS | |||||||
| type Room struct { | type Room struct { | ||||||
| 	Id                    int32 | 	Id                    int32 | ||||||
| 	Capacity              int | 	Capacity              int | ||||||
| 	playerColliderRadius  float64 |  | ||||||
| 	collisionSpaceOffsetX float64 | 	collisionSpaceOffsetX float64 | ||||||
| 	collisionSpaceOffsetY float64 | 	collisionSpaceOffsetY float64 | ||||||
| 	Players               map[int32]*Player | 	Players               map[int32]*Player | ||||||
| @@ -219,7 +218,8 @@ func (pR *Room) AddPlayerIfPossible(pPlayerFromDbInit *Player, session *websocke | |||||||
| 	pPlayerFromDbInit.AckingInputFrameId = -1 | 	pPlayerFromDbInit.AckingInputFrameId = -1 | ||||||
| 	pPlayerFromDbInit.LastSentInputFrameId = MAGIC_LAST_SENT_INPUT_FRAME_ID_NORMAL_ADDED | 	pPlayerFromDbInit.LastSentInputFrameId = MAGIC_LAST_SENT_INPUT_FRAME_ID_NORMAL_ADDED | ||||||
| 	pPlayerFromDbInit.BattleState = PlayerBattleStateIns.ADDED_PENDING_BATTLE_COLLIDER_ACK | 	pPlayerFromDbInit.BattleState = PlayerBattleStateIns.ADDED_PENDING_BATTLE_COLLIDER_ACK | ||||||
| 	pPlayerFromDbInit.Speed = pR.PlayerDefaultSpeed | 	pPlayerFromDbInit.Speed = pR.PlayerDefaultSpeed // Hardcoded | ||||||
|  | 	pPlayerFromDbInit.ColliderRadius = float64(12)  // Hardcoded | ||||||
|  |  | ||||||
| 	pR.Players[playerId] = pPlayerFromDbInit | 	pR.Players[playerId] = pPlayerFromDbInit | ||||||
| 	pR.PlayerDownsyncSessionDict[playerId] = session | 	pR.PlayerDownsyncSessionDict[playerId] = session | ||||||
| @@ -251,6 +251,8 @@ func (pR *Room) ReAddPlayerIfPossible(pTmpPlayerInstance *Player, session *webso | |||||||
| 	pEffectiveInRoomPlayerInstance.AckingInputFrameId = -1 | 	pEffectiveInRoomPlayerInstance.AckingInputFrameId = -1 | ||||||
| 	pEffectiveInRoomPlayerInstance.LastSentInputFrameId = MAGIC_LAST_SENT_INPUT_FRAME_ID_READDED | 	pEffectiveInRoomPlayerInstance.LastSentInputFrameId = MAGIC_LAST_SENT_INPUT_FRAME_ID_READDED | ||||||
| 	pEffectiveInRoomPlayerInstance.BattleState = PlayerBattleStateIns.READDED_PENDING_BATTLE_COLLIDER_ACK | 	pEffectiveInRoomPlayerInstance.BattleState = PlayerBattleStateIns.READDED_PENDING_BATTLE_COLLIDER_ACK | ||||||
|  | 	pEffectiveInRoomPlayerInstance.Speed = pR.PlayerDefaultSpeed // Hardcoded | ||||||
|  | 	pEffectiveInRoomPlayerInstance.ColliderRadius = float64(12)  // Hardcoded | ||||||
|  |  | ||||||
| 	Logger.Warn("ReAddPlayerIfPossible finished.", zap.Any("roomId", pR.Id), zap.Any("playerId", playerId), zap.Any("joinIndex", pEffectiveInRoomPlayerInstance.JoinIndex), zap.Any("playerBattleState", pEffectiveInRoomPlayerInstance.BattleState), zap.Any("roomState", pR.State), zap.Any("roomEffectivePlayerCount", pR.EffectivePlayerCount), zap.Any("AckingFrameId", pEffectiveInRoomPlayerInstance.AckingFrameId), zap.Any("AckingInputFrameId", pEffectiveInRoomPlayerInstance.AckingInputFrameId), zap.Any("LastSentInputFrameId", pEffectiveInRoomPlayerInstance.LastSentInputFrameId)) | 	Logger.Warn("ReAddPlayerIfPossible finished.", zap.Any("roomId", pR.Id), zap.Any("playerId", playerId), zap.Any("joinIndex", pEffectiveInRoomPlayerInstance.JoinIndex), zap.Any("playerBattleState", pEffectiveInRoomPlayerInstance.BattleState), zap.Any("roomState", pR.State), zap.Any("roomEffectivePlayerCount", pR.EffectivePlayerCount), zap.Any("AckingFrameId", pEffectiveInRoomPlayerInstance.AckingFrameId), zap.Any("AckingInputFrameId", pEffectiveInRoomPlayerInstance.AckingInputFrameId), zap.Any("LastSentInputFrameId", pEffectiveInRoomPlayerInstance.LastSentInputFrameId)) | ||||||
| 	return true | 	return true | ||||||
| @@ -723,6 +725,7 @@ func (pR *Room) onBattlePrepare(cb BattleStartCbType) { | |||||||
| 			Name:           player.Name, | 			Name:           player.Name, | ||||||
| 			DisplayName:    player.DisplayName, | 			DisplayName:    player.DisplayName, | ||||||
| 			Avatar:         player.Avatar, | 			Avatar:         player.Avatar, | ||||||
|  | 			ColliderRadius: player.ColliderRadius, // hardcoded for now | ||||||
| 			JoinIndex:      player.JoinIndex, | 			JoinIndex:      player.JoinIndex, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @@ -797,7 +800,6 @@ func (pR *Room) Dismiss() { | |||||||
| func (pR *Room) OnDismissed() { | func (pR *Room) OnDismissed() { | ||||||
|  |  | ||||||
| 	// Always instantiates new HeapRAM blocks and let the old blocks die out due to not being retained by any root reference. | 	// Always instantiates new HeapRAM blocks and let the old blocks die out due to not being retained by any root reference. | ||||||
| 	pR.playerColliderRadius = float64(12) // hardcoded |  | ||||||
| 	pR.WorldToVirtualGridRatio = float64(10) | 	pR.WorldToVirtualGridRatio = float64(10) | ||||||
| 	pR.VirtualGridToWorldRatio = float64(1.0) / pR.WorldToVirtualGridRatio // this is a one-off computation, should avoid division in iterations | 	pR.VirtualGridToWorldRatio = float64(1.0) / pR.WorldToVirtualGridRatio // this is a one-off computation, should avoid division in iterations | ||||||
| 	pR.PlayerDefaultSpeed = int32(3 * pR.WorldToVirtualGridRatio)          // Hardcoded in virtual grids per frame | 	pR.PlayerDefaultSpeed = int32(3 * pR.WorldToVirtualGridRatio)          // Hardcoded in virtual grids per frame | ||||||
| @@ -1222,7 +1224,7 @@ func (pR *Room) applyInputFrameDownsyncDynamics(fromRenderFrameId int32, toRende | |||||||
| 				collisionPlayerIndex := COLLISION_PLAYER_INDEX_PREFIX + joinIndex | 				collisionPlayerIndex := COLLISION_PLAYER_INDEX_PREFIX + joinIndex | ||||||
| 				playerCollider := pR.CollisionSysMap[collisionPlayerIndex] | 				playerCollider := pR.CollisionSysMap[collisionPlayerIndex] | ||||||
| 				// Reset playerCollider position from the "virtual grid position" | 				// Reset playerCollider position from the "virtual grid position" | ||||||
| 				playerCollider.X, playerCollider.Y = pR.virtualGridToPlayerColliderPos(player.VirtualGridX, player.VirtualGridY) | 				playerCollider.X, playerCollider.Y = pR.virtualGridToPlayerColliderPos(player.VirtualGridX, player.VirtualGridY, player) | ||||||
|  |  | ||||||
| 				if collision := playerCollider.Check(oldDx, oldDy, "Barrier"); collision != nil { | 				if collision := playerCollider.Check(oldDx, oldDy, "Barrier"); collision != nil { | ||||||
| 					playerShape := playerCollider.Shape.(*resolv.ConvexPolygon) | 					playerShape := playerCollider.Shape.(*resolv.ConvexPolygon) | ||||||
| @@ -1245,7 +1247,7 @@ func (pR *Room) applyInputFrameDownsyncDynamics(fromRenderFrameId int32, toRende | |||||||
|  |  | ||||||
| 				player.Dir.Dx = decodedInput[0] | 				player.Dir.Dx = decodedInput[0] | ||||||
| 				player.Dir.Dy = decodedInput[1] | 				player.Dir.Dy = decodedInput[1] | ||||||
| 				player.VirtualGridX, player.VirtualGridY = pR.playerColliderAnchorToVirtualGridPos(playerCollider.X, playerCollider.Y) | 				player.VirtualGridX, player.VirtualGridY = pR.playerColliderAnchorToVirtualGridPos(playerCollider.X, playerCollider.Y, player) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -1270,7 +1272,7 @@ func (pR *Room) refreshColliders(spaceW, spaceH int32) { | |||||||
| 	space := resolv.NewSpace(int(spaceW), int(spaceH), minStep, minStep) // allocate a new collision space everytime after a battle is settled | 	space := resolv.NewSpace(int(spaceW), int(spaceH), minStep, minStep) // allocate a new collision space everytime after a battle is settled | ||||||
| 	for _, player := range pR.Players { | 	for _, player := range pR.Players { | ||||||
| 		wx, wy := pR.virtualGridToWorldPos(player.VirtualGridX, player.VirtualGridY) | 		wx, wy := pR.virtualGridToWorldPos(player.VirtualGridX, player.VirtualGridY) | ||||||
| 		playerCollider := GenerateRectCollider(wx, wy, pR.playerColliderRadius*2, pR.playerColliderRadius*2, pR.collisionSpaceOffsetX, pR.collisionSpaceOffsetY, "Player") | 		playerCollider := GenerateRectCollider(wx, wy, player.ColliderRadius*2, player.ColliderRadius*2, pR.collisionSpaceOffsetX, pR.collisionSpaceOffsetY, "Player") | ||||||
| 		space.Add(playerCollider) | 		space.Add(playerCollider) | ||||||
| 		// Keep track of the collider in "pR.CollisionSysMap" | 		// Keep track of the collider in "pR.CollisionSysMap" | ||||||
| 		joinIndex := player.JoinIndex | 		joinIndex := player.JoinIndex | ||||||
| @@ -1298,26 +1300,26 @@ func (pR *Room) worldToVirtualGridPos(x, y float64) (int32, int32) { | |||||||
| } | } | ||||||
|  |  | ||||||
| func (pR *Room) virtualGridToWorldPos(vx, vy int32) (float64, float64) { | func (pR *Room) virtualGridToWorldPos(vx, vy int32) (float64, float64) { | ||||||
| 	var x float64 = float64(vx) * pR.VirtualGridToWorldRatio | 	var wx float64 = float64(vx) * pR.VirtualGridToWorldRatio | ||||||
| 	var y float64 = float64(vy) * pR.VirtualGridToWorldRatio | 	var wy float64 = float64(vy) * pR.VirtualGridToWorldRatio | ||||||
| 	return x, y | 	return wx, wy | ||||||
| } | } | ||||||
|  |  | ||||||
| func (pR *Room) playerWorldToCollisionPos(wx, wy float64) (float64, float64) { | func (pR *Room) playerWorldToCollisionPos(wx, wy float64, player *Player) (float64, float64) { | ||||||
| 	// TODO: remove this duplicate code w.r.t. "dnmshared/resolv_helper.go" | 	// TODO: remove this duplicate code w.r.t. "dnmshared/resolv_helper.go" | ||||||
| 	return wx - pR.playerColliderRadius + pR.collisionSpaceOffsetX, wy - pR.playerColliderRadius + pR.collisionSpaceOffsetY | 	return wx - player.ColliderRadius + pR.collisionSpaceOffsetX, wy - player.ColliderRadius + pR.collisionSpaceOffsetY | ||||||
| } | } | ||||||
|  |  | ||||||
| func (pR *Room) playerColliderAnchorToWorldPos(cx, cy float64) (float64, float64) { | func (pR *Room) playerColliderAnchorToWorldPos(cx, cy float64, player *Player) (float64, float64) { | ||||||
| 	return cx + pR.playerColliderRadius - pR.collisionSpaceOffsetX, cy + pR.playerColliderRadius - pR.collisionSpaceOffsetY | 	return cx + player.ColliderRadius - pR.collisionSpaceOffsetX, cy + player.ColliderRadius - pR.collisionSpaceOffsetY | ||||||
| } | } | ||||||
|  |  | ||||||
| func (pR *Room) playerColliderAnchorToVirtualGridPos(cx, cy float64) (int32, int32) { | func (pR *Room) playerColliderAnchorToVirtualGridPos(cx, cy float64, player *Player) (int32, int32) { | ||||||
| 	wx, wy := pR.playerColliderAnchorToWorldPos(cx, cy) | 	wx, wy := pR.playerColliderAnchorToWorldPos(cx, cy, player) | ||||||
| 	return pR.worldToVirtualGridPos(wx, wy) | 	return pR.worldToVirtualGridPos(wx, wy) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (pR *Room) virtualGridToPlayerColliderPos(vx, vy int32) (float64, float64) { | func (pR *Room) virtualGridToPlayerColliderPos(vx, vy int32, player *Player) (float64, float64) { | ||||||
| 	wx, wy := pR.virtualGridToWorldPos(vx, vy) | 	wx, wy := pR.virtualGridToWorldPos(vx, vy) | ||||||
| 	return pR.playerWorldToCollisionPos(wx, wy) | 	return pR.playerWorldToCollisionPos(wx, wy, player) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -365,6 +365,7 @@ type PlayerDownsyncMeta struct { | |||||||
| 	DisplayName    string  `protobuf:"bytes,3,opt,name=displayName,proto3" json:"displayName,omitempty"` | 	DisplayName    string  `protobuf:"bytes,3,opt,name=displayName,proto3" json:"displayName,omitempty"` | ||||||
| 	Avatar         string  `protobuf:"bytes,4,opt,name=avatar,proto3" json:"avatar,omitempty"` | 	Avatar         string  `protobuf:"bytes,4,opt,name=avatar,proto3" json:"avatar,omitempty"` | ||||||
| 	JoinIndex      int32   `protobuf:"varint,5,opt,name=joinIndex,proto3" json:"joinIndex,omitempty"` | 	JoinIndex      int32   `protobuf:"varint,5,opt,name=joinIndex,proto3" json:"joinIndex,omitempty"` | ||||||
|  | 	ColliderRadius float64 `protobuf:"fixed64,6,opt,name=colliderRadius,proto3" json:"colliderRadius,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
| func (x *PlayerDownsyncMeta) Reset() { | func (x *PlayerDownsyncMeta) Reset() { | ||||||
| @@ -434,6 +435,13 @@ func (x *PlayerDownsyncMeta) GetJoinIndex() int32 { | |||||||
| 	return 0 | 	return 0 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (x *PlayerDownsyncMeta) GetColliderRadius() float64 { | ||||||
|  | 	if x != nil { | ||||||
|  | 		return x.ColliderRadius | ||||||
|  | 	} | ||||||
|  | 	return 0 | ||||||
|  | } | ||||||
|  |  | ||||||
| type InputFrameUpsync struct { | type InputFrameUpsync struct { | ||||||
| 	state         protoimpl.MessageState | 	state         protoimpl.MessageState | ||||||
| 	sizeCache     protoimpl.SizeCache | 	sizeCache     protoimpl.SizeCache | ||||||
| @@ -972,7 +980,7 @@ var file_room_downsync_frame_proto_rawDesc = []byte{ | |||||||
| 	0x72, 0x65, 0x6d, 0x6f, 0x76, 0x65, 0x64, 0x18, 0x0b, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x72, | 	0x72, 0x65, 0x6d, 0x6f, 0x76, 0x65, 0x64, 0x18, 0x0b, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x72, | ||||||
| 	0x65, 0x6d, 0x6f, 0x76, 0x65, 0x64, 0x12, 0x1c, 0x0a, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, 0x6e, | 	0x65, 0x6d, 0x6f, 0x76, 0x65, 0x64, 0x12, 0x1c, 0x0a, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, 0x6e, | ||||||
| 	0x64, 0x65, 0x78, 0x18, 0x0c, 0x20, 0x01, 0x28, 0x05, 0x52, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, | 	0x64, 0x65, 0x78, 0x18, 0x0c, 0x20, 0x01, 0x28, 0x05, 0x52, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, | ||||||
| 	0x6e, 0x64, 0x65, 0x78, 0x22, 0x90, 0x01, 0x0a, 0x12, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x44, | 	0x6e, 0x64, 0x65, 0x78, 0x22, 0xb8, 0x01, 0x0a, 0x12, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x44, | ||||||
| 	0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x4d, 0x65, 0x74, 0x61, 0x12, 0x0e, 0x0a, 0x02, 0x69, | 	0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x4d, 0x65, 0x74, 0x61, 0x12, 0x0e, 0x0a, 0x02, 0x69, | ||||||
| 	0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x02, 0x69, 0x64, 0x12, 0x12, 0x0a, 0x04, 0x6e, | 	0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x02, 0x69, 0x64, 0x12, 0x12, 0x0a, 0x04, 0x6e, | ||||||
| 	0x61, 0x6d, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, | 	0x61, 0x6d, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, | ||||||
| @@ -981,87 +989,90 @@ var file_room_downsync_frame_proto_rawDesc = []byte{ | |||||||
| 	0x65, 0x12, 0x16, 0x0a, 0x06, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x18, 0x04, 0x20, 0x01, 0x28, | 	0x65, 0x12, 0x16, 0x0a, 0x06, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x18, 0x04, 0x20, 0x01, 0x28, | ||||||
| 	0x09, 0x52, 0x06, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x12, 0x1c, 0x0a, 0x09, 0x6a, 0x6f, 0x69, | 	0x09, 0x52, 0x06, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x12, 0x1c, 0x0a, 0x09, 0x6a, 0x6f, 0x69, | ||||||
| 	0x6e, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x18, 0x05, 0x20, 0x01, 0x28, 0x05, 0x52, 0x09, 0x6a, 0x6f, | 	0x6e, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x18, 0x05, 0x20, 0x01, 0x28, 0x05, 0x52, 0x09, 0x6a, 0x6f, | ||||||
| 	0x69, 0x6e, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x22, 0x56, 0x0a, 0x10, 0x49, 0x6e, 0x70, 0x75, 0x74, | 	0x69, 0x6e, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x12, 0x26, 0x0a, 0x0e, 0x63, 0x6f, 0x6c, 0x6c, 0x69, | ||||||
| 	0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x12, 0x22, 0x0a, 0x0c, 0x69, | 	0x64, 0x65, 0x72, 0x52, 0x61, 0x64, 0x69, 0x75, 0x73, 0x18, 0x06, 0x20, 0x01, 0x28, 0x01, 0x52, | ||||||
| 	0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, | 	0x0e, 0x63, 0x6f, 0x6c, 0x6c, 0x69, 0x64, 0x65, 0x72, 0x52, 0x61, 0x64, 0x69, 0x75, 0x73, 0x22, | ||||||
| 	0x05, 0x52, 0x0c, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x12, | 	0x56, 0x0a, 0x10, 0x49, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, 0x70, 0x73, | ||||||
| 	0x1e, 0x0a, 0x0a, 0x65, 0x6e, 0x63, 0x6f, 0x64, 0x65, 0x64, 0x44, 0x69, 0x72, 0x18, 0x06, 0x20, | 	0x79, 0x6e, 0x63, 0x12, 0x22, 0x0a, 0x0c, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, | ||||||
| 	0x01, 0x28, 0x05, 0x52, 0x0a, 0x65, 0x6e, 0x63, 0x6f, 0x64, 0x65, 0x64, 0x44, 0x69, 0x72, 0x22, | 	0x65, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0c, 0x69, 0x6e, 0x70, 0x75, 0x74, | ||||||
| 	0x7c, 0x0a, 0x12, 0x49, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, 0x6f, 0x77, | 	0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x12, 0x1e, 0x0a, 0x0a, 0x65, 0x6e, 0x63, 0x6f, 0x64, | ||||||
| 	0x6e, 0x73, 0x79, 0x6e, 0x63, 0x12, 0x22, 0x0a, 0x0c, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, | 	0x65, 0x64, 0x44, 0x69, 0x72, 0x18, 0x06, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0a, 0x65, 0x6e, 0x63, | ||||||
| 	0x61, 0x6d, 0x65, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0c, 0x69, 0x6e, 0x70, | 	0x6f, 0x64, 0x65, 0x64, 0x44, 0x69, 0x72, 0x22, 0x7c, 0x0a, 0x12, 0x49, 0x6e, 0x70, 0x75, 0x74, | ||||||
| 	0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x12, 0x1c, 0x0a, 0x09, 0x69, 0x6e, 0x70, | 	0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x12, 0x22, 0x0a, | ||||||
| 	0x75, 0x74, 0x4c, 0x69, 0x73, 0x74, 0x18, 0x02, 0x20, 0x03, 0x28, 0x04, 0x52, 0x09, 0x69, 0x6e, | 	0x0c, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x18, 0x01, 0x20, | ||||||
| 	0x70, 0x75, 0x74, 0x4c, 0x69, 0x73, 0x74, 0x12, 0x24, 0x0a, 0x0d, 0x63, 0x6f, 0x6e, 0x66, 0x69, | 	0x01, 0x28, 0x05, 0x52, 0x0c, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, | ||||||
| 	0x72, 0x6d, 0x65, 0x64, 0x4c, 0x69, 0x73, 0x74, 0x18, 0x03, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0d, | 	0x64, 0x12, 0x1c, 0x0a, 0x09, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x4c, 0x69, 0x73, 0x74, 0x18, 0x02, | ||||||
| 	0x63, 0x6f, 0x6e, 0x66, 0x69, 0x72, 0x6d, 0x65, 0x64, 0x4c, 0x69, 0x73, 0x74, 0x22, 0x3b, 0x0a, | 	0x20, 0x03, 0x28, 0x04, 0x52, 0x09, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x4c, 0x69, 0x73, 0x74, 0x12, | ||||||
| 	0x0f, 0x48, 0x65, 0x61, 0x72, 0x74, 0x62, 0x65, 0x61, 0x74, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, | 	0x24, 0x0a, 0x0d, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x72, 0x6d, 0x65, 0x64, 0x4c, 0x69, 0x73, 0x74, | ||||||
| 	0x12, 0x28, 0x0a, 0x0f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x73, 0x74, | 	0x18, 0x03, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0d, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x72, 0x6d, 0x65, | ||||||
| 	0x61, 0x6d, 0x70, 0x18, 0x01, 0x20, 0x01, 0x28, 0x03, 0x52, 0x0f, 0x63, 0x6c, 0x69, 0x65, 0x6e, | 	0x64, 0x4c, 0x69, 0x73, 0x74, 0x22, 0x3b, 0x0a, 0x0f, 0x48, 0x65, 0x61, 0x72, 0x74, 0x62, 0x65, | ||||||
| 	0x74, 0x54, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x22, 0x8b, 0x03, 0x0a, 0x11, 0x52, | 	0x61, 0x74, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x12, 0x28, 0x0a, 0x0f, 0x63, 0x6c, 0x69, 0x65, | ||||||
| 	0x6f, 0x6f, 0x6d, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, 0x72, 0x61, 0x6d, 0x65, | 	0x6e, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x18, 0x01, 0x20, 0x01, 0x28, | ||||||
| 	0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x02, 0x69, 0x64, | 	0x03, 0x52, 0x0f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, | ||||||
| 	0x12, 0x40, 0x0a, 0x07, 0x70, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x73, 0x18, 0x02, 0x20, 0x03, 0x28, | 	0x6d, 0x70, 0x22, 0x8b, 0x03, 0x0a, 0x11, 0x52, 0x6f, 0x6f, 0x6d, 0x44, 0x6f, 0x77, 0x6e, 0x73, | ||||||
| 	0x0b, 0x32, 0x26, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x52, 0x6f, 0x6f, 0x6d, 0x44, | 	0x79, 0x6e, 0x63, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, | ||||||
| 	0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x2e, 0x50, 0x6c, 0x61, | 	0x20, 0x01, 0x28, 0x05, 0x52, 0x02, 0x69, 0x64, 0x12, 0x40, 0x0a, 0x07, 0x70, 0x6c, 0x61, 0x79, | ||||||
| 	0x79, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x07, 0x70, 0x6c, 0x61, 0x79, 0x65, | 	0x65, 0x72, 0x73, 0x18, 0x02, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x26, 0x2e, 0x70, 0x72, 0x6f, 0x74, | ||||||
| 	0x72, 0x73, 0x12, 0x26, 0x0a, 0x0e, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x64, 0x6f, 0x77, 0x6e, 0x4e, | 	0x6f, 0x73, 0x2e, 0x52, 0x6f, 0x6f, 0x6d, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, | ||||||
| 	0x61, 0x6e, 0x6f, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28, 0x03, 0x52, 0x0e, 0x63, 0x6f, 0x75, 0x6e, | 	0x72, 0x61, 0x6d, 0x65, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, | ||||||
| 	0x74, 0x64, 0x6f, 0x77, 0x6e, 0x4e, 0x61, 0x6e, 0x6f, 0x73, 0x12, 0x4c, 0x0a, 0x0b, 0x70, 0x6c, | 	0x79, 0x52, 0x07, 0x70, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x73, 0x12, 0x26, 0x0a, 0x0e, 0x63, 0x6f, | ||||||
| 	0x61, 0x79, 0x65, 0x72, 0x4d, 0x65, 0x74, 0x61, 0x73, 0x18, 0x04, 0x20, 0x03, 0x28, 0x0b, 0x32, | 	0x75, 0x6e, 0x74, 0x64, 0x6f, 0x77, 0x6e, 0x4e, 0x61, 0x6e, 0x6f, 0x73, 0x18, 0x03, 0x20, 0x01, | ||||||
| 	0x2a, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x52, 0x6f, 0x6f, 0x6d, 0x44, 0x6f, 0x77, | 	0x28, 0x03, 0x52, 0x0e, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x64, 0x6f, 0x77, 0x6e, 0x4e, 0x61, 0x6e, | ||||||
| 	0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, | 	0x6f, 0x73, 0x12, 0x4c, 0x0a, 0x0b, 0x70, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x4d, 0x65, 0x74, 0x61, | ||||||
| 	0x72, 0x4d, 0x65, 0x74, 0x61, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x0b, 0x70, 0x6c, 0x61, | 	0x73, 0x18, 0x04, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x2a, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, | ||||||
| 	0x79, 0x65, 0x72, 0x4d, 0x65, 0x74, 0x61, 0x73, 0x1a, 0x52, 0x0a, 0x0c, 0x50, 0x6c, 0x61, 0x79, | 	0x2e, 0x52, 0x6f, 0x6f, 0x6d, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, 0x72, 0x61, | ||||||
| 	0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, | 	0x6d, 0x65, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x4d, 0x65, 0x74, 0x61, 0x73, 0x45, 0x6e, | ||||||
| 	0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x2c, 0x0a, 0x05, 0x76, 0x61, | 	0x74, 0x72, 0x79, 0x52, 0x0b, 0x70, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x4d, 0x65, 0x74, 0x61, 0x73, | ||||||
| 	0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x16, 0x2e, 0x70, 0x72, 0x6f, 0x74, | 	0x1a, 0x52, 0x0a, 0x0c, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, | ||||||
| 	0x6f, 0x73, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, |  | ||||||
| 	0x63, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x1a, 0x5a, 0x0a, 0x10, |  | ||||||
| 	0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x4d, 0x65, 0x74, 0x61, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, |  | ||||||
| 	0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x6b, | 	0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x6b, | ||||||
| 	0x65, 0x79, 0x12, 0x30, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, | 	0x65, 0x79, 0x12, 0x2c, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, | ||||||
| 	0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, | 	0x0b, 0x32, 0x16, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, | ||||||
| 	0x72, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x4d, 0x65, 0x74, 0x61, 0x52, 0x05, 0x76, | 	0x72, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, | ||||||
| 	0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x22, 0xb8, 0x02, 0x0a, 0x05, 0x57, 0x73, 0x52, | 	0x3a, 0x02, 0x38, 0x01, 0x1a, 0x5a, 0x0a, 0x10, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x4d, 0x65, | ||||||
| 	0x65, 0x71, 0x12, 0x14, 0x0a, 0x05, 0x6d, 0x73, 0x67, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, | 	0x74, 0x61, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, | ||||||
| 	0x05, 0x52, 0x05, 0x6d, 0x73, 0x67, 0x49, 0x64, 0x12, 0x1a, 0x0a, 0x08, 0x70, 0x6c, 0x61, 0x79, | 	0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x30, 0x0a, 0x05, 0x76, 0x61, | ||||||
| 	0x65, 0x72, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x05, 0x52, 0x08, 0x70, 0x6c, 0x61, 0x79, | 	0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, 0x74, | ||||||
| 	0x65, 0x72, 0x49, 0x64, 0x12, 0x10, 0x0a, 0x03, 0x61, 0x63, 0x74, 0x18, 0x03, 0x20, 0x01, 0x28, | 	0x6f, 0x73, 0x2e, 0x50, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, | ||||||
| 	0x05, 0x52, 0x03, 0x61, 0x63, 0x74, 0x12, 0x1c, 0x0a, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, 0x6e, | 	0x63, 0x4d, 0x65, 0x74, 0x61, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, | ||||||
| 	0x64, 0x65, 0x78, 0x18, 0x04, 0x20, 0x01, 0x28, 0x05, 0x52, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, | 	0x22, 0xb8, 0x02, 0x0a, 0x05, 0x57, 0x73, 0x52, 0x65, 0x71, 0x12, 0x14, 0x0a, 0x05, 0x6d, 0x73, | ||||||
| 	0x6e, 0x64, 0x65, 0x78, 0x12, 0x24, 0x0a, 0x0d, 0x61, 0x63, 0x6b, 0x69, 0x6e, 0x67, 0x46, 0x72, | 	0x67, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x05, 0x6d, 0x73, 0x67, 0x49, 0x64, | ||||||
| 	0x61, 0x6d, 0x65, 0x49, 0x64, 0x18, 0x05, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0d, 0x61, 0x63, 0x6b, | 	0x12, 0x1a, 0x0a, 0x08, 0x70, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, | ||||||
| 	0x69, 0x6e, 0x67, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x12, 0x2e, 0x0a, 0x12, 0x61, 0x63, | 	0x28, 0x05, 0x52, 0x08, 0x70, 0x6c, 0x61, 0x79, 0x65, 0x72, 0x49, 0x64, 0x12, 0x10, 0x0a, 0x03, | ||||||
| 	0x6b, 0x69, 0x6e, 0x67, 0x49, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, | 	0x61, 0x63, 0x74, 0x18, 0x03, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x61, 0x63, 0x74, 0x12, 0x1c, | ||||||
| 	0x18, 0x06, 0x20, 0x01, 0x28, 0x05, 0x52, 0x12, 0x61, 0x63, 0x6b, 0x69, 0x6e, 0x67, 0x49, 0x6e, | 	0x0a, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x18, 0x04, 0x20, 0x01, 0x28, | ||||||
| 	0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x12, 0x4e, 0x0a, 0x15, 0x69, 0x6e, | 	0x05, 0x52, 0x09, 0x6a, 0x6f, 0x69, 0x6e, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x12, 0x24, 0x0a, 0x0d, | ||||||
| 	0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x42, 0x61, | 	0x61, 0x63, 0x6b, 0x69, 0x6e, 0x67, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x18, 0x05, 0x20, | ||||||
| 	0x74, 0x63, 0x68, 0x18, 0x07, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x18, 0x2e, 0x70, 0x72, 0x6f, 0x74, | 	0x01, 0x28, 0x05, 0x52, 0x0d, 0x61, 0x63, 0x6b, 0x69, 0x6e, 0x67, 0x46, 0x72, 0x61, 0x6d, 0x65, | ||||||
| 	0x6f, 0x73, 0x2e, 0x49, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, 0x70, 0x73, | 	0x49, 0x64, 0x12, 0x2e, 0x0a, 0x12, 0x61, 0x63, 0x6b, 0x69, 0x6e, 0x67, 0x49, 0x6e, 0x70, 0x75, | ||||||
| 	0x79, 0x6e, 0x63, 0x52, 0x15, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, | 	0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x49, 0x64, 0x18, 0x06, 0x20, 0x01, 0x28, 0x05, 0x52, 0x12, | ||||||
| 	0x70, 0x73, 0x79, 0x6e, 0x63, 0x42, 0x61, 0x74, 0x63, 0x68, 0x12, 0x27, 0x0a, 0x02, 0x68, 0x62, | 	0x61, 0x63, 0x6b, 0x69, 0x6e, 0x67, 0x49, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, | ||||||
| 	0x18, 0x08, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x17, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, | 	0x49, 0x64, 0x12, 0x4e, 0x0a, 0x15, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, | ||||||
| 	0x48, 0x65, 0x61, 0x72, 0x74, 0x62, 0x65, 0x61, 0x74, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x52, | 	0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x42, 0x61, 0x74, 0x63, 0x68, 0x18, 0x07, 0x20, 0x03, 0x28, | ||||||
| 	0x02, 0x68, 0x62, 0x22, 0x89, 0x02, 0x0a, 0x06, 0x57, 0x73, 0x52, 0x65, 0x73, 0x70, 0x12, 0x10, | 	0x0b, 0x32, 0x18, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x49, 0x6e, 0x70, 0x75, 0x74, | ||||||
| 	0x0a, 0x03, 0x72, 0x65, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x72, 0x65, 0x74, | 	0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x52, 0x15, 0x69, 0x6e, 0x70, | ||||||
| 	0x12, 0x20, 0x0a, 0x0b, 0x65, 0x63, 0x68, 0x6f, 0x65, 0x64, 0x4d, 0x73, 0x67, 0x49, 0x64, 0x18, | 	0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x42, 0x61, 0x74, | ||||||
| 	0x02, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0b, 0x65, 0x63, 0x68, 0x6f, 0x65, 0x64, 0x4d, 0x73, 0x67, | 	0x63, 0x68, 0x12, 0x27, 0x0a, 0x02, 0x68, 0x62, 0x18, 0x08, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x17, | ||||||
| 	0x49, 0x64, 0x12, 0x10, 0x0a, 0x03, 0x61, 0x63, 0x74, 0x18, 0x03, 0x20, 0x01, 0x28, 0x05, 0x52, | 	0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x48, 0x65, 0x61, 0x72, 0x74, 0x62, 0x65, 0x61, | ||||||
| 	0x03, 0x61, 0x63, 0x74, 0x12, 0x2b, 0x0a, 0x03, 0x72, 0x64, 0x66, 0x18, 0x04, 0x20, 0x01, 0x28, | 	0x74, 0x55, 0x70, 0x73, 0x79, 0x6e, 0x63, 0x52, 0x02, 0x68, 0x62, 0x22, 0x89, 0x02, 0x0a, 0x06, | ||||||
| 	0x0b, 0x32, 0x19, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x52, 0x6f, 0x6f, 0x6d, 0x44, | 	0x57, 0x73, 0x52, 0x65, 0x73, 0x70, 0x12, 0x10, 0x0a, 0x03, 0x72, 0x65, 0x74, 0x18, 0x01, 0x20, | ||||||
| 	0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x52, 0x03, 0x72, 0x64, | 	0x01, 0x28, 0x05, 0x52, 0x03, 0x72, 0x65, 0x74, 0x12, 0x20, 0x0a, 0x0b, 0x65, 0x63, 0x68, 0x6f, | ||||||
| 	0x66, 0x12, 0x54, 0x0a, 0x17, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, | 	0x65, 0x64, 0x4d, 0x73, 0x67, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0b, 0x65, | ||||||
| 	0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x42, 0x61, 0x74, 0x63, 0x68, 0x18, 0x05, 0x20, 0x03, | 	0x63, 0x68, 0x6f, 0x65, 0x64, 0x4d, 0x73, 0x67, 0x49, 0x64, 0x12, 0x10, 0x0a, 0x03, 0x61, 0x63, | ||||||
| 	0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x49, 0x6e, 0x70, 0x75, | 	0x74, 0x18, 0x03, 0x20, 0x01, 0x28, 0x05, 0x52, 0x03, 0x61, 0x63, 0x74, 0x12, 0x2b, 0x0a, 0x03, | ||||||
| 	0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x52, 0x17, | 	0x72, 0x64, 0x66, 0x18, 0x04, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x70, 0x72, 0x6f, 0x74, | ||||||
| 	0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, | 	0x6f, 0x73, 0x2e, 0x52, 0x6f, 0x6f, 0x6d, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x46, | ||||||
| 	0x6e, 0x63, 0x42, 0x61, 0x74, 0x63, 0x68, 0x12, 0x36, 0x0a, 0x08, 0x62, 0x63, 0x69, 0x46, 0x72, | 	0x72, 0x61, 0x6d, 0x65, 0x52, 0x03, 0x72, 0x64, 0x66, 0x12, 0x54, 0x0a, 0x17, 0x69, 0x6e, 0x70, | ||||||
| 	0x61, 0x6d, 0x65, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, 0x74, | 	0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x42, | ||||||
| 	0x6f, 0x73, 0x2e, 0x42, 0x61, 0x74, 0x74, 0x6c, 0x65, 0x43, 0x6f, 0x6c, 0x6c, 0x69, 0x64, 0x65, | 	0x61, 0x74, 0x63, 0x68, 0x18, 0x05, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, | ||||||
| 	0x72, 0x49, 0x6e, 0x66, 0x6f, 0x52, 0x08, 0x62, 0x63, 0x69, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x42, | 	0x74, 0x6f, 0x73, 0x2e, 0x49, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x44, 0x6f, | ||||||
| 	0x13, 0x5a, 0x11, 0x62, 0x61, 0x74, 0x74, 0x6c, 0x65, 0x5f, 0x73, 0x72, 0x76, 0x2f, 0x70, 0x72, | 	0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x52, 0x17, 0x69, 0x6e, 0x70, 0x75, 0x74, 0x46, 0x72, 0x61, | ||||||
| 	0x6f, 0x74, 0x6f, 0x73, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, | 	0x6d, 0x65, 0x44, 0x6f, 0x77, 0x6e, 0x73, 0x79, 0x6e, 0x63, 0x42, 0x61, 0x74, 0x63, 0x68, 0x12, | ||||||
|  | 	0x36, 0x0a, 0x08, 0x62, 0x63, 0x69, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x18, 0x06, 0x20, 0x01, 0x28, | ||||||
|  | 	0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x2e, 0x42, 0x61, 0x74, 0x74, 0x6c, | ||||||
|  | 	0x65, 0x43, 0x6f, 0x6c, 0x6c, 0x69, 0x64, 0x65, 0x72, 0x49, 0x6e, 0x66, 0x6f, 0x52, 0x08, 0x62, | ||||||
|  | 	0x63, 0x69, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x42, 0x13, 0x5a, 0x11, 0x62, 0x61, 0x74, 0x74, 0x6c, | ||||||
|  | 	0x65, 0x5f, 0x73, 0x72, 0x76, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x73, 0x62, 0x06, 0x70, 0x72, | ||||||
|  | 	0x6f, 0x74, 0x6f, 0x33, | ||||||
| } | } | ||||||
|  |  | ||||||
| var ( | var ( | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "ver": "1.0.5", |  | ||||||
|   "uuid": "bd514df4-095e-4088-9060-d99397a29a4f", |  | ||||||
|   "isPlugin": true, |  | ||||||
|   "loadPluginInWeb": true, |  | ||||||
|   "loadPluginInNative": true, |  | ||||||
|   "loadPluginInEditor": false, |  | ||||||
|   "subMetas": {} |  | ||||||
| } |  | ||||||
							
								
								
									
										5
									
								
								frontend/assets/resources/pbfiles/geometry.proto.meta
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								frontend/assets/resources/pbfiles/geometry.proto.meta
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | { | ||||||
|  |   "ver": "2.0.0", | ||||||
|  |   "uuid": "2ba698f8-1af7-4c47-9d43-b2730b62c692", | ||||||
|  |   "subMetas": {} | ||||||
|  | } | ||||||
| @@ -50,6 +50,7 @@ message PlayerDownsyncMeta { | |||||||
|   string displayName = 3; |   string displayName = 3; | ||||||
|   string avatar = 4; |   string avatar = 4; | ||||||
|   int32 joinIndex = 5; |   int32 joinIndex = 5; | ||||||
|  |   double colliderRadius = 6; | ||||||
| } | } | ||||||
|  |  | ||||||
| message InputFrameUpsync { | message InputFrameUpsync { | ||||||
|   | |||||||
| @@ -440,7 +440,7 @@ | |||||||
|       "array": [ |       "array": [ | ||||||
|         0, |         0, | ||||||
|         0, |         0, | ||||||
|         209.73151519075364, |         377.5870760500153, | ||||||
|         0, |         0, | ||||||
|         0, |         0, | ||||||
|         0, |         0, | ||||||
|   | |||||||
| @@ -123,12 +123,6 @@ cc.Class({ | |||||||
|  |  | ||||||
|   dumpToRenderCache: function(rdf) { |   dumpToRenderCache: function(rdf) { | ||||||
|     const self = this; |     const self = this; | ||||||
|     // round player position to lower precision |  | ||||||
|     for (let playerId in rdf.players) { |  | ||||||
|       const immediatePlayerInfo = rdf.players[playerId]; |  | ||||||
|       rdf.players[playerId].x = parseFloat(parseInt(immediatePlayerInfo.x * 100)) / 100.0; |  | ||||||
|       rdf.players[playerId].y = parseFloat(parseInt(immediatePlayerInfo.y * 100)) / 100.0; |  | ||||||
|     } |  | ||||||
|     const minToKeepRenderFrameId = self.lastAllConfirmedRenderFrameId; |     const minToKeepRenderFrameId = self.lastAllConfirmedRenderFrameId; | ||||||
|     while (0 < self.recentRenderCache.cnt && self.recentRenderCache.stFrameId < minToKeepRenderFrameId) { |     while (0 < self.recentRenderCache.cnt && self.recentRenderCache.stFrameId < minToKeepRenderFrameId) { | ||||||
|       self.recentRenderCache.pop(); |       self.recentRenderCache.pop(); | ||||||
| @@ -428,9 +422,11 @@ cc.Class({ | |||||||
|       self.rollbackEstimatedDt = parsedBattleColliderInfo.rollbackEstimatedDt; |       self.rollbackEstimatedDt = parsedBattleColliderInfo.rollbackEstimatedDt; | ||||||
|       self.rollbackEstimatedDtMillis = parsedBattleColliderInfo.rollbackEstimatedDtMillis; |       self.rollbackEstimatedDtMillis = parsedBattleColliderInfo.rollbackEstimatedDtMillis; | ||||||
|       self.rollbackEstimatedDtNanos = parsedBattleColliderInfo.rollbackEstimatedDtNanos; |       self.rollbackEstimatedDtNanos = parsedBattleColliderInfo.rollbackEstimatedDtNanos; | ||||||
|       self.rollbackEstimatedDtToleranceMillis = self.rollbackEstimatedDtMillis / 1000.0; |  | ||||||
|       self.maxChasingRenderFramesPerUpdate = parsedBattleColliderInfo.maxChasingRenderFramesPerUpdate; |       self.maxChasingRenderFramesPerUpdate = parsedBattleColliderInfo.maxChasingRenderFramesPerUpdate; | ||||||
|  |  | ||||||
|  |       self.worldToVirtualGridRatio = parsedBattleColliderInfo.worldToVirtualGridRatio; | ||||||
|  |       self.virtualGridToWorldRatio = parsedBattleColliderInfo.virtualGridToWorldRatio; | ||||||
|  |  | ||||||
|       const tiledMapIns = self.node.getComponent(cc.TiledMap); |       const tiledMapIns = self.node.getComponent(cc.TiledMap); | ||||||
|  |  | ||||||
|       const fullPathOfTmxFile = cc.js.formatStr("map/%s/map", parsedBattleColliderInfo.stageName); |       const fullPathOfTmxFile = cc.js.formatStr("map/%s/map", parsedBattleColliderInfo.stageName); | ||||||
| @@ -970,11 +966,12 @@ cc.Class({ | |||||||
|       const collisionPlayerIndex = self.collisionPlayerIndexPrefix + joinIndex; |       const collisionPlayerIndex = self.collisionPlayerIndexPrefix + joinIndex; | ||||||
|       const playerCollider = collisionSysMap.get(collisionPlayerIndex); |       const playerCollider = collisionSysMap.get(collisionPlayerIndex); | ||||||
|       const currentSelfColliderCircle = playerRichInfo.node.getComponent(cc.CircleCollider); |       const currentSelfColliderCircle = playerRichInfo.node.getComponent(cc.CircleCollider); | ||||||
|  |       const vpos = self.playerColliderAnchorToVirtualGridPos(playerCollider.x, playerCollider.y, playerRichInfo); | ||||||
|       const r = currentSelfColliderCircle.radius; |       const r = currentSelfColliderCircle.radius; | ||||||
|       rdf.players[playerRichInfo.id] = { |       rdf.players[playerRichInfo.id] = { | ||||||
|         id: playerRichInfo.id, |         id: playerRichInfo.id, | ||||||
|         x: playerCollider.x + r, // [WARNING] the (x, y) of "playerCollider" is offset to the anchor (i.e. first point of all points) of the polygon shape |         virtualGridX: vpos[0], | ||||||
|         y: playerCollider.y + r, |         virtualGridY: vpos[1], | ||||||
|         dir: self.ctrl.decodeDirection(null == inputFrameAppliedOnPrevRenderFrame ? 0 : inputFrameAppliedOnPrevRenderFrame.inputList[joinIndex - 1]), |         dir: self.ctrl.decodeDirection(null == inputFrameAppliedOnPrevRenderFrame ? 0 : inputFrameAppliedOnPrevRenderFrame.inputList[joinIndex - 1]), | ||||||
|         speed: (null == speedRefRenderFrame ? playerRichInfo.speed : speedRefRenderFrame.players[playerRichInfo.id].speed), |         speed: (null == speedRefRenderFrame ? playerRichInfo.speed : speedRefRenderFrame.players[playerRichInfo.id].speed), | ||||||
|         joinIndex: joinIndex |         joinIndex: joinIndex | ||||||
| @@ -1001,12 +998,13 @@ cc.Class({ | |||||||
|  |  | ||||||
|     self.playerRichInfoDict.forEach((playerRichInfo, playerId) => { |     self.playerRichInfoDict.forEach((playerRichInfo, playerId) => { | ||||||
|       const immediatePlayerInfo = rdf.players[playerId]; |       const immediatePlayerInfo = rdf.players[playerId]; | ||||||
|       const dx = (immediatePlayerInfo.x - playerRichInfo.node.x); |       const wpos = self.virtualGridToWorldPos(immediatePlayerInfo.virtualGridX, immediatePlayerInfo.virtualGridY); | ||||||
|       const dy = (immediatePlayerInfo.y - playerRichInfo.node.y); |       const dx = (wpos[0] - playerRichInfo.node.x); | ||||||
|  |       const dy = (wpos[1] - playerRichInfo.node.y); | ||||||
|       const justJiggling = (self.teleportEps1D >= Math.abs(dx) && self.teleportEps1D >= Math.abs(dy)); |       const justJiggling = (self.teleportEps1D >= Math.abs(dx) && self.teleportEps1D >= Math.abs(dy)); | ||||||
|       if (!justJiggling) { |       if (!justJiggling) { | ||||||
|         console.log("@renderFrameId=" + self.renderFrameId + ", teleporting playerId=" + playerId + ": '(" + playerRichInfo.node.x + ", " + playerRichInfo.node.y, ")' to '(" + immediatePlayerInfo.x + ", " + immediatePlayerInfo.y + ")'"); |         console.log("@renderFrameId=" + self.renderFrameId + ", teleporting playerId=" + playerId + ": '(" + playerRichInfo.node.x + ", " + playerRichInfo.node.y, ")' to '(" + wpos[0] + ", " + wpos[1] + ")'"); | ||||||
|         playerRichInfo.node.setPosition(immediatePlayerInfo.x, immediatePlayerInfo.y); |         playerRichInfo.node.setPosition(wpos[0], wpos[1]); | ||||||
|       } |       } | ||||||
|       playerRichInfo.scriptIns.scheduleNewDirection(immediatePlayerInfo.dir, false); |       playerRichInfo.scriptIns.scheduleNewDirection(immediatePlayerInfo.dir, false); | ||||||
|       playerRichInfo.scriptIns.updateSpeed(immediatePlayerInfo.speed); |       playerRichInfo.scriptIns.updateSpeed(immediatePlayerInfo.speed); | ||||||
| @@ -1046,10 +1044,9 @@ cc.Class({ | |||||||
|       const playerCollider = collisionSysMap.get(collisionPlayerIndex); |       const playerCollider = collisionSysMap.get(collisionPlayerIndex); | ||||||
|       const player = latestRdf.players[playerId]; |       const player = latestRdf.players[playerId]; | ||||||
|  |  | ||||||
|       const currentSelfColliderCircle = playerRichInfo.node.getComponent(cc.CircleCollider); |       const cpos = self.worldToVirtualGridPos(player.virtualGridX, player.virtualGridY); | ||||||
|       const r = currentSelfColliderCircle.radius; |       playerCollider.x = cpos[0]; | ||||||
|       playerCollider.x = player.x - r; |       playerCollider.y = cpos[1]; | ||||||
|       playerCollider.y = player.y - r; |  | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
| @@ -1072,7 +1069,7 @@ cc.Class({ | |||||||
|         const player = renderFrame.players[playerId]; |         const player = renderFrame.players[playerId]; | ||||||
|         const encodedInput = inputList[joinIndex - 1]; |         const encodedInput = inputList[joinIndex - 1]; | ||||||
|         const decodedInput = self.ctrl.decodeDirection(encodedInput); |         const decodedInput = self.ctrl.decodeDirection(encodedInput); | ||||||
|         const baseChange = player.speed * self.rollbackEstimatedDt * decodedInput.speedFactor; |         const baseChange = player.speed * decodedInput.speedFactor; | ||||||
|         playerCollider.x += baseChange * decodedInput.dx; |         playerCollider.x += baseChange * decodedInput.dx; | ||||||
|         playerCollider.y += baseChange * decodedInput.dy; |         playerCollider.y += baseChange * decodedInput.dy; | ||||||
|       } |       } | ||||||
| @@ -1115,6 +1112,8 @@ cc.Class({ | |||||||
|         scriptIns: nodeAndScriptIns[1] |         scriptIns: nodeAndScriptIns[1] | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  |       Object.assign(self.playerRichInfoDict.get(playerId), immediatePlayerMeta); | ||||||
|  |  | ||||||
|       if (self.selfPlayerInfo.id == playerId) { |       if (self.selfPlayerInfo.id == playerId) { | ||||||
|         self.selfPlayerInfo = Object.assign(self.selfPlayerInfo, immediatePlayerInfo); |         self.selfPlayerInfo = Object.assign(self.selfPlayerInfo, immediatePlayerInfo); | ||||||
|         nodeAndScriptIns[1].showArrowTipNode(); |         nodeAndScriptIns[1].showArrowTipNode(); | ||||||
| @@ -1152,4 +1151,38 @@ cc.Class({ | |||||||
|     return "[stRenderFrameId=" + self.recentRenderCache.stFrameId + ", edRenderFrameId=" + self.recentRenderCache.edFrameId + ")"; |     return "[stRenderFrameId=" + self.recentRenderCache.stFrameId + ", edRenderFrameId=" + self.recentRenderCache.edFrameId + ")"; | ||||||
|   }, |   }, | ||||||
|  |  | ||||||
|  |   worldToVirtualGridPos(x, y) { | ||||||
|  |     const self = this; | ||||||
|  |     // In JavaScript floating numbers suffer from seemingly non-deterministic arithmetics, and even if certain libs solved this issue by approaches such as fixed-point-number, they might not be used in other libs -- e.g. the "collision libs" we're interested in -- thus couldn't kill all pains. | ||||||
|  |     let virtualGridX = parseInt(x * self.worldToVirtualGridRatio); | ||||||
|  |     let virtualGridY = parseInt(y * self.worldToVirtualGridRatio); | ||||||
|  |     return [virtualGridX, virtualGridY]; | ||||||
|  |   }, | ||||||
|  |  | ||||||
|  |   virtualGridToWorldPos(vx, vy) { | ||||||
|  |     const self = this; | ||||||
|  |     let wx = parseFloat(vx) * self.virtualGridToWorldRatio; | ||||||
|  |     let wy = parseFloat(vy) * self.virtualGridToWorldRatio; | ||||||
|  |     return [wx, wy]; | ||||||
|  |   }, | ||||||
|  |  | ||||||
|  |   playerWorldToCollisionPos(wx, wy, playerRichInfo) { | ||||||
|  |     return [wx - playerRichInfo.colliderRadius, wy - playerRichInfo.colliderRadius]; | ||||||
|  |   }, | ||||||
|  |  | ||||||
|  |   playerColliderAnchorToWorldPos(cx, cy, playerRichInfo) { | ||||||
|  |     return [cx + playerRichInfo.colliderRadius, cy + playerRichInfo.colliderRadius]; | ||||||
|  |   }, | ||||||
|  |  | ||||||
|  |   playerColliderAnchorToVirtualGridPos(cx, cy, playerRichInfo) { | ||||||
|  |     const self = this; | ||||||
|  |     const wpos = self.playerColliderAnchorToWorldPos(cx, cy, playerRichInfo); | ||||||
|  |     return pR.worldToVirtualGridPos(wpos[0], wpos[1]) | ||||||
|  |   }, | ||||||
|  |  | ||||||
|  |   virtualGridToPlayerColliderPos(vx, vy, playerRichInfo) { | ||||||
|  |     const self = this; | ||||||
|  |     const wpos = self.virtualGridToWorldPos(vx, vy); | ||||||
|  |     return playerWorldToCollisionPos(wpos[0], wpos[1], playerRichInfo) | ||||||
|  |   }, | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -5,10 +5,10 @@ window.DIRECTION_DECODER = [ | |||||||
|     [0, -1, 1.0], |     [0, -1, 1.0], | ||||||
|     [+2, 0, 0.5], |     [+2, 0, 0.5], | ||||||
|     [-2, 0, 0.5], |     [-2, 0, 0.5], | ||||||
|     [+2, +1, 0.4472], |     [+2, +1, 0.44], | ||||||
|     [-2, -1, 0.4472], |     [-2, -1, 0.44], | ||||||
|     [+2, -1, 0.4472], |     [+2, -1, 0.44], | ||||||
|     [-2, +1, 0.4472], |     [-2, +1, 0.44], | ||||||
|     [+2, 0, 0.5], |     [+2, 0, 0.5], | ||||||
|     [-2, 0, 0.5], |     [-2, 0, 0.5], | ||||||
|     [0, +1, 1.0], |     [0, +1, 1.0], | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "ver": "1.0.5", |   "ver": "1.0.5", | ||||||
|   "uuid": "f9cd97f6-3533-4a27-afc8-cf302da003b2", |   "uuid": "1ef4a156-5c54-45b9-85ac-86734985e13a", | ||||||
|   "isPlugin": false, |   "isPlugin": false, | ||||||
|   "loadPluginInWeb": true, |   "loadPluginInWeb": true, | ||||||
|   "loadPluginInNative": true, |   "loadPluginInNative": true, | ||||||
|   | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,5 +0,0 @@ | |||||||
| { |  | ||||||
|   "ver": "1.0.1", |  | ||||||
|   "uuid": "e646fbd9-7821-4567-9846-fb6e45aeb921", |  | ||||||
|   "subMetas": {} |  | ||||||
| } |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -22,6 +22,8 @@ js_outdir=$js_basedir/assets/scripts/modules | |||||||
| # npm install -g protobufjs-cli  | # npm install -g protobufjs-cli  | ||||||
|  |  | ||||||
| # The specific filename is respected by "frontend/build-templates/wechatgame/game.js". | # The specific filename is respected by "frontend/build-templates/wechatgame/game.js". | ||||||
| pbjs -t static-module -w commonjs --keep-case --force-message -o $js_outdir/room_downsync_frame_proto_bundle.forcemsg.js $js_basedir/assets/resources/pbfiles/room_downsync_frame.proto | pbjs -t static-module -w commonjs --keep-case --force-message -o $js_outdir/room_downsync_frame_proto_bundle.forcemsg.js $js_basedir/assets/resources/pbfiles/geometry.proto $js_basedir/assets/resources/pbfiles/room_downsync_frame.proto | ||||||
|  |  | ||||||
|  | sed -i 's#require("protobufjs/minimal")#require("./protobuf-with-floating-num-decoding-endianess-toggle")#g' $js_outdir/room_downsync_frame_proto_bundle.forcemsg.js # Not working in OSX, needs further investigation | ||||||
|  |  | ||||||
| echo "JavaScript part done" | echo "JavaScript part done" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user