2016-04-19 16:39:17 -07:00
|
|
|
|
using System;
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.IO;
|
|
|
|
|
|
|
|
|
|
|
|
using SabreTools.Helper;
|
|
|
|
|
|
|
|
|
|
|
|
namespace SabreTools
|
|
|
|
|
|
{
|
2016-04-19 17:29:09 -07:00
|
|
|
|
public class MergeDAT
|
2016-04-19 16:39:17 -07:00
|
|
|
|
{
|
2016-04-20 21:17:23 -07:00
|
|
|
|
// Listing related variables
|
|
|
|
|
|
private List<String> _inputs;
|
|
|
|
|
|
|
|
|
|
|
|
// User specified flags
|
2016-04-20 20:17:57 -07:00
|
|
|
|
private bool _diff;
|
|
|
|
|
|
private bool _dedup;
|
2016-04-20 21:17:23 -07:00
|
|
|
|
private bool _noDate;
|
|
|
|
|
|
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 20:40:43 -07:00
|
|
|
|
/// <param name="inputs">A List of Strings representing the DATs or DAT folders to be merged</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="logger">Logger object for console and file output</param>
|
2016-04-20 21:17:23 -07:00
|
|
|
|
|
|
|
|
|
|
public MergeDAT(List<String> inputs, string name, string desc, string cat, string version, string author,
|
|
|
|
|
|
bool diff, bool dedup, bool noDate, bool forceunpack, bool old, Logger logger)
|
2016-04-20 20:17:57 -07:00
|
|
|
|
{
|
|
|
|
|
|
_inputs = inputs;
|
2016-04-20 21:17:23 -07:00
|
|
|
|
_name = name;
|
|
|
|
|
|
_desc = desc;
|
|
|
|
|
|
_cat = cat;
|
|
|
|
|
|
_version = version;
|
|
|
|
|
|
_author = author;
|
2016-04-20 20:17:57 -07:00
|
|
|
|
_diff = diff;
|
|
|
|
|
|
_dedup = dedup;
|
2016-04-20 21:17:23 -07:00
|
|
|
|
_noDate = noDate;
|
|
|
|
|
|
_forceunpack = forceunpack;
|
|
|
|
|
|
_old = old;
|
2016-04-20 20:17:57 -07:00
|
|
|
|
_logger = logger;
|
|
|
|
|
|
}
|
2016-04-19 16:39:17 -07:00
|
|
|
|
|
2016-04-19 17:48:27 -07:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Entry point for MergeDat program
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="args">String array representing command line parameters</param>
|
2016-04-19 16:39:17 -07:00
|
|
|
|
public static void Main(string[] args)
|
|
|
|
|
|
{
|
|
|
|
|
|
Console.Clear();
|
|
|
|
|
|
|
|
|
|
|
|
// Credits take precidence over all
|
|
|
|
|
|
if ((new List<string>(args)).Contains("--credits"))
|
|
|
|
|
|
{
|
|
|
|
|
|
Build.Credits();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (args.Length == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
Build.Help();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-20 20:17:57 -07:00
|
|
|
|
Logger logger = new Logger(false, "diffdat.log");
|
2016-04-19 16:39:17 -07:00
|
|
|
|
logger.Start();
|
|
|
|
|
|
|
|
|
|
|
|
// Output the title
|
|
|
|
|
|
Build.Start("DiffDat");
|
|
|
|
|
|
|
|
|
|
|
|
List<String> inputs = new List<String>();
|
2016-04-20 21:17:23 -07:00
|
|
|
|
bool help = false, dedup = false, diff = false, forceunpack = false, old = false, log = false, noDate = false;
|
|
|
|
|
|
string name = "", desc = "", cat = "", version = "", author = "";
|
2016-04-19 16:39:17 -07:00
|
|
|
|
foreach (string arg in args)
|
|
|
|
|
|
{
|
|
|
|
|
|
switch (arg)
|
|
|
|
|
|
{
|
|
|
|
|
|
case "-h":
|
|
|
|
|
|
case "-?":
|
|
|
|
|
|
case "--help":
|
2016-04-20 21:17:23 -07:00
|
|
|
|
Build.Help();
|
|
|
|
|
|
logger.Close();
|
|
|
|
|
|
return;
|
2016-04-20 12:52:05 -07:00
|
|
|
|
case "-di":
|
2016-04-19 17:31:03 -07:00
|
|
|
|
case "--diff":
|
|
|
|
|
|
diff = true;
|
|
|
|
|
|
break;
|
2016-04-20 12:52:05 -07:00
|
|
|
|
case "-dd":
|
|
|
|
|
|
case "--dedup":
|
2016-04-20 20:17:57 -07:00
|
|
|
|
dedup = true;
|
2016-04-19 16:58:47 -07:00
|
|
|
|
break;
|
2016-04-20 21:17:23 -07:00
|
|
|
|
case "-b":
|
|
|
|
|
|
case "--bare":
|
|
|
|
|
|
noDate = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-u":
|
|
|
|
|
|
case "--unzip":
|
|
|
|
|
|
forceunpack = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-o":
|
|
|
|
|
|
case "--old":
|
|
|
|
|
|
old = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-l":
|
|
|
|
|
|
case "--log":
|
|
|
|
|
|
log = true;
|
|
|
|
|
|
break;
|
2016-04-19 16:39:17 -07:00
|
|
|
|
default:
|
2016-04-20 21:17:23 -07:00
|
|
|
|
if (arg.StartsWith("-n=") || arg.StartsWith("--name="))
|
|
|
|
|
|
{
|
|
|
|
|
|
name = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-d=") || arg.StartsWith("--desc="))
|
|
|
|
|
|
{
|
|
|
|
|
|
desc = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-c=") || arg.StartsWith("--cat="))
|
|
|
|
|
|
{
|
|
|
|
|
|
cat = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-a=") || arg.StartsWith("--author="))
|
|
|
|
|
|
{
|
|
|
|
|
|
author = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-v=") || arg.StartsWith("--version="))
|
|
|
|
|
|
{
|
|
|
|
|
|
version = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-04-19 16:39:17 -07:00
|
|
|
|
// Add actual files to the list of inputs
|
2016-04-20 21:17:23 -07:00
|
|
|
|
else if (File.Exists(arg.Replace("\"", "")))
|
2016-04-19 16:39:17 -07:00
|
|
|
|
{
|
|
|
|
|
|
inputs.Add(Path.GetFullPath(arg.Replace("\"", "")));
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (Directory.Exists(arg.Replace("\"", "")))
|
|
|
|
|
|
{
|
|
|
|
|
|
foreach (string file in Directory.EnumerateFiles(arg, "*", SearchOption.AllDirectories))
|
|
|
|
|
|
{
|
|
|
|
|
|
inputs.Add(Path.GetFullPath(file));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Set the possibly new value for logger
|
2016-04-20 21:17:23 -07:00
|
|
|
|
logger.ToFile = log;
|
2016-04-19 16:39:17 -07:00
|
|
|
|
|
|
|
|
|
|
// Show help if explicitly asked for it or if not enough files are supplied
|
|
|
|
|
|
if (help || inputs.Count < 2)
|
|
|
|
|
|
{
|
|
|
|
|
|
Build.Help();
|
|
|
|
|
|
logger.Close();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-19 17:31:03 -07:00
|
|
|
|
// Otherwise, read in the files, process them and write the result to the file type that the first one is
|
2016-04-20 21:17:23 -07:00
|
|
|
|
MergeDAT md = new MergeDAT(inputs, name, desc, cat, version, author, diff, dedup, noDate, forceunpack, old, logger);
|
2016-04-20 20:17:57 -07:00
|
|
|
|
md.MergeDiff();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Combine DATs, optionally diffing and deduping them
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <returns>True if the DATs merged correctly, false otherwise</returns>
|
|
|
|
|
|
/// <remarks>
|
|
|
|
|
|
/// TODO: @tractivo -for the A and B and AB output you could let this be determined by comparing the hashes.
|
|
|
|
|
|
/// when a hash is present in both dats then this entry goes to AB, if its only in A then it stay in A if in B then in B.
|
|
|
|
|
|
/// </remarks>
|
|
|
|
|
|
public bool MergeDiff()
|
|
|
|
|
|
{
|
|
|
|
|
|
// Check if there are any inputs
|
|
|
|
|
|
if (_inputs.Count == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
_logger.Warning("No inputs were found!");
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-19 16:39:17 -07:00
|
|
|
|
List<RomData> A = new List<RomData>();
|
2016-04-20 20:17:57 -07:00
|
|
|
|
foreach (string input in _inputs)
|
2016-04-19 16:39:17 -07:00
|
|
|
|
{
|
2016-04-20 20:17:57 -07:00
|
|
|
|
_logger.Log("Adding DAT: " + input);
|
|
|
|
|
|
List<RomData> B = RomManipulation.Parse(input, 0, 0, _logger);
|
|
|
|
|
|
if (_diff)
|
2016-04-19 17:31:03 -07:00
|
|
|
|
{
|
|
|
|
|
|
A = RomManipulation.Diff(A, B);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
A.AddRange(B);
|
|
|
|
|
|
}
|
2016-04-19 16:39:17 -07:00
|
|
|
|
}
|
2016-04-19 16:58:47 -07:00
|
|
|
|
|
|
|
|
|
|
// If we want a merged list, send it for merging before outputting
|
2016-04-20 20:17:57 -07:00
|
|
|
|
if (_dedup)
|
2016-04-19 16:58:47 -07:00
|
|
|
|
{
|
|
|
|
|
|
A = RomManipulation.Merge(A);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-20 21:17:23 -07:00
|
|
|
|
// Get the names that will be used
|
|
|
|
|
|
if (_name == "")
|
|
|
|
|
|
{
|
|
|
|
|
|
_name = (_diff ? "diffdat" : "mergedat") + (_dedup ? "-merged" : "");
|
|
|
|
|
|
}
|
|
|
|
|
|
if (_desc == "")
|
|
|
|
|
|
{
|
|
|
|
|
|
_desc = (_diff ? "diffdat" : "mergedat") + (_dedup ? "-merged" : "");
|
|
|
|
|
|
if (!_noDate)
|
|
|
|
|
|
{
|
|
|
|
|
|
_desc += " (" + _date + ")";
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (_cat == "" && _diff)
|
2016-04-20 12:31:51 -07:00
|
|
|
|
{
|
2016-04-20 21:17:23 -07:00
|
|
|
|
_cat = "DiffDAT";
|
2016-04-20 12:31:51 -07:00
|
|
|
|
}
|
2016-04-20 21:17:23 -07:00
|
|
|
|
if (_author == "")
|
2016-04-20 12:31:51 -07:00
|
|
|
|
{
|
2016-04-20 21:17:23 -07:00
|
|
|
|
_author = "SabreTools";
|
2016-04-20 12:31:51 -07:00
|
|
|
|
}
|
2016-04-20 20:17:57 -07:00
|
|
|
|
|
2016-04-20 21:17:23 -07:00
|
|
|
|
// Now write the file out
|
|
|
|
|
|
Output.WriteToDat(_name, _desc, _version, _date, _cat, _author, _forceunpack, _old, "", A, _logger);
|
|
|
|
|
|
|
2016-04-20 20:17:57 -07:00
|
|
|
|
return true;
|
2016-04-19 16:39:17 -07:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|