Files
SabreTools/DATabase/MergeDiff.cs

189 lines
5.7 KiB
C#
Raw Normal View History

2016-04-19 16:39:17 -07:00
using System;
using System.Collections.Generic;
using System.IO;
2016-04-19 16:39:17 -07:00
using SabreTools.Helper;
namespace SabreTools
{
2016-04-21 14:10:59 -07:00
public class MergeDiff
2016-04-19 16:39:17 -07:00
{
// Listing related variables
private List<String> _inputs;
// User specified flags
private bool _ad;
2016-04-20 20:17:57 -07:00
private bool _diff;
private bool _dedup;
2016-04-21 14:38:11 -07:00
private bool _bare;
private bool _forceunpack;
private bool _old;
// User specified strings
private string _name;
private string _desc;
private string _cat;
private string _version;
private string _author;
// Other required variables
private string _date = DateTime.Now.ToString("yyyy-MM-dd");
2016-04-20 20:17:57 -07:00
private Logger _logger;
2016-04-20 21:59:55 -07:00
/// <summary>
/// Create a new MergeDAT object
/// </summary>
/// <param name="inputs">A List of Strings representing the DATs or DAT folders to be merged</param>
2016-04-20 21:59:55 -07:00
/// <param name="name">Internal name of the DAT</param>
/// <param name="desc">Description and external name of the DAT</param>
/// <param name="cat">Category for the DAT</param>
/// <param name="version">Version of the DAT</param>
/// <param name="author">Author of the DAT</param>
/// <param name="ad">True if all diff variants should be outputted, false otherwise</param>
/// <param name="diff">True if a DiffDat of all inputs is wanted, false otherwise</param>
/// <param name="dedup">True if the outputted file should remove duplicates, false otherwise</param>
2016-04-21 14:38:11 -07:00
/// <param name="bare">True if the date should be omitted from the DAT, false otherwise</param>
2016-04-20 21:59:55 -07:00
/// <param name="forceunpack">True if the forcepacking="unzip" tag is to be added, false otherwise</param>
/// <param name="old">True if a old-style DAT should be output, false otherwise</param>
/// <param name="logger">Logger object for console and file output</param>
2016-04-21 14:10:59 -07:00
public MergeDiff(List<String> inputs, string name, string desc, string cat, string version, string author,
bool ad, bool diff, bool dedup, bool bare, bool forceunpack, bool old, Logger logger)
2016-04-20 20:17:57 -07:00
{
_inputs = inputs;
_name = name;
_desc = desc;
_cat = cat;
_version = version;
_author = author;
_ad = ad;
2016-04-20 20:17:57 -07:00
_diff = diff;
_dedup = dedup;
2016-04-21 14:38:11 -07:00
_bare = bare;
_forceunpack = forceunpack;
_old = old;
2016-04-20 20:17:57 -07:00
_logger = logger;
}
2016-04-19 16:39:17 -07:00
2016-04-20 20:17:57 -07:00
/// <summary>
/// Combine DATs, optionally diffing and deduping them
/// </summary>
/// <returns>True if the DATs merged correctly, false otherwise</returns>
2016-04-21 14:10:59 -07:00
public bool Process()
2016-04-20 20:17:57 -07:00
{
2016-04-21 13:32:35 -07:00
// Check if there are enough inputs
if ((!_ad && _inputs.Count < 1) || (_ad && _inputs.Count < 2))
2016-04-20 20:17:57 -07:00
{
_logger.Warning("At least " + (_ad ? "2" : "1") + " input(s) are required!");
2016-04-20 20:17:57 -07:00
return false;
}
// Get the values that will be used
if (_name == "")
{
2016-04-27 20:44:17 -07:00
_name = (_diff ? "diffdat" : "mergedat") + (_dedup ? "-deduped" : "");
}
if (_desc == "")
{
2016-04-27 20:44:17 -07:00
_desc = (_diff ? "diffdat" : "mergedat") + (_dedup ? "-deduped" : "");
if (!_bare)
{
_desc += " (" + _date + ")";
}
}
if (_cat == "" && _diff)
{
_cat = "DiffDAT";
}
if (_author == "")
{
_author = "SabreTools";
}
2016-04-28 10:57:32 -07:00
// Create a dictionary of all ROMs from the input DATs
int i = 0;
Dictionary<string, List<RomData>> dict = new Dictionary<string, List<RomData>>();
foreach (string input in _inputs)
{
_logger.User("Adding DAT: " + input);
dict = RomManipulation.ParseDict(input, i, 0, dict, _logger);
i++;
}
2016-04-28 10:57:32 -07:00
// Modify the Dictionary if necessary and output the results
if (_diff || _ad)
{
// Get all entries that don't have External dupes
Dictionary<string, List<RomData>> diffed = new Dictionary<string, List<RomData>>();
foreach (string key in dict.Keys)
{
List<RomData> temp = dict[key];
temp = RomManipulation.Merge(temp);
foreach (RomData rom in temp)
{
if ((_dedup && rom.Dupe != DupeType.InternalHash) || (!_dedup && rom.Dupe != DupeType.InternalAll))
{
if (diffed.ContainsKey(key))
{
diffed[key].Add(rom);
}
else
{
List<RomData> tl = new List<RomData>();
tl.Add(rom);
diffed.Add(key, tl);
}
}
}
}
// Output the difflist only if we're in diff mode and not AB
if (_diff)
{
Output.WriteToDatFromDict(_name, _desc, _version, _date, _cat, _author, _forceunpack, _old, _dedup, "", diffed, _logger);
}
// For the AB mode, get all required dictionaries and output with a new name
if (_ad)
{
// Loop through _inputs first and filter from all diffed roms to find the ones that have the same "System"
string post = "";
foreach (string filename in _inputs)
{
Dictionary<string, List<RomData>> sysDict = new Dictionary<string, List<RomData>>();
foreach (string key in diffed.Keys)
{
if (diffed[key][0].System == filename)
{
sysDict.Add(key, diffed[key]);
}
}
post = " (" + Path.GetFileNameWithoutExtension(filename) + ")";
Output.WriteToDatFromDict(_name + post, _desc + post, _version, _date, _cat, _author, _forceunpack, _old, _dedup, "", sysDict, _logger);
}
// Then loop through all that have a count > 1 for the AB merged DAT
Dictionary<string, List<RomData>> duplicates = new Dictionary<string, List<RomData>>();
post = " (dupes)";
foreach (string key in dict.Keys)
{
if (dict[key].Count > 1)
{
2016-04-28 12:01:54 -07:00
duplicates.Add(key, dict[key]);
}
}
Output.WriteToDatFromDict(_name + post, _desc + post, _version, _date, _cat, _author, _forceunpack, _old, _dedup, "", duplicates, _logger);
}
}
// Output all entries with user-defined merge
else
{
Output.WriteToDatFromDict(_name, _desc, _version, _date, _cat, _author, _forceunpack, _old, _dedup, "", dict, _logger);
}
2016-04-28 10:57:32 -07:00
2016-04-20 20:17:57 -07:00
return true;
2016-04-19 16:39:17 -07:00
}
}
}