mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Move field replacement
This commit is contained in:
@@ -536,6 +536,81 @@ namespace SabreTools.Library.DatItems
|
||||
return key;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Replace fields from another item
|
||||
/// </summary>
|
||||
/// <param name="item">DatItem to pull new information from</param>
|
||||
/// <param name="updateFields">List of Fields representing what should be updated</param>
|
||||
public override void ReplaceFields(DatItem item, List<Field> updateFields)
|
||||
{
|
||||
// Replace common fields first
|
||||
base.ReplaceFields(item, updateFields);
|
||||
|
||||
// If we don't have a Disk to replace from, ignore specific fields
|
||||
if (item.ItemType != ItemType.Disk)
|
||||
return;
|
||||
|
||||
// Cast for easier access
|
||||
Disk newItem = item as Disk;
|
||||
|
||||
// Replace the fields
|
||||
if (updateFields.Contains(Field.MD5))
|
||||
{
|
||||
if (string.IsNullOrEmpty(MD5) && !string.IsNullOrEmpty(newItem.MD5))
|
||||
MD5 = newItem.MD5;
|
||||
}
|
||||
|
||||
#if NET_FRAMEWORK
|
||||
if (updateFields.Contains(Field.RIPEMD160))
|
||||
{
|
||||
if (string.IsNullOrEmpty(RIPEMD160) && !string.IsNullOrEmpty(newItem.RIPEMD160))
|
||||
RIPEMD160 = newItem.RIPEMD160;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (updateFields.Contains(Field.SHA1))
|
||||
{
|
||||
if (string.IsNullOrEmpty(SHA1) && !string.IsNullOrEmpty(newItem.SHA1))
|
||||
SHA1 = newItem.SHA1;
|
||||
}
|
||||
|
||||
if (updateFields.Contains(Field.SHA256))
|
||||
{
|
||||
if (string.IsNullOrEmpty(SHA256) && !string.IsNullOrEmpty(newItem.SHA256))
|
||||
SHA256 = newItem.SHA256;
|
||||
}
|
||||
|
||||
if (updateFields.Contains(Field.SHA384))
|
||||
{
|
||||
if (string.IsNullOrEmpty(SHA384) && !string.IsNullOrEmpty(newItem.SHA384))
|
||||
SHA384 = newItem.SHA384;
|
||||
}
|
||||
|
||||
if (updateFields.Contains(Field.SHA512))
|
||||
{
|
||||
if (string.IsNullOrEmpty(SHA512) && !string.IsNullOrEmpty(newItem.SHA512))
|
||||
SHA512 = newItem.SHA512;
|
||||
}
|
||||
|
||||
if (updateFields.Contains(Field.Merge))
|
||||
MergeTag = newItem.MergeTag;
|
||||
|
||||
if (updateFields.Contains(Field.Region))
|
||||
Region = newItem.Region;
|
||||
|
||||
if (updateFields.Contains(Field.Index))
|
||||
Index = newItem.Index;
|
||||
|
||||
if (updateFields.Contains(Field.Writable))
|
||||
Writable = newItem.Writable;
|
||||
|
||||
if (updateFields.Contains(Field.Status))
|
||||
ItemStatus = newItem.ItemStatus;
|
||||
|
||||
if (updateFields.Contains(Field.Optional))
|
||||
Optional = newItem.Optional;
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user