Fix npc chat? ???

This commit is contained in:
SilicaAndPina 2022-04-18 10:08:44 +12:00
parent dbbf913719
commit ea544dcbe1
7 changed files with 43 additions and 22 deletions

@ -1 +1 @@
Subproject commit 69e6a3393d1fe41986a92c489a43ea6d920786df
Subproject commit c872d4a508e1514f302c6b3eac98c91db2d125d7

View file

@ -2559,17 +2559,15 @@ namespace HISP.Game
if (result.GotoChatpoint != -1)
chatpoint = Npc.GetNpcChatpoint(npc, result.GotoChatpoint);
if (chatpoint.ChatText.Trim() == "")
if (result.NpcChat != null)
if(result.NpcChat.Trim() != "")
chatpoint.ChatText = result.NpcChat;
if (result.NpcChat != null && result.NpcChat.Trim() != "")
chatpoint.ChatText = result.NpcChat;
}
else
{
if (result.GotoChatpoint != -1)
chatpoint = Npc.GetNpcChatpoint(npc, result.GotoChatpoint);
if (result.NpcChat != null)
if (result.NpcChat != null && result.NpcChat.Trim() != "")
chatpoint.ChatText = result.NpcChat;
if (result.HideRepliesOnFail)

View file

@ -219,7 +219,7 @@ namespace HISP.Game
res.QuestCompleted = true;
if (npcActivation)
{
if (quest.SuccessNpcChat != null && quest.SuccessNpcChat != "")
if (quest.SuccessNpcChat != null && quest.SuccessNpcChat.Trim() != "")
res.NpcChat = quest.SuccessNpcChat;
if(quest.SetNpcChatpoint != -1)
@ -241,7 +241,7 @@ namespace HISP.Game
user.LoggedinClient.SendPacket(ChatPacket);
}
if (quest.SuccessNpcChat != null)
if (quest.SuccessNpcChat != null && quest.SuccessNpcChat.Trim() != "")
{
if (!npcActivation)
{

View file

@ -14,14 +14,16 @@
</Compile>
</ItemGroup>
<ItemGroup>
<ContentWithTargetPath Include="..\..\HorseIsleData\gamedata.json">
<ContentWithTargetPath Include="..\..\HorseIsleData\gamedata\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
<TargetPath>gamedata.json</TargetPath>
<CopyToPublishDirectory>PreserveNewest</CopyToPublishDirectory>
<TargetPath>gamedata\%(Filename)%(Extension)</TargetPath>
</ContentWithTargetPath>
</ItemGroup>
<ItemGroup>
<ContentWithTargetPath Include="..\..\HorseIsleData\HI1.MAP">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
<CopyToPublishDirectory>PreserveNewest</CopyToPublishDirectory>
<TargetPath>HI1.MAP</TargetPath>
</ContentWithTargetPath>
</ItemGroup>

View file

@ -30,9 +30,10 @@ sql_lite=false
# the default was downloaded from the original server
map=HI1.MAP
# This file contains all definitions in the game
# This folder contains all definitions in the game
# such as items, horses. and quest data.
gamedata=gamedata.json
# NOTE: This can be a folder or a file.
gamedata=gamedata
# =======================
# Security

View file

@ -18,7 +18,7 @@ namespace HISP.Server
public static int IntrestRate = 3333;
public static string Motd = "April 11, 2020. New breed, Camarillo White Horse. Two new quests.";
public static string MapFile = "HI1.MAP";
public static string GameDataFile = "gamedata.json";
public static string GameData = "gamedata.json";
public static string CrossDomainPolicyFile = "CrossDomainPolicy.xml";
public static int LogLevel = 4;
@ -92,7 +92,7 @@ namespace HISP.Server
Motd = data;
break;
case "gamedata":
GameDataFile = data;
GameData = data;
break;
case "crossdomain":
CrossDomainPolicyFile = data;

View file

@ -12,21 +12,41 @@ using System.Globalization;
using HISP.Security;
using System;
using HISP.Game.Events;
using System.Dynamic;
using Newtonsoft.Json.Linq;
namespace HISP.Server
{
public class GameDataJson
{
public static void ReadGamedata()
{
if (!File.Exists(ConfigReader.GameDataFile))
{
Logger.ErrorPrint("Game Data JSON File: " + ConfigReader.GameDataFile + " Does not exist!");
throw new FileNotFoundException(ConfigReader.GameDataFile + " Not found :(");
dynamic gameData;
if (Directory.Exists(ConfigReader.GameData))
{
gameData = new JObject();
string[] files = Directory.GetFiles(ConfigReader.GameData);
foreach(string file in files)
{
string jsonData = File.ReadAllText(file);
JObject thisData = (JObject)JsonConvert.DeserializeObject(jsonData);
JObject jData = (JObject)gameData;
jData.Merge(thisData);
}
}
string jsonData = File.ReadAllText(ConfigReader.GameDataFile);
dynamic gameData = JsonConvert.DeserializeObject(jsonData);
else if (File.Exists(ConfigReader.GameData))
{
string jsonData = File.ReadAllText(ConfigReader.GameData);
gameData = JsonConvert.DeserializeObject(jsonData);
}
else
{
Logger.ErrorPrint("Game Data : " + ConfigReader.GameData + " Does not exist!");
GameServer.ShutdownServer();
return;
}
// Register Towns
int totalTowns = gameData.places.towns.Count;