mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
[SabreTools, Headerer] Reverse flag
This commit is contained in:
@@ -12,7 +12,7 @@ namespace SabreTools
|
|||||||
{
|
{
|
||||||
// Private instance variables
|
// Private instance variables
|
||||||
private string _input;
|
private string _input;
|
||||||
private bool _extract;
|
private bool _restore;
|
||||||
private Logger _logger;
|
private Logger _logger;
|
||||||
|
|
||||||
// Private required variables
|
// Private required variables
|
||||||
@@ -24,12 +24,12 @@ namespace SabreTools
|
|||||||
/// Create a new Headerer object
|
/// Create a new Headerer object
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="input">Input file or folder name</param>
|
/// <param name="input">Input file or folder name</param>
|
||||||
/// <param name="extract">True if we're extracting headers (default), false if we're replacing them</param>
|
/// <param name="restore">False if we're extracting headers (default), true if we're restoring them</param>
|
||||||
/// <param name="logger">Logger object for file and console output</param>
|
/// <param name="logger">Logger object for file and console output</param>
|
||||||
public Headerer(string input, bool extract, Logger logger)
|
public Headerer(string input, bool restore, Logger logger)
|
||||||
{
|
{
|
||||||
_input = input;
|
_input = input;
|
||||||
_extract = extract;
|
_restore = restore;
|
||||||
_logger = logger;
|
_logger = logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -39,7 +39,26 @@ namespace SabreTools
|
|||||||
/// <returns>True if it succeeded, false otherwise</returns>
|
/// <returns>True if it succeeded, false otherwise</returns>
|
||||||
public bool Process()
|
public bool Process()
|
||||||
{
|
{
|
||||||
if (_extract)
|
if (_restore)
|
||||||
|
{
|
||||||
|
// If it's a single file, just check it
|
||||||
|
if (File.Exists(_input))
|
||||||
|
{
|
||||||
|
RestoreHeader(_input);
|
||||||
|
}
|
||||||
|
// If it's a directory, recursively check all
|
||||||
|
else if (Directory.Exists(_input))
|
||||||
|
{
|
||||||
|
foreach (string sub in Directory.GetFiles(_input))
|
||||||
|
{
|
||||||
|
if (sub != ".." && sub != ".")
|
||||||
|
{
|
||||||
|
RestoreHeader(sub);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
// If it's a single file, just check it
|
// If it's a single file, just check it
|
||||||
if (File.Exists(_input))
|
if (File.Exists(_input))
|
||||||
@@ -58,25 +77,6 @@ namespace SabreTools
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
// If it's a single file, just check it
|
|
||||||
if (File.Exists(_input))
|
|
||||||
{
|
|
||||||
ReplaceHeader(_input);
|
|
||||||
}
|
|
||||||
// If it's a directory, recursively check all
|
|
||||||
else if (Directory.Exists(_input))
|
|
||||||
{
|
|
||||||
foreach (string sub in Directory.GetFiles(_input))
|
|
||||||
{
|
|
||||||
if (sub != ".." && sub != ".")
|
|
||||||
{
|
|
||||||
ReplaceHeader(sub);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -184,7 +184,7 @@ namespace SabreTools
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="file">Name of the file to be parsed</param>
|
/// <param name="file">Name of the file to be parsed</param>
|
||||||
/// <returns>True if a header was found and appended, false otherwise</returns>
|
/// <returns>True if a header was found and appended, false otherwise</returns>
|
||||||
public bool ReplaceHeader(string file)
|
public bool RestoreHeader(string file)
|
||||||
{
|
{
|
||||||
// First, get the SHA-1 hash of the file
|
// First, get the SHA-1 hash of the file
|
||||||
Rom rom = FileTools.GetSingleFileInfo(file);
|
Rom rom = FileTools.GetSingleFileInfo(file);
|
||||||
|
|||||||
@@ -318,13 +318,13 @@ namespace SabreTools
|
|||||||
/// Wrap extracting and replacing headers
|
/// Wrap extracting and replacing headers
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="inputs">Input file or folder names</param>
|
/// <param name="inputs">Input file or folder names</param>
|
||||||
/// <param name="extract">True if we're extracting headers (default), false if we're replacing them</param>
|
/// <param name="restore">False if we're extracting headers (default), true if we're restoring them</param>
|
||||||
/// <param name="logger">Logger object for file and console output</param>
|
/// <param name="logger">Logger object for file and console output</param>
|
||||||
private static void InitHeaderer(List<string> inputs, bool extract, Logger logger)
|
private static void InitHeaderer(List<string> inputs, bool restore, Logger logger)
|
||||||
{
|
{
|
||||||
foreach (string input in inputs)
|
foreach (string input in inputs)
|
||||||
{
|
{
|
||||||
Headerer headerer = new Headerer(input, extract, logger);
|
Headerer headerer = new Headerer(input, restore, logger);
|
||||||
headerer.Process();
|
headerer.Process();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -93,7 +93,6 @@ namespace SabreTools
|
|||||||
datprefix = false,
|
datprefix = false,
|
||||||
dedup = false,
|
dedup = false,
|
||||||
enableGzip = false,
|
enableGzip = false,
|
||||||
extract = true,
|
|
||||||
extsplit = false,
|
extsplit = false,
|
||||||
forceunpack = false,
|
forceunpack = false,
|
||||||
generate = false,
|
generate = false,
|
||||||
@@ -113,6 +112,7 @@ namespace SabreTools
|
|||||||
quotes = false,
|
quotes = false,
|
||||||
rem = false,
|
rem = false,
|
||||||
remext = false,
|
remext = false,
|
||||||
|
restore = true,
|
||||||
romba = false,
|
romba = false,
|
||||||
single = false,
|
single = false,
|
||||||
softlist = false,
|
softlist = false,
|
||||||
@@ -377,7 +377,7 @@ namespace SabreTools
|
|||||||
break;
|
break;
|
||||||
case "-re":
|
case "-re":
|
||||||
case "--restore":
|
case "--restore":
|
||||||
extract = false;
|
restore = true;
|
||||||
break;
|
break;
|
||||||
case "-rm":
|
case "-rm":
|
||||||
case "--remove":
|
case "--remove":
|
||||||
@@ -713,7 +713,7 @@ namespace SabreTools
|
|||||||
// If we're in headerer mode
|
// If we're in headerer mode
|
||||||
else if (headerer)
|
else if (headerer)
|
||||||
{
|
{
|
||||||
InitHeaderer(inputs, extract, _logger);
|
InitHeaderer(inputs, restore, _logger);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Import a file or folder
|
// Import a file or folder
|
||||||
|
|||||||
Reference in New Issue
Block a user