first push
continuous-integration/drone/push Build is passing Details

lastBranch
Rami KHEDAIR 2 years ago
parent 94d79627be
commit 9ed29c5f21

@ -62,17 +62,16 @@ public class PongServer
Console.WriteLine("Connection " + choisenRoom.Key); Console.WriteLine("Connection " + choisenRoom.Key);
if (choisenRoom.Value != default ) if (choisenRoom.Value != default )
{ {
Thread join = new Thread(() => Join(data, remoteEndPoint, serverSocket, choisenRoom.Value)); Join(data, remoteEndPoint, serverSocket, choisenRoom.Value);
join.Start();
} }
else else
{ {
Thread host = new Thread(() => Host(data, remoteEndPoint, serverSocket, true)); Host(data, remoteEndPoint, serverSocket, true);
host.Start();
} }
} }
Console.WriteLine("");
} }
@ -80,11 +79,22 @@ public class PongServer
private void Host(ObjectTransfert<Player> data, IPEndPoint remoteEndPoint, UdpClient serverSocket, bool availaible) private void Host(ObjectTransfert<Player> data, IPEndPoint remoteEndPoint, UdpClient serverSocket, bool availaible)
{ {
var choisenRoom = rooms.FirstOrDefault(room => room.Value.Free);
var chosenPort = nextPort;
if (choisenRoom.Value != default)
{
chosenPort= choisenRoom.Value.Port;
choisenRoom.Value.playerHost.Value.Close();
choisenRoom.Value.playerJoin.Value.Close();
rooms.Remove(choisenRoom.Key);
choisenRoom = default;
}
Room room = new Room(data.Data.playerId, availaible); Room room = new Room(data.Data.playerId, availaible);
// Assign a unique port to the client // Assign a unique port to the client
IPEndPoint clientEndPoint = new IPEndPoint(IPAddress.Any, nextPort); IPEndPoint clientEndPoint = new IPEndPoint(IPAddress.Any, chosenPort);
UdpClient clientSocket = new UdpClient(clientEndPoint); UdpClient clientSocket = new UdpClient(clientEndPoint);
room.playerHost = new KeyValuePair<Player,UdpClient>(data.Data,clientSocket); room.playerHost = new KeyValuePair<Player,UdpClient>(data.Data,clientSocket);
@ -95,8 +105,12 @@ public class PongServer
Console.WriteLine("New connection Host From " + remoteEndPoint.ToString()); Console.WriteLine("New connection Host From " + remoteEndPoint.ToString());
room.Port = nextPort; room.Port = chosenPort;
nextPort++; if(chosenPort==nextPort)
{
nextPort++;
}
Tuple<int, bool> dataToSend = new Tuple<int, bool>(room.Port, true); Tuple<int, bool> dataToSend = new Tuple<int, bool>(room.Port, true);
@ -107,7 +121,7 @@ public class PongServer
serverSocket.Send(connectionData, connectionData.Length, remoteEndPoint); serverSocket.Send(connectionData, connectionData.Length, remoteEndPoint);
rooms[data.Data.playerId] = room; rooms[data.Data.playerId] = room;
room.PropertyChanged += room.OnReadyChanged;
Console.WriteLine("FIN HOST..............."); Console.WriteLine("FIN HOST...............");

@ -24,6 +24,8 @@ namespace Server
Tuple<int, int> ScoreImp = new(0, 0); Tuple<int, int> ScoreImp = new(0, 0);
public bool Availaible { get; set; } public bool Availaible { get; set; }
public bool Free { get; set; }=false;
public event PropertyChangedEventHandler? PropertyChanged; public event PropertyChangedEventHandler? PropertyChanged;
public string Id { get; set; } public string Id { get; set; }
@ -86,8 +88,14 @@ namespace Server
clientSocket2.Send(receivedData, receivedData.Length, endpoint2); clientSocket2.Send(receivedData, receivedData.Length, endpoint2);
semaphore.Release(); semaphore.Release();
} }
Availaible = true; Free = true;
/* playerHost = default;
playerJoin = default;
gameRunning = true;
ScoreImp = new(0, 0);*/
Console.WriteLine("Game Finished Am i host " + isHost); Console.WriteLine("Game Finished Am i host " + isHost);
} }
@ -102,10 +110,10 @@ namespace Server
gameRunning = false; gameRunning = false;
} }
public void OnReadyChanged(object sender, PropertyChangedEventArgs e) async public void OnReadyChanged(object sender, PropertyChangedEventArgs e)
{ {
/*Thread principal = new Thread(() => await Task.Run(() =>
{*/ {
Room room = sender as Room; Room room = sender as Room;
int maxPlayer = room.nbPlayer; int maxPlayer = room.nbPlayer;
@ -141,8 +149,8 @@ namespace Server
receiveThread2.Join(); receiveThread2.Join();
} }
/*}); });
principal.Start();*/
} }

Loading…
Cancel
Save