Skip to content

Commit

Permalink
feat: ✨ ship type validation check
Browse files Browse the repository at this point in the history
  • Loading branch information
panxuc committed Apr 7, 2024
1 parent 3b567b6 commit 3abf6ea
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 5 deletions.
3 changes: 1 addition & 2 deletions dependency/proto/Message2Server.proto
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,5 @@ message BuildShipMsg
{
ShipType ship_type = 1;
int64 team_id = 2;
int64 player_id = 3;
int32 birthpoint_index = 4;
int32 birthpoint_index = 3;
}
30 changes: 28 additions & 2 deletions logic/Gaming/Game.cs
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ public struct PlayerInitInfo(long teamID, long playerID, ShipType shipType)
public List<Team> TeamList => teamList;
private readonly Map gameMap;
public Map GameMap => gameMap;
private Random random = new();
public long AddPlayer(PlayerInitInfo playerInitInfo)
{
if (!gameMap.TeamExists(playerInitInfo.teamID))
Expand All @@ -31,6 +32,32 @@ public long AddPlayer(PlayerInitInfo playerInitInfo)
if (playerInitInfo.playerID != 0)
{
// Add a ship
var shipType = playerInitInfo.shipType;
switch (shipType)
{
case ShipType.Null:
return GameObj.invalidID;
case ShipType.CivilShip:
if (teamList[(int)playerInitInfo.teamID].ShipPool.GetNum(ShipType.CivilShip) >= GameData.MaxCivilShipNum)
{
return GameObj.invalidID;
}
break;
case ShipType.WarShip:
if (teamList[(int)playerInitInfo.teamID].ShipPool.GetNum(ShipType.WarShip) >= GameData.MaxWarShipNum)
{
return GameObj.invalidID;
}
break;
case ShipType.FlagShip:
if (teamList[(int)playerInitInfo.teamID].ShipPool.GetNum(ShipType.FlagShip) >= GameData.MaxFlagShipNum)
{
return GameObj.invalidID;
}
break;
default:
return GameObj.invalidID;
}
Ship? newShip = shipManager.AddShip(playerInitInfo.teamID, playerInitInfo.playerID,
playerInitInfo.shipType, teamList[(int)playerInitInfo.teamID].MoneyPool);
if (newShip == null)
Expand All @@ -46,7 +73,7 @@ public long AddPlayer(PlayerInitInfo playerInitInfo)
return playerInitInfo.playerID;
}
}
public long ActivateShip(long teamID, long playerID, ShipType shipType, int birthPointIndex = 0)
public long ActivateShip(long teamID, ShipType shipType, int birthPointIndex = 0)
{
Ship? ship = teamList[(int)teamID].ShipPool.GetObj(shipType);
if (ship == null)
Expand All @@ -56,7 +83,6 @@ public long ActivateShip(long teamID, long playerID, ShipType shipType, int birt
if (birthPointIndex >= teamList[(int)teamID].BirthPointList.Count)
birthPointIndex = teamList[(int)teamID].BirthPointList.Count - 1;
XY pos = teamList[(int)teamID].BirthPointList[birthPointIndex];
Random random = new();
pos += new XY(((random.Next() & 2) - 1) * 1000, ((random.Next() & 2) - 1) * 1000);
if (shipManager.ActivateShip(ship, pos))
{
Expand Down
2 changes: 1 addition & 1 deletion logic/Server/RpcServices.cs
Original file line number Diff line number Diff line change
Expand Up @@ -519,7 +519,7 @@ public override Task<BoolRes> BuildShip(BuildShipMsg request, ServerCallContext
boolRes.ActSuccess = false;
return Task.FromResult(boolRes);
}
boolRes.ActSuccess = game.ActivateShip(request.TeamId, request.PlayerId, Transformation.ShipTypeFromProto(request.ShipType), request.BirthpointIndex) != GameObj.invalidID;
boolRes.ActSuccess = game.ActivateShip(request.TeamId, Transformation.ShipTypeFromProto(request.ShipType), request.BirthpointIndex) != GameObj.invalidID;
#if DEBUG
Console.WriteLine("END BuildShip");
#endif
Expand Down

0 comments on commit 3abf6ea

Please sign in to comment.