Core: Added trait 'SurrenderOnDisconnect' and the core changes required to make this work

This commit is contained in:
geckosoft
2010-10-25 17:19:48 +02:00
committed by Chris Forbes
parent e7c61fac5c
commit f5b8b18d86
8 changed files with 256 additions and 184 deletions

View File

@@ -34,7 +34,8 @@ namespace OpenRA.Network
public enum ClientState public enum ClientState
{ {
NotReady, NotReady,
Ready Ready,
Disconnected = 1000
} }
public class Client public class Client

View File

@@ -43,6 +43,7 @@ namespace OpenRA.Network
if (Game.IsHost && Game.Settings.Server.Extension != null && !Game.Settings.Server.Extension.OnIngameChat(client, order.TargetString, false)) if (Game.IsHost && Game.Settings.Server.Extension != null && !Game.Settings.Server.Extension.OnIngameChat(client, order.TargetString, false))
break; break;
if (client != null) if (client != null)
{ {
var player = world != null ? world.FindPlayerByClient(client) : null; var player = world != null ? world.FindPlayerByClient(client) : null;
@@ -53,6 +54,16 @@ namespace OpenRA.Network
Game.AddChatLine(Color.White, "(player {0})".F(clientId), order.TargetString); Game.AddChatLine(Color.White, "(player {0})".F(clientId), order.TargetString);
break; break;
} }
case "Disconnected": /* reports that the target player disconnected */
{
var client = orderManager.LobbyInfo.ClientWithIndex(clientId);
if (client != null)
{
client.State = Session.ClientState.Disconnected;
}
break;
}
case "TeamChat": case "TeamChat":
{ {
var client = orderManager.LobbyInfo.ClientWithIndex(clientId); var client = orderManager.LobbyInfo.ClientWithIndex(clientId);
@@ -72,12 +83,16 @@ namespace OpenRA.Network
{ {
var player = world.FindPlayerByClient(client); var player = world.FindPlayerByClient(client);
var display = player != null var display = player != null
&& (world.LocalPlayer != null && player.Stances[world.LocalPlayer] == Stance.Ally &&
(world.LocalPlayer != null &&
player.Stances[world.LocalPlayer] == Stance.Ally
|| player.WinState == WinState.Lost); || player.WinState == WinState.Lost);
if (display) if (display)
{ {
var suffix = (player != null && player.WinState == WinState.Lost) ? " (Dead)" : " (Team)"; var suffix = (player != null && player.WinState == WinState.Lost)
? " (Dead)"
: " (Team)";
Game.AddChatLine(client.Color1, client.Name + suffix, order.TargetString); Game.AddChatLine(client.Color1, client.Name + suffix, order.TargetString);
} }
} }
@@ -98,15 +113,15 @@ namespace OpenRA.Network
&& !orderManager.GameStarted) && !orderManager.GameStarted)
{ {
orderManager.FramesAhead = orderManager.LobbyInfo.GlobalSettings.OrderLatency; orderManager.FramesAhead = orderManager.LobbyInfo.GlobalSettings.OrderLatency;
Game.Debug( "Order lag is now {0} frames.".F( orderManager.LobbyInfo.GlobalSettings.OrderLatency ) ); Game.Debug(
"Order lag is now {0} frames.".F(orderManager.LobbyInfo.GlobalSettings.OrderLatency));
} }
Game.SyncLobbyInfo(); Game.SyncLobbyInfo();
break; break;
} }
case "SetStance": case "SetStance":
{ {
var targetPlayer = order.Player.World.players[order.TargetLocation.X]; var targetPlayer = order.Player.World.players[order.TargetLocation.X];
var newStance = (Stance)order.TargetLocation.Y; var newStance = (Stance)order.TargetLocation.Y;

View File

@@ -76,6 +76,7 @@ namespace OpenRA
Color = client.Color1; Color = client.Color1;
Color2 = client.Color2; Color2 = client.Color2;
PlayerName = client.Name; PlayerName = client.Name;
InternalName = pr.Name; InternalName = pr.Name;
Country = world.GetCountries() Country = world.GetCountries()
.FirstOrDefault(c => client != null && client.Country == c.Race) .FirstOrDefault(c => client != null && client.Country == c.Race)

View File

@@ -661,6 +661,11 @@ namespace OpenRA.Server
DispatchOrders(asConn, 0, new ServerOrder("Chat", text).Serialize()); DispatchOrders(asConn, 0, new ServerOrder("Chat", text).Serialize());
} }
static void SendDisconnected(Connection asConn)
{
DispatchOrders(asConn, 0, new ServerOrder("Disconnected", "").Serialize());
}
static void InterpretServerOrder(Connection conn, ServerOrder so) static void InterpretServerOrder(Connection conn, ServerOrder so)
{ {
switch (so.Name) switch (so.Name)
@@ -681,6 +686,7 @@ namespace OpenRA.Server
case "Chat": case "Chat":
case "TeamChat": case "TeamChat":
case "Disconnected":
if (E(e => e.OnChat(conn, so.Data, so.Name == "TeamChat"))) if (E(e => e.OnChat(conn, so.Data, so.Name == "TeamChat")))
foreach (var c in conns.Except(conn).ToArray()) foreach (var c in conns.Except(conn).ToArray())
DispatchOrdersToClient(c, GetClient(conn).Index, 0, so.Serialize()); DispatchOrdersToClient(c, GetClient(conn).Index, 0, so.Serialize());
@@ -698,6 +704,9 @@ namespace OpenRA.Server
conns.Remove(toDrop); conns.Remove(toDrop);
SendChat(toDrop, "Connection Dropped"); SendChat(toDrop, "Connection Dropped");
if (GameStarted)
SendDisconnected(toDrop); /* Report disconnection */
lobbyInfo.Clients.RemoveAll(c => c.Index == toDrop.PlayerIndex); lobbyInfo.Clients.RemoveAll(c => c.Index == toDrop.PlayerIndex);
DispatchOrders( toDrop, toDrop.MostRecentFrame, new byte[] { 0xbf } ); DispatchOrders( toDrop, toDrop.MostRecentFrame, new byte[] { 0xbf } );

View File

@@ -84,6 +84,7 @@
<Compile Include="AttackMove.cs" /> <Compile Include="AttackMove.cs" />
<Compile Include="Buildable.cs" /> <Compile Include="Buildable.cs" />
<Compile Include="Combat.cs" /> <Compile Include="Combat.cs" />
<Compile Include="Player\SurrenderOnDisconnect.cs" />
<Compile Include="Crates\CloakCrateAction.cs" /> <Compile Include="Crates\CloakCrateAction.cs" />
<Compile Include="Crates\GiveMcvCrateAction.cs" /> <Compile Include="Crates\GiveMcvCrateAction.cs" />
<Compile Include="Crates\GiveUnitCrateAction.cs" /> <Compile Include="Crates\GiveUnitCrateAction.cs" />

View File

@@ -0,0 +1,44 @@
#region Copyright & License Information
/*
* Copyright 2007-2010 The OpenRA Developers (see AUTHORS)
* This file is part of OpenRA, which is free software. It is made
* available to you under the terms of the GNU General Public License
* as published by the Free Software Foundation. For more information,
* see LICENSE.
*/
#endregion
using OpenRA.Network;
using OpenRA.Traits;
namespace OpenRA.Mods.RA
{
class SurrenderOnDisconnectInfo : TraitInfo<SurrenderOnDisconnect>
{
}
class SurrenderOnDisconnect : ITick
{
private bool Disconnected = false;
public void Tick(Actor self)
{
if (Disconnected) return;
var p = self.Owner;
if (p.WinState == WinState.Lost || p.WinState == WinState.Won) return; /* already won or lost */
var client = p.World.LobbyInfo.ClientWithIndex(p.ClientIndex);
if (client == null)
return;
if (client.State == Session.ClientState.Disconnected)
{
Disconnected = true; /* dont call this multiple times! */
self.World.IssueOrder(new Order("Surrender", self));
}
}
}
}

View File

@@ -68,7 +68,7 @@ Player:
PlayerColorPalette: PlayerColorPalette:
BasePalette: terrain BasePalette: terrain
PaletteFormat: cnc PaletteFormat: cnc
SurrenderOnDisconnect:
World: World:
OpenWidgetAtGameStart: OpenWidgetAtGameStart:
Widget: INGAME_ROOT Widget: INGAME_ROOT

View File

@@ -124,6 +124,7 @@ Player:
3tnk: 0% 3tnk: 0%
PlayerColorPalette: PlayerColorPalette:
BasePalette: terrain BasePalette: terrain
SurrenderOnDisconnect:
World: World:
OpenWidgetAtGameStart: OpenWidgetAtGameStart: