using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using SabreTools.Helper;
namespace SabreTools
{
/*
"Special Merge" by Obiwantje
------------------------
Inputs:
(1) All - Current all merged
(2) Missing - Current all missing
(3) Add - Current to add
(4) All-New - Current with replaced DATs (some add/remove)
(5) [Flag] Set all roms to have 0-byte values; if set, prepend "Offline" to DAT name/desc
0-byte Values:
CRC - 00000000
MD5 - d41d8cd98f00b204e9800998ecf8427e
SHA-1 - da39a3ee5e6b4b0d3255bfef95601890afd80709
*/
public class OfflineMerge
{
// Instance variables
private string _currentAllMerged;
private string _currentMissingMerged;
private string _currentNewMerged;
private bool _fake;
private Logger _logger;
///
/// Instantiate an OfflineMerge object
///
/// Old-current DAT with merged and deduped values
/// Old-current missing DAT with merged and deduped values
/// New-current DAT with merged and deduped values
/// True if all values should be replaced with default 0-byte values, false otherwise
/// Logger object for console and file output
public OfflineMerge (string currentAllMerged, string currentMissingMerged, string currentNewMerged, bool fake, Logger logger)
{
_currentAllMerged = currentAllMerged.Replace("\"", "");
_currentMissingMerged = currentMissingMerged.Replace("\"", "");
_currentNewMerged = currentNewMerged;
_fake = fake;
_logger = logger;
}
public static void Main(string[] args)
{
// Read in inputs and start the processing
}
///
/// Process the supplied inputs and create the three required outputs:
/// (a) Net New - (currentNewMerged)-(currentAllMerged)
/// (b) Unneeded - (currentAllMerged)-(currentNewMerged)
/// (c) New Missing - (a)+(currentMissingMerged-(b))
///
/// True if the files were created properly, false otherwise
public bool Process()
{
// First get the combination Dictionary of currentWithReplaced and currentAllMerged
Dictionary> completeDats = new Dictionary>();
completeDats = RomManipulation.ParseDict(_currentAllMerged, 0, 0, completeDats, _logger);
completeDats = RomManipulation.ParseDict(_currentNewMerged, 0, 0, completeDats, _logger);
// Now get Net New output dictionary
Dictionary> netNew = new Dictionary>();
foreach (string key in completeDats.Keys)
{
if (completeDats[key].Count == 1)
{
if (completeDats[key][0].System == _currentNewMerged)
{
if (netNew.ContainsKey(key))
{
netNew[key].Add(completeDats[key][0]);
}
else
{
List temp = new List();
temp.Add(completeDats[key][0]);
netNew.Add(key, temp);
}
}
}
}
// Now create the Unneeded dictionary
Dictionary> unneeded = new Dictionary>();
foreach (string key in completeDats.Keys)
{
if (completeDats[key].Count == 1)
{
if (completeDats[key][0].System == _currentAllMerged)
{
if (netNew.ContainsKey(key))
{
netNew[key].Add(completeDats[key][0]);
}
else
{
List temp = new List();
temp.Add(completeDats[key][0]);
netNew.Add(key, temp);
}
}
}
}
// Now create the New Missing dictionary
Dictionary> midMissing = new Dictionary>();
midMissing = RomManipulation.ParseDict(_currentMissingMerged, 0, 0, midMissing, _logger);
foreach (string key in unneeded.Keys)
{
if (midMissing.ContainsKey(key))
{
midMissing[key].AddRange(unneeded[key]);
}
else
{
midMissing.Add(key, unneeded[key]);
}
}
Dictionary> newMissing = new Dictionary>();
foreach (string key in midMissing.Keys)
{
if (midMissing[key].Count == 1)
{
if (midMissing[key][0].System == _currentMissingMerged)
{
if (newMissing.ContainsKey(key))
{
newMissing[key].Add(midMissing[key][0]);
}
else
{
List temp = new List();
temp.Add(midMissing[key][0]);
newMissing.Add(key, temp);
}
}
}
}
foreach (string key in netNew.Keys)
{
if (midMissing.ContainsKey(key))
{
midMissing[key].AddRange(netNew[key]);
}
else
{
midMissing.Add(key, netNew[key]);
}
}
return true;
}
}
}