using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using static PKHeX.Core.MessageStrings;
namespace PKHeX.Core
{
public class BatchEditor
{
private int Modified { get; set; }
private int Iterated { get; set; }
private int Errored { get; set; }
///
/// Tries to modify the .
///
/// Object to modify.
/// Filters which must be satisfied prior to any modifications being made.
/// Modifications to perform on the .
/// Result of the attempted modification.
public bool ProcessPKM(PKM pkm, IEnumerable filters, IEnumerable modifications)
{
if (pkm.Species <= 0)
return false;
if (!pkm.Valid || pkm.Locked)
{
Iterated++;
var reason = pkm.Locked ? "Locked." : "Not Valid.";
Debug.WriteLine($"{MsgBEModifyFailBlocked} {reason}");
return false;
}
var r = BatchEditing.TryModifyPKM(pkm, filters, modifications);
if (r != ModifyResult.Invalid)
Iterated++;
if (r == ModifyResult.Error)
Errored++;
if (r != ModifyResult.Modified)
return false;
pkm.RefreshChecksum();
Modified++;
return true;
}
///
/// Gets a message indicating the overall result of all modifications performed across multiple Batch Edit jobs.
///
/// Collection of modifications.
/// Friendly (multi-line) string indicating the result of the batch edits.
public string GetEditorResults(ICollection sets)
{
if (sets.Count == 0)
return MsgBEInstructionNone;
int ctr = Modified / sets.Count;
int len = Iterated / sets.Count;
string maybe = sets.Count == 1 ? string.Empty : "~";
string result = string.Format(MsgBEModifySuccess, maybe, ctr, len);
if (Errored > 0)
result += Environment.NewLine + maybe + string.Format(MsgBEModifyFailError, Errored);
return result;
}
public static BatchEditor Execute(IList lines, IEnumerable data)
{
var editor = new BatchEditor();
var sets = StringInstructionSet.GetBatchSets(lines).ToList();
foreach (var pk in data)
{
foreach (var set in sets)
editor.ProcessPKM(pk, set.Filters, set.Instructions);
}
return editor;
}
}
}