mirror of
https://github.com/Tyrrrz/DiscordChatExporter.git
synced 2026-02-15 00:03:38 -07:00
[CLI] Cleanup
This commit is contained in:
parent
58464d8708
commit
1b8af364d3
|
|
@ -13,7 +13,6 @@ using DiscordChatExporter.Core.Discord.Data;
|
|||
using DiscordChatExporter.Core.Exceptions;
|
||||
using DiscordChatExporter.Core.Exporting;
|
||||
using DiscordChatExporter.Core.Utils.Extensions;
|
||||
using Spectre.Console;
|
||||
using Tyrrrz.Extensions;
|
||||
|
||||
namespace DiscordChatExporter.Cli.Commands.Base
|
||||
|
|
@ -63,6 +62,8 @@ namespace DiscordChatExporter.Cli.Commands.Base
|
|||
{
|
||||
// Export
|
||||
try
|
||||
{
|
||||
await progressContext.StartTaskAsync($"{channel.Category} / {channel.Name}", async progress =>
|
||||
{
|
||||
var guild = await Discord.GetGuildAsync(channel.GuildId);
|
||||
|
||||
|
|
@ -79,31 +80,20 @@ namespace DiscordChatExporter.Cli.Commands.Base
|
|||
DateFormat
|
||||
);
|
||||
|
||||
var progress = progressContext.AddTask(
|
||||
$"{channel.Category} / {channel.Name}",
|
||||
new ProgressTaskSettings {MaxValue = 1}
|
||||
);
|
||||
|
||||
try
|
||||
{
|
||||
await Exporter.ExportChannelAsync(request, progress);
|
||||
}
|
||||
finally
|
||||
{
|
||||
progress.StopTask();
|
||||
}
|
||||
});
|
||||
}
|
||||
catch (DiscordChatExporterException ex) when (!ex.IsCritical)
|
||||
{
|
||||
errors[channel] = ex.Message;
|
||||
}
|
||||
}, ParallelLimit.ClampMin(1));
|
||||
|
||||
await console.Output.WriteLineAsync();
|
||||
});
|
||||
|
||||
await console.Output.WriteLineAsync();
|
||||
|
||||
// Print result
|
||||
using (console.WithForegroundColor(ConsoleColor.Green))
|
||||
using (console.WithForegroundColor(ConsoleColor.White))
|
||||
{
|
||||
await console.Output.WriteLineAsync(
|
||||
$"Successfully exported {channels.Count - errors.Count} channel(s)."
|
||||
|
|
@ -116,7 +106,11 @@ namespace DiscordChatExporter.Cli.Commands.Base
|
|||
await console.Output.WriteLineAsync();
|
||||
|
||||
using (console.WithForegroundColor(ConsoleColor.Red))
|
||||
await console.Output.WriteLineAsync($"Failed to export {errors.Count} channel(s):");
|
||||
{
|
||||
await console.Output.WriteLineAsync(
|
||||
$"Failed to export {errors.Count} channel(s):"
|
||||
);
|
||||
}
|
||||
|
||||
foreach (var (channel, error) in errors)
|
||||
{
|
||||
|
|
@ -143,7 +137,7 @@ namespace DiscordChatExporter.Cli.Commands.Base
|
|||
{
|
||||
if (ShouldReuseMedia && !ShouldDownloadMedia)
|
||||
{
|
||||
throw new CommandException("The --reuse-media option cannot be used without the --media option.");
|
||||
throw new CommandException("Option --reuse-media cannot be used without --media.");
|
||||
}
|
||||
|
||||
return default;
|
||||
|
|
|
|||
|
|
@ -1,4 +1,6 @@
|
|||
using CliFx.Infrastructure;
|
||||
using System;
|
||||
using System.Threading.Tasks;
|
||||
using CliFx.Infrastructure;
|
||||
using Spectre.Console;
|
||||
|
||||
namespace DiscordChatExporter.Cli.Utils.Extensions
|
||||
|
|
@ -34,5 +36,22 @@ namespace DiscordChatExporter.Cli.Utils.Extensions
|
|||
new ProgressBarColumn(),
|
||||
new PercentageColumn()
|
||||
});
|
||||
|
||||
public static async ValueTask StartTaskAsync(
|
||||
this ProgressContext progressContext,
|
||||
string description,
|
||||
Func<ProgressTask, ValueTask> performOperationAsync)
|
||||
{
|
||||
var progressTask = progressContext.AddTask(description, new ProgressTaskSettings {MaxValue = 1});
|
||||
|
||||
try
|
||||
{
|
||||
await performOperationAsync(progressTask);
|
||||
}
|
||||
finally
|
||||
{
|
||||
progressTask.StopTask();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Reference in a new issue