public static void StartGameService(IPAddress IP, GameSettings setting, int roomId, GameEndCallback callback, out int portNumber) { int totalNumberOfPlayers = setting.TotalPlayers; int timeOutSeconds = setting.TimeOutSeconds; #if DEBUG Trace.Listeners.Clear(); TextWriterTraceListener twtl = new TextWriterTraceListener(Path.Combine(Directory.GetCurrentDirectory(), AppDomain.CurrentDomain.FriendlyName + DateTime.Now.Hour.ToString() + DateTime.Now.Minute.ToString() + DateTime.Now.Second.ToString() + ".txt")); twtl.Name = "TextLogger"; twtl.TraceOutputOptions = TraceOptions.ThreadId | TraceOptions.DateTime; ConsoleTraceListener ctl = new ConsoleTraceListener(false); ctl.TraceOutputOptions = TraceOptions.DateTime; Trace.Listeners.Add(twtl); Trace.Listeners.Add(ctl); Trace.AutoFlush = true; Trace.WriteLine("Log starting"); Trace.Listeners.Add(new ConsoleTraceListener()); #endif Game game = new RoleGame(); game.Settings = setting; Sanguosha.Core.Network.Server server; server = new Sanguosha.Core.Network.Server(game, totalNumberOfPlayers, IP); portNumber = server.IpPort; for (int i = 0; i < totalNumberOfPlayers; i++) { var player = new Player(); player.Id = i; game.Players.Add(player); IUiProxy proxy; proxy = new ServerNetworkUiProxy(server, i); proxy.TimeOutSeconds = timeOutSeconds; proxy.HostPlayer = player; game.UiProxies.Add(player, proxy); } GlobalServerUiProxy pxy = new GlobalServerUiProxy(game, game.UiProxies); pxy.TimeOutSeconds = timeOutSeconds; game.GlobalProxy = pxy; game.NotificationProxy = new DummyNotificationProxy(); foreach (var g in GameEngine.Expansions.Values) { game.LoadExpansion(g); } game.GameServer = server; var thread = new Thread(() => { game.Run(); callback(roomId); }) { IsBackground = true }; thread.Start(); }
static void Main(string[] args) { Trace.Listeners.Clear(); TextWriterTraceListener twtl = new TextWriterTraceListener(Path.Combine(Directory.GetCurrentDirectory(), AppDomain.CurrentDomain.FriendlyName + DateTime.Now.Hour.ToString() + DateTime.Now.Minute.ToString() + DateTime.Now.Second.ToString() + ".txt")); twtl.Name = "TextLogger"; twtl.TraceOutputOptions = TraceOptions.ThreadId | TraceOptions.DateTime; ConsoleTraceListener ctl = new ConsoleTraceListener(false); ctl.TraceOutputOptions = TraceOptions.DateTime; Trace.Listeners.Add(twtl); Trace.Listeners.Add(ctl); Trace.AutoFlush = true; Trace.WriteLine("Log starting"); Trace.Listeners.Add(new ConsoleTraceListener()); Game game = new RoleGame(1); Server server; server = new Server(game, totalNumberOfPlayers); for (int i = 0; i < totalNumberOfPlayers; i++) { var player = new Player(); player.Id = i; game.Players.Add(player); IUiProxy proxy; proxy = new ServerNetworkUiProxy(server, i); proxy.TimeOutSeconds = timeOutSeconds; proxy.HostPlayer = player; game.UiProxies.Add(player, proxy); } GlobalServerUiProxy pxy = new GlobalServerUiProxy(game, game.UiProxies); pxy.TimeOutSeconds = timeOutSeconds; game.GlobalProxy = pxy; game.NotificationProxy = new DummyNotificationProxy(); GameEngine.LoadExpansions("./"); foreach (var g in GameEngine.Expansions.Values) { game.LoadExpansion(g); } game.GameServer = server; game.Run(); }