mirror of
https://github.com/SabreTools/MPF.git
synced 2026-02-05 13:49:40 +00:00
139 lines
4.1 KiB
C#
139 lines
4.1 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Text.RegularExpressions;
|
|
#if NET462_OR_GREATER || NETCOREAPP
|
|
using SharpCompress.Archives;
|
|
using SharpCompress.Archives.Zip;
|
|
#endif
|
|
|
|
namespace MPF.Processors.OutputFiles
|
|
{
|
|
/// <summary>
|
|
/// Represents a single output file with a Regex-matched name
|
|
/// </summary>
|
|
internal class RegexOutputFile : OutputFile
|
|
{
|
|
/// <summary>
|
|
/// Create an OutputFile with a single filename
|
|
/// </summary>
|
|
public RegexOutputFile(string filename, OutputFileFlags flags)
|
|
: base([filename], flags)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Create an OutputFile with a single filename
|
|
/// </summary>
|
|
public RegexOutputFile(string filename, OutputFileFlags flags, string artifactKey)
|
|
: base([filename], flags, artifactKey)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Create an OutputFile with set of filenames
|
|
/// </summary>
|
|
public RegexOutputFile(string[] filenames, OutputFileFlags flags)
|
|
: base(filenames, flags)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Create an OutputFile with set of filenames
|
|
/// </summary>
|
|
public RegexOutputFile(string[] filenames, OutputFileFlags flags, string artifactKey)
|
|
: base(filenames, flags, artifactKey)
|
|
{
|
|
}
|
|
|
|
/// <inheritdoc/>
|
|
public override bool Exists(string outputDirectory)
|
|
{
|
|
// Ensure the directory exists
|
|
if (!Directory.Exists(outputDirectory))
|
|
return false;
|
|
|
|
// Get list of all files in directory
|
|
var directoryFiles = Directory.GetFiles(outputDirectory);
|
|
foreach (string file in directoryFiles)
|
|
{
|
|
if (Array.FindIndex(Filenames, pattern => Regex.IsMatch(file, pattern)) > -1)
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
#if NET462_OR_GREATER || NETCOREAPP
|
|
/// <inheritdoc/>
|
|
public override bool Exists(ZipArchive? archive)
|
|
{
|
|
// If the archive is invalid
|
|
if (archive is null)
|
|
return false;
|
|
|
|
// Get list of all files in archive
|
|
foreach (var entry in archive.Entries)
|
|
{
|
|
if (entry.Key is null)
|
|
continue;
|
|
|
|
if (Array.Exists(Filenames, pattern => Regex.IsMatch(entry.Key, pattern)))
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/// <inheritdoc/>
|
|
public override bool Extract(ZipArchive? archive, string outputDirectory)
|
|
{
|
|
// If the archive is invalid
|
|
if (archive is null)
|
|
return false;
|
|
|
|
// Get list of all files in archive
|
|
foreach (var entry in archive.Entries)
|
|
{
|
|
if (entry.Key is null)
|
|
continue;
|
|
|
|
var matches = Array.FindAll(Filenames, pattern => Regex.IsMatch(entry.Key, pattern));
|
|
if (matches.Length > 0)
|
|
{
|
|
try
|
|
{
|
|
string outputPath = Path.Combine(outputDirectory, entry.Key);
|
|
entry.WriteToFile(outputPath);
|
|
}
|
|
catch { }
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
#endif
|
|
|
|
/// <inheritdoc/>
|
|
public override List<string> GetPaths(string outputDirectory)
|
|
{
|
|
// Ensure the directory exists
|
|
if (!Directory.Exists(outputDirectory))
|
|
return [];
|
|
|
|
List<string> paths = [];
|
|
|
|
// Get list of all files in directory
|
|
var directoryFiles = Directory.GetFiles(outputDirectory);
|
|
foreach (string file in directoryFiles)
|
|
{
|
|
var matches = Array.FindAll(Filenames, pattern => Regex.IsMatch(file, pattern));
|
|
if (matches is not null && matches.Length > 0)
|
|
paths.Add(file);
|
|
}
|
|
|
|
return paths;
|
|
}
|
|
}
|
|
}
|