Files
CustomizeTool/CustomizePlus/Plugin.cs
2025-07-30 19:10:04 +03:00

57 lines
1.6 KiB
C#

using System;
using CustomizePlus.Api;
using CustomizePlus.Core;
using CustomizePlus.Core.Helpers;
using CustomizePlus.Core.Services;
using CustomizePlus.UI;
using Dalamud.Game.ClientState.Objects;
using Dalamud.IoC;
using Dalamud.Plugin;
using ECommonsLite;
using OtterGui.Log;
using OtterGui.Services;
using Penumbra.GameData.Actors;
namespace CustomizePlus;
public sealed class Plugin : IDalamudPlugin
{
private readonly ServiceManager _services;
[PluginService] public static ITargetManager TargetManager { get; private set; } = null!;
public static readonly Logger Logger = new(); //for loggin in static classes/methods
public Plugin(IDalamudPluginInterface pluginInterface)
{
try
{
ECommonsLiteMain.Init(pluginInterface, this);
_services = ServiceManagerBuilder.CreateProvider(pluginInterface, Logger);
_services.GetService<ActorManager>(); //needs to be initialized early for config to be read properly
_services.GetService<UserNotifierService>();
_services.GetService<CustomizePlusIpc>();
_services.GetService<CPlusWindowSystem>();
_services.GetService<CommandService>();
Logger.Information($"Customize+ {VersionHelper.Version} ({ThisAssembly.Git.Commit}+{ThisAssembly.Git.Sha}) [FantasiaPlus] started");
}
catch (Exception ex)
{
Logger.Error($"Error instantiating plugin: {ex}");
Dispose();
throw;
}
}
public void Dispose()
{
_services?.Dispose();
ECommonsLiteMain.Dispose();
}
}