mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
This change brings about a few changes: 1) A new LogLevel called "User" that is used for non-verbose, non-error output 2) Only User and Error are output to console now, not all of them 3) All programs have log to file enabled by default and all flags for enabling logging have been removed 4) Some former Verbose statements have been converted over to User because of the shift in usage.
172 lines
5.3 KiB
C#
172 lines
5.3 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
|
|
using SabreTools.Helper;
|
|
|
|
namespace SabreTools
|
|
{
|
|
public class MergeDiff
|
|
{
|
|
// Listing related variables
|
|
private List<String> _inputs;
|
|
|
|
// User specified flags
|
|
private bool _ad;
|
|
private bool _diff;
|
|
private bool _dedup;
|
|
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");
|
|
private Logger _logger;
|
|
|
|
/// <summary>
|
|
/// Create a new MergeDAT object
|
|
/// </summary>
|
|
/// <param name="inputs">A List of Strings representing the DATs or DAT folders to be merged</param>
|
|
/// <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>
|
|
/// <param name="bare">True if the date should be omitted from the DAT, false otherwise</param>
|
|
/// <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>
|
|
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)
|
|
{
|
|
_inputs = inputs;
|
|
_name = name;
|
|
_desc = desc;
|
|
_cat = cat;
|
|
_version = version;
|
|
_author = author;
|
|
_ad = ad;
|
|
_diff = diff;
|
|
_dedup = dedup;
|
|
_bare = bare;
|
|
_forceunpack = forceunpack;
|
|
_old = old;
|
|
_logger = logger;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Combine DATs, optionally diffing and deduping them
|
|
/// </summary>
|
|
/// <returns>True if the DATs merged correctly, false otherwise</returns>
|
|
public bool Process()
|
|
{
|
|
// Check if there are enough inputs
|
|
if ((!_ad && _inputs.Count < 1) || (_ad && _inputs.Count < 2))
|
|
{
|
|
_logger.Warning("At least " + (_ad ? "2" : "1") + " input(s) are required!");
|
|
return false;
|
|
}
|
|
|
|
// Get the values that will be used
|
|
if (_name == "")
|
|
{
|
|
_name = (_diff ? "diffdat" : "mergedat") + (_dedup ? "-deduped" : "");
|
|
}
|
|
if (_desc == "")
|
|
{
|
|
_desc = (_diff ? "diffdat" : "mergedat") + (_dedup ? "-deduped" : "");
|
|
if (!_bare)
|
|
{
|
|
_desc += " (" + _date + ")";
|
|
}
|
|
}
|
|
if (_cat == "" && _diff)
|
|
{
|
|
_cat = "DiffDAT";
|
|
}
|
|
if (_author == "")
|
|
{
|
|
_author = "SabreTools";
|
|
}
|
|
|
|
// Create a dictionary of all ROMs from the input DATs
|
|
Dictionary<string, List<RomData>> dict = new Dictionary<string, List<RomData>>();
|
|
foreach (string input in _inputs)
|
|
{
|
|
_logger.User("Adding DAT: " + input);
|
|
dict = RomManipulation.ParseDict(input, 0, 0, dict, _logger);
|
|
}
|
|
|
|
// Modify the Dictionary if necessary and output the results
|
|
if (_diff || _ad)
|
|
{
|
|
// Get all entries that have only one item in their list
|
|
Dictionary<string, List<RomData>> diffed = new Dictionary<string, List<RomData>>();
|
|
foreach (string key in dict.Keys)
|
|
{
|
|
if (dict[key].Count == 1)
|
|
{
|
|
diffed.Add(key, dict[key]);
|
|
}
|
|
}
|
|
|
|
// 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)
|
|
{
|
|
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);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|
|
}
|