mirror of
https://github.com/goatcorp/Dalamud.git
synced 2026-02-23 16:27:44 +01:00
Compare commits
3 commits
e3498f1b9c
...
7aa77aa2eb
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7aa77aa2eb | ||
|
|
7f3fc5aac1 | ||
|
|
852b1289e2 |
3 changed files with 7 additions and 6 deletions
|
|
@ -38,7 +38,7 @@ internal sealed class ClientState : IInternalDisposableService, IClientState
|
||||||
private readonly ClientStateAddressResolver address;
|
private readonly ClientStateAddressResolver address;
|
||||||
private readonly Hook<EventFramework.Delegates.SetTerritoryTypeId> setupTerritoryTypeHook;
|
private readonly Hook<EventFramework.Delegates.SetTerritoryTypeId> setupTerritoryTypeHook;
|
||||||
private readonly Hook<UIModule.Delegates.HandlePacket> uiModuleHandlePacketHook;
|
private readonly Hook<UIModule.Delegates.HandlePacket> uiModuleHandlePacketHook;
|
||||||
private readonly Hook<LogoutCallbackInterface.Delegates.OnLogout> onLogoutHook;
|
private Hook<LogoutCallbackInterface.Delegates.OnLogout> onLogoutHook;
|
||||||
|
|
||||||
[ServiceManager.ServiceDependency]
|
[ServiceManager.ServiceDependency]
|
||||||
private readonly Framework framework = Service<Framework>.Get();
|
private readonly Framework framework = Service<Framework>.Get();
|
||||||
|
|
@ -64,14 +64,12 @@ internal sealed class ClientState : IInternalDisposableService, IClientState
|
||||||
|
|
||||||
this.setupTerritoryTypeHook = Hook<EventFramework.Delegates.SetTerritoryTypeId>.FromAddress(setTerritoryTypeAddr, this.SetupTerritoryTypeDetour);
|
this.setupTerritoryTypeHook = Hook<EventFramework.Delegates.SetTerritoryTypeId>.FromAddress(setTerritoryTypeAddr, this.SetupTerritoryTypeDetour);
|
||||||
this.uiModuleHandlePacketHook = Hook<UIModule.Delegates.HandlePacket>.FromAddress((nint)UIModule.StaticVirtualTablePointer->HandlePacket, this.UIModuleHandlePacketDetour);
|
this.uiModuleHandlePacketHook = Hook<UIModule.Delegates.HandlePacket>.FromAddress((nint)UIModule.StaticVirtualTablePointer->HandlePacket, this.UIModuleHandlePacketDetour);
|
||||||
this.onLogoutHook = Hook<LogoutCallbackInterface.Delegates.OnLogout>.FromAddress((nint)LogoutCallbackInterface.StaticVirtualTablePointer->OnLogout, this.OnLogoutDetour);
|
|
||||||
|
|
||||||
this.framework.Update += this.FrameworkOnOnUpdateEvent;
|
this.framework.Update += this.FrameworkOnOnUpdateEvent;
|
||||||
this.networkHandlers.CfPop += this.NetworkHandlersOnCfPop;
|
this.networkHandlers.CfPop += this.NetworkHandlersOnCfPop;
|
||||||
|
|
||||||
this.setupTerritoryTypeHook.Enable();
|
this.setupTerritoryTypeHook.Enable();
|
||||||
this.uiModuleHandlePacketHook.Enable();
|
this.uiModuleHandlePacketHook.Enable();
|
||||||
this.onLogoutHook.Enable();
|
|
||||||
|
|
||||||
this.framework.RunOnTick(this.Setup);
|
this.framework.RunOnTick(this.Setup);
|
||||||
}
|
}
|
||||||
|
|
@ -184,6 +182,9 @@ internal sealed class ClientState : IInternalDisposableService, IClientState
|
||||||
|
|
||||||
private unsafe void Setup()
|
private unsafe void Setup()
|
||||||
{
|
{
|
||||||
|
this.onLogoutHook = Hook<LogoutCallbackInterface.Delegates.OnLogout>.FromAddress((nint)AgentLobby.Instance()->LogoutCallbackInterface.VirtualTable->OnLogout, this.OnLogoutDetour);
|
||||||
|
this.onLogoutHook.Enable();
|
||||||
|
|
||||||
this.TerritoryType = (ushort)GameMain.Instance()->CurrentTerritoryTypeId;
|
this.TerritoryType = (ushort)GameMain.Instance()->CurrentTerritoryTypeId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -415,13 +415,13 @@ internal sealed unsafe class ChatGui : IInternalDisposableService, IChatGui
|
||||||
|
|
||||||
if (!terminatedSender.SequenceEqual(possiblyModifiedSenderData))
|
if (!terminatedSender.SequenceEqual(possiblyModifiedSenderData))
|
||||||
{
|
{
|
||||||
Log.Verbose($"HandlePrintMessageDetour Sender modified: {SeString.Parse(terminatedSender)} -> {parsedSender}");
|
Log.Verbose($"HandlePrintMessageDetour Sender modified: {new ReadOnlySeStringSpan(terminatedSender).ToMacroString()} -> {new ReadOnlySeStringSpan(possiblyModifiedSenderData).ToMacroString()}");
|
||||||
sender->SetString(possiblyModifiedSenderData);
|
sender->SetString(possiblyModifiedSenderData);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!terminatedMessage.SequenceEqual(possiblyModifiedMessageData))
|
if (!terminatedMessage.SequenceEqual(possiblyModifiedMessageData))
|
||||||
{
|
{
|
||||||
Log.Verbose($"HandlePrintMessageDetour Message modified: {SeString.Parse(terminatedMessage)} -> {parsedMessage}");
|
Log.Verbose($"HandlePrintMessageDetour Message modified: {new ReadOnlySeStringSpan(terminatedMessage).ToMacroString()} -> {new ReadOnlySeStringSpan(possiblyModifiedMessageData).ToMacroString()}");
|
||||||
message->SetString(possiblyModifiedMessageData);
|
message->SetString(possiblyModifiedMessageData);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1 +1 @@
|
||||||
Subproject commit 4fbd01f1b1c4ac740f2b6e64ad5efcad10d227a0
|
Subproject commit 834d3cc94082fd812cf6cda8da217b22e4f9f15d
|
||||||
Loading…
Add table
Add a link
Reference in a new issue