-
-
Notifications
You must be signed in to change notification settings - Fork 6
API and customizations
Emanuele Manzione edited this page Apr 26, 2020
·
24 revisions
You can implement your own downloader for your Launcher, if needed. Just implement IDownloader
interface in your own class as following:
public sealed class MyDownloader : MHLab.Patch.Core.Client.IO.IDownloader
{
// The code to implement IDownloader
}
then inject it into the Updater/Repairer/PatcherUpdater:
// This is taken from Launcher.cs, Initialize method.
_updater = new Updater(_context);
_updater.Downloader.DownloadComplete += DownloadComplete;
_updater.Downloader.ProgressChanged += DownloadProgressChanged;
You can implement your own logger for your Launcher, if needed. Just implement ILogger
interface in your own class as following:
public sealed class MyLogger : MHLab.Patch.Core.Loggers.ILogger
{
// The code to implement ILogger
}
then inject it into the UpdatingContext:
// This is taken from Launcher.cs, Initialize method.
_context = new UpdatingContext(settings, progress);
_context.Logger = new MyLogger();
Normally the Launcher sample script automatically starts the updating process, but for your convenience (and for customization purposes) some methods are exposed.
var repairer = new Repairer(_context);
repairer.IsRepairNeeded();
// It will return true if a repair is needed
var updater = new Updater(_context);
updater.IsUpdateAvailable();
// It will return true if a patch is available
Also, the UpdatingContext
has the IsDirty
property: you can check if it is set on true. If it is, a restart is recommended.
If you call those methods before the UpdatingContext's
Initialize
, you will get an exception.