Some improvements ..

This commit is contained in:
Li 2022-11-20 15:33:36 +13:00
parent 1909950409
commit d630abb66a
11 changed files with 51 additions and 39 deletions

View file

@ -46,12 +46,14 @@ namespace HISP.Cli
{ {
if(fs != null) if(fs != null)
{ {
fs.Flush();
fs.Close(); fs.Close();
fs.Dispose(); fs.Dispose();
fs = null; fs = null;
} }
if(sw != null) if(sw != null)
{ {
sw.Flush();
sw.Close(); sw.Close();
sw.Dispose(); sw.Dispose();
sw = null; sw = null;
@ -81,25 +83,27 @@ namespace HISP.Cli
{ {
if (type == "CRASH") if (type == "CRASH")
LogToFile(error, type, text); LogToFile(error, type, text);
try
if (error) {
Console.Error.WriteAsync(formatMessage(type, text)); if (error)
else Console.Error.WriteAsync(formatMessage(type, text));
Console.Out.WriteAsync(formatMessage(type, text)); else
Console.Out.WriteAsync(formatMessage(type, text));
}
catch (Exception) { };
} }
public static void Main(string[] args) public static void Main(string[] args)
{ {
AppDomain.CurrentDomain.ProcessExit += ProcessQuitHandler; AppDomain.CurrentDomain.ProcessExit += ProcessQuitHandler;
string BaseDir = Directory.GetCurrentDirectory(); string baseDir = Directory.GetCurrentDirectory();
Logger.SetCallback(LogStdout); Logger.SetCallback(LogStdout);
Entry.SetShutdownCallback(OnShutdown); Entry.SetShutdownCallback(OnShutdown);
string HispConfVar = Environment.GetEnvironmentVariable("HISP_CONF_FILE"); string hispConfVar = Environment.GetEnvironmentVariable("HISP_CONF_FILE");
string HispLogVar = Environment.GetEnvironmentVariable("HISP_LOG_FILE"); string hispLogVar = Environment.GetEnvironmentVariable("HISP_LOG_FILE");
string HispBaseDir = Environment.GetEnvironmentVariable("HISP_BASE_DIR"); string hispBaseDir = Environment.GetEnvironmentVariable("HISP_BASE_DIR");
foreach (string arg in args) foreach (string arg in args)
{ {
@ -129,8 +133,8 @@ namespace HISP.Cli
Logger.SetCallback(LogToFile); Logger.SetCallback(LogToFile);
break; break;
case "--base-directory": case "--base-directory":
BaseDir = argu[1]; baseDir = argu[1];
Directory.SetCurrentDirectory(BaseDir); Directory.SetCurrentDirectory(baseDir);
break; break;
default: default:
continue; continue;
@ -141,25 +145,25 @@ namespace HISP.Cli
} }
} }
if (HispConfVar != null) if (hispConfVar != null)
{ {
ConfigReader.ConfigurationFileName = HispConfVar; ConfigReader.ConfigurationFileName = hispConfVar;
} }
if (HispLogVar != null) if (hispLogVar != null)
{ {
LogFile = HispLogVar; LogFile = hispLogVar;
Logger.SetCallback(LogToFile); Logger.SetCallback(LogToFile);
} }
else else
{ {
LogFile = Path.Combine(BaseDir, "crash.log"); LogFile = Path.Combine(baseDir, "crash.log");
} }
if (HispBaseDir != null) if (hispBaseDir != null)
{ {
BaseDir = HispBaseDir; baseDir = hispBaseDir;
Directory.SetCurrentDirectory(BaseDir); Directory.SetCurrentDirectory(baseDir);
} }
Entry.Start(); Entry.Start();
@ -170,7 +174,7 @@ namespace HISP.Cli
private static void ProcessQuitHandler(object sender, EventArgs e) private static void ProcessQuitHandler(object sender, EventArgs e)
{ {
GameServer.ShutdownServer(); GameServer.ShutdownServer("HISPd process quitting.");
} }
} }
} }

View file

@ -31,5 +31,5 @@ using System.Runtime.InteropServices;
// You can specify all the values or you can default the Build and Revision Numbers // You can specify all the values or you can default the Build and Revision Numbers
// by using the '*' as shown below: // by using the '*' as shown below:
// [assembly: AssemblyVersion("1.0.*")] // [assembly: AssemblyVersion("1.0.*")]
[assembly: AssemblyVersion("1.8.55.0")] [assembly: AssemblyVersion("1.8.56.0")]
[assembly: AssemblyFileVersion("1.8.55.0")] [assembly: AssemblyFileVersion("1.8.56.0")]

View file

@ -1,5 +1,5 @@
Package: hisp Package: hisp
Version: 1.8.55 Version: 1.8.56
Depends: coreutils,systemd,mariadb-server,libsqlite3-dev,zlib1g-dev,libicu-dev,libkrb5-dev Depends: coreutils,systemd,mariadb-server,libsqlite3-dev,zlib1g-dev,libicu-dev,libkrb5-dev
Maintainer: Li Maintainer: Li
Homepage: https://islehorse.com Homepage: https://islehorse.com

View file

@ -92,7 +92,8 @@ namespace HISP.Game.Chat
byte[] chatPacket = PacketBuilder.CreateChat(Messages.FormatAdminCommandCompleteMessage(message), PacketBuilder.CHAT_BOTTOM_LEFT); byte[] chatPacket = PacketBuilder.CreateChat(Messages.FormatAdminCommandCompleteMessage(message), PacketBuilder.CHAT_BOTTOM_LEFT);
user.LoggedinClient.SendPacket(chatPacket); user.LoggedinClient.SendPacket(chatPacket);
GameServer.ShutdownServer();
GameServer.ShutdownServer("Administrator initiated");
return true; return true;
} }

View file

@ -24,7 +24,7 @@ namespace HISP.Game.Services
if (Item.ItemIdExist(stock)) if (Item.ItemIdExist(stock))
this.Inventory.AddInfinity(Item.GetItemById(stock)); this.Inventory.AddInfinity(Item.GetItemById(stock));
else else
Logger.WarnPrint("Item ID: " + stock + " Does not exist."); Logger.WarnPrint("Item ID: " + stock + " doesn't exist, but shop " + id + " stocks it");
} }
ItemInstance[] instances = Database.GetShopInventory(this.Id); ItemInstance[] instances = Database.GetShopInventory(this.Id);

View file

@ -30,8 +30,8 @@ using System.Runtime.InteropServices;
// //
// You can specify all the values or you can default the Build and Revision Numbers // You can specify all the values or you can default the Build and Revision Numbers
// by using the '*' as shown below: // by using the '*' as shown below:
[assembly: AssemblyVersion("1.8.55.0")] [assembly: AssemblyVersion("1.8.56.0")]
[assembly: AssemblyFileVersion("1.8.55.0")] [assembly: AssemblyFileVersion("1.8.56.0")]

View file

@ -1,7 +1,6 @@
using System; using System;
using System.Net.Sockets; using System.Net.Sockets;
using System.Threading; using System.Threading;
using System.Collections.Generic;
using HISP.Player; using HISP.Player;
using HISP.Game; using HISP.Game;
using HISP.Game.Horse; using HISP.Game.Horse;
@ -9,7 +8,6 @@ using HISP.Game.Events;
using HISP.Game.Items; using HISP.Game.Items;
using HISP.Util; using HISP.Util;
using HISP.Server.Network; using HISP.Server.Network;
using System.Net;
namespace HISP.Server namespace HISP.Server
{ {
@ -83,7 +81,7 @@ namespace HISP.Server
} }
public static void OnShutdown() public static void OnShutdown(string reason)
{ {
try try
{ {
@ -101,8 +99,7 @@ namespace HISP.Server
client.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.GameUpdates).Count++; client.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.GameUpdates).Count++;
Logger.DebugPrint("Kicking: " + client.LoggedinUser.Username); Logger.DebugPrint("Kicking: " + client.LoggedinUser.Username);
} }
client.Kick("Server shutdown."); client.Kick("Server shutdown: "+reason);
} }
} }
catch (Exception) { }; catch (Exception) { };

View file

@ -416,7 +416,9 @@ namespace HISP.Server
if (gameData.quest_list[i].chained_questid != null) if (gameData.quest_list[i].chained_questid != null)
quest.ChainedQuestId = gameData.quest_list[i].chained_questid; quest.ChainedQuestId = gameData.quest_list[i].chained_questid;
quest.Minigame = gameData.quest_list[i].minigame; quest.Minigame = gameData.quest_list[i].minigame;
Logger.DebugPrint("Registered Quest: " + quest.Id + " - " + quest.Title);
if(quest.Title.Trim() != "")
Logger.DebugPrint("Registered Quest: " + quest.Id + " - " + quest.Title);
Quest.AddQuestEntry(quest); Quest.AddQuestEntry(quest);
} }

View file

@ -8240,12 +8240,12 @@ namespace HISP.Server
if (minuteTimer != null) if (minuteTimer != null)
minuteTimer.Dispose(); minuteTimer.Dispose();
} }
public static void ShutdownServer() public static void ShutdownServer(string shutdownReason = "No reason provided.")
{ {
Logger.InfoPrint("Server shutting down."); Logger.InfoPrint("Server shutting down; " + shutdownReason);
try try
{ {
GameClient.OnShutdown(); GameClient.OnShutdown(shutdownReason);
GameServer.OnShutdown(); GameServer.OnShutdown();
Database.OnShutdown(); Database.OnShutdown();
} }

View file

@ -11,6 +11,14 @@ namespace HISP.Server
private static Action<bool, string, string> logFunction = defaultCallbackFunc; private static Action<bool, string, string> logFunction = defaultCallbackFunc;
private void log(bool error, string type, string text)
{
string[] msgs = text.Replace("\r", "").Split("\n");
foreach(string msg in msgs)
{
logFunction(error, type, msg);
}
}
public static void SetCallback(Action<bool, string, string> callback) public static void SetCallback(Action<bool, string, string> callback)
{ {

View file

@ -30,8 +30,8 @@ using System.Runtime.InteropServices;
// //
// You can specify all the values or you can default the Build and Revision Numbers // You can specify all the values or you can default the Build and Revision Numbers
// by using the '*' as shown below: // by using the '*' as shown below:
[assembly: AssemblyVersion("1.8.55.0")] [assembly: AssemblyVersion("1.8.56.0")]
[assembly: AssemblyFileVersion("1.8.55.0")] [assembly: AssemblyFileVersion("1.8.56.0")]