2016-03-18 01:17:39 -07:00
|
|
|
|
using System;
|
2016-04-18 16:32:17 -07:00
|
|
|
|
using System.Collections.Generic;
|
2016-04-20 17:02:15 -07:00
|
|
|
|
using Mono.Data.Sqlite;
|
2016-03-18 01:17:39 -07:00
|
|
|
|
using System.IO;
|
2016-04-06 16:23:46 -07:00
|
|
|
|
using System.IO.Compression;
|
2016-03-19 02:16:26 -07:00
|
|
|
|
|
2016-03-29 13:48:10 -07:00
|
|
|
|
using SabreTools.Helper;
|
2016-03-24 14:03:22 -07:00
|
|
|
|
|
2016-03-29 13:48:10 -07:00
|
|
|
|
namespace SabreTools
|
2016-03-18 01:17:39 -07:00
|
|
|
|
{
|
2016-03-29 14:49:03 -07:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Entry class for the DATabase application
|
|
|
|
|
|
/// </summary>
|
2016-05-28 16:36:39 -07:00
|
|
|
|
/// <remarks>
|
|
|
|
|
|
/// The following features are missing from DATabaseTwo with respect to the original DATabase:
|
|
|
|
|
|
/// - Source merging
|
|
|
|
|
|
/// - Custom DATs based on a system and a source
|
|
|
|
|
|
/// - Multi-source and multi-system DATs
|
|
|
|
|
|
///
|
|
|
|
|
|
/// The following features need to (want to) be implemented in DATabaseTwo for further stability
|
|
|
|
|
|
/// - Import updating file locations and names when SHA-1 hashes are matched
|
|
|
|
|
|
/// - True duplicate DATs being removed from the import folder (SHA-1 matches)
|
|
|
|
|
|
/// - Generate All only generating DATs that have been recently updated
|
|
|
|
|
|
/// + This requires implementing a "last updated" data point for all DATs and tracking for "last generate" somewhere
|
|
|
|
|
|
/// - Impelement a ToSort folder for DATs that will place DATs in the correct subfolder on Import
|
|
|
|
|
|
/// </remarks>
|
2016-06-10 01:38:58 -07:00
|
|
|
|
public partial class DATabase
|
2016-03-18 01:17:39 -07:00
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
// Private required variables
|
|
|
|
|
|
private static string _datroot = "DATS";
|
|
|
|
|
|
private static string _outroot = "Output";
|
|
|
|
|
|
private static string _dbName = "dats.sqlite";
|
2016-03-24 16:17:33 -07:00
|
|
|
|
private static string _connectionString = "Data Source=" + _dbName + ";Version = 3;";
|
2016-03-18 01:17:39 -07:00
|
|
|
|
|
2016-05-28 16:36:39 -07:00
|
|
|
|
private static Logger _logger;
|
|
|
|
|
|
|
2016-03-29 14:49:03 -07:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Start menu or use supplied parameters
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="args">String array representing command line parameters</param>
|
|
|
|
|
|
public static void Main(string[] args)
|
2016-03-18 01:17:39 -07:00
|
|
|
|
{
|
2016-03-24 16:17:33 -07:00
|
|
|
|
// Perform initial setup and verification
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger = new Logger(true, "database.log");
|
|
|
|
|
|
_logger.Start();
|
2016-06-09 23:35:12 -07:00
|
|
|
|
|
|
|
|
|
|
// If output is being redirected, don't allow clear screens
|
|
|
|
|
|
if (!Console.IsOutputRedirected)
|
|
|
|
|
|
{
|
|
|
|
|
|
Console.Clear();
|
|
|
|
|
|
}
|
2016-05-29 00:07:07 -07:00
|
|
|
|
Setup();
|
2016-03-18 01:17:39 -07:00
|
|
|
|
|
2016-04-18 16:32:17 -07:00
|
|
|
|
// Credits take precidence over all
|
|
|
|
|
|
if ((new List<string>(args)).Contains("--credits"))
|
|
|
|
|
|
{
|
|
|
|
|
|
Build.Credits();
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Close();
|
2016-04-18 16:32:17 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-03-24 22:25:56 -07:00
|
|
|
|
// If there's no arguments, show the menu
|
2016-03-24 13:23:25 -07:00
|
|
|
|
if (args.Length == 0)
|
2016-03-18 01:17:39 -07:00
|
|
|
|
{
|
2016-03-24 22:25:56 -07:00
|
|
|
|
ShowMainMenu();
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Close();
|
2016-03-18 01:17:39 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-20 00:15:02 -07:00
|
|
|
|
// Set all default values
|
2016-04-20 00:50:31 -07:00
|
|
|
|
bool help = false,
|
2016-04-20 00:15:02 -07:00
|
|
|
|
add = false,
|
2016-04-21 13:32:35 -07:00
|
|
|
|
bare = false,
|
2016-05-19 12:43:30 -07:00
|
|
|
|
cascade = false,
|
2016-05-29 13:31:22 -07:00
|
|
|
|
clean = false,
|
2016-04-21 13:32:35 -07:00
|
|
|
|
dedup = false,
|
|
|
|
|
|
diff = false,
|
2016-04-20 17:45:39 -07:00
|
|
|
|
gamename = false,
|
2016-04-20 00:50:31 -07:00
|
|
|
|
disableForce = false,
|
2016-04-20 11:27:17 -07:00
|
|
|
|
extsplit = false,
|
2016-04-21 13:32:35 -07:00
|
|
|
|
forceunpack = false,
|
2016-04-20 00:15:02 -07:00
|
|
|
|
generate = false,
|
|
|
|
|
|
genall = false,
|
2016-05-22 12:45:20 -07:00
|
|
|
|
hashsplit = false,
|
2016-05-28 16:36:39 -07:00
|
|
|
|
ignore = false,
|
2016-04-20 00:15:02 -07:00
|
|
|
|
import = false,
|
2016-05-26 21:57:36 -07:00
|
|
|
|
inplace = false,
|
2016-04-20 00:15:02 -07:00
|
|
|
|
listsrc = false,
|
|
|
|
|
|
listsys = false,
|
2016-04-21 13:32:35 -07:00
|
|
|
|
merge = false,
|
2016-04-20 00:15:02 -07:00
|
|
|
|
norename = false,
|
|
|
|
|
|
old = false,
|
2016-06-10 01:38:58 -07:00
|
|
|
|
outputCMP = false,
|
|
|
|
|
|
outputMiss = false,
|
|
|
|
|
|
outputRC = false,
|
|
|
|
|
|
outputSD = false,
|
|
|
|
|
|
outputXML = false,
|
2016-04-20 15:09:26 -07:00
|
|
|
|
quotes = false,
|
2016-04-20 00:15:02 -07:00
|
|
|
|
rem = false,
|
2016-05-16 22:13:59 -07:00
|
|
|
|
romba = false,
|
2016-05-27 09:38:25 -07:00
|
|
|
|
single = false,
|
|
|
|
|
|
stats = false,
|
2016-05-17 23:29:03 -07:00
|
|
|
|
superdat = false,
|
2016-04-20 01:27:15 -07:00
|
|
|
|
trim = false,
|
2016-05-29 00:44:37 -07:00
|
|
|
|
tsv = false,
|
2016-04-20 15:09:26 -07:00
|
|
|
|
skip = false,
|
2016-06-10 01:38:58 -07:00
|
|
|
|
update = false,
|
2016-04-20 15:09:26 -07:00
|
|
|
|
usegame = true;
|
|
|
|
|
|
string addext = "",
|
2016-04-21 13:32:35 -07:00
|
|
|
|
author = "",
|
2016-06-10 01:38:58 -07:00
|
|
|
|
category = "",
|
|
|
|
|
|
comment = "",
|
|
|
|
|
|
date = "",
|
|
|
|
|
|
description = "",
|
|
|
|
|
|
email = "",
|
2016-04-20 15:09:26 -07:00
|
|
|
|
exta = "",
|
2016-04-20 11:27:17 -07:00
|
|
|
|
extb = "",
|
2016-06-10 01:38:58 -07:00
|
|
|
|
filename = "",
|
|
|
|
|
|
forcemerge = "",
|
|
|
|
|
|
forcend = "",
|
|
|
|
|
|
forcepack = "",
|
|
|
|
|
|
header = "",
|
|
|
|
|
|
homepage = "",
|
2016-04-21 13:32:35 -07:00
|
|
|
|
name = "",
|
2016-04-20 11:27:17 -07:00
|
|
|
|
manu = "",
|
2016-04-20 00:15:02 -07:00
|
|
|
|
outdir = "",
|
2016-04-20 15:09:26 -07:00
|
|
|
|
postfix = "",
|
|
|
|
|
|
prefix = "",
|
|
|
|
|
|
repext = "",
|
2016-04-20 00:15:02 -07:00
|
|
|
|
sources = "",
|
|
|
|
|
|
systems = "",
|
2016-04-20 00:50:31 -07:00
|
|
|
|
root = "",
|
2016-04-21 13:32:35 -07:00
|
|
|
|
url = "",
|
|
|
|
|
|
version = "";
|
2016-04-20 00:15:02 -07:00
|
|
|
|
List<string> inputs = new List<string>();
|
|
|
|
|
|
|
2016-03-24 13:23:25 -07:00
|
|
|
|
// Determine which switches are enabled (with values if necessary)
|
|
|
|
|
|
foreach (string arg in args)
|
2016-03-18 01:17:39 -07:00
|
|
|
|
{
|
2016-04-19 01:57:29 -07:00
|
|
|
|
switch (arg)
|
|
|
|
|
|
{
|
|
|
|
|
|
case "-?":
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "-h":
|
2016-04-19 01:57:29 -07:00
|
|
|
|
case "--help":
|
|
|
|
|
|
help = true;
|
|
|
|
|
|
break;
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "-a":
|
|
|
|
|
|
case "--add":
|
|
|
|
|
|
add = true;
|
|
|
|
|
|
break;
|
2016-04-21 13:32:35 -07:00
|
|
|
|
case "-b":
|
|
|
|
|
|
case "--bare":
|
2016-04-21 14:38:11 -07:00
|
|
|
|
bare = true;
|
2016-04-21 13:32:35 -07:00
|
|
|
|
break;
|
2016-05-19 12:43:30 -07:00
|
|
|
|
case "-c":
|
|
|
|
|
|
case "--cascade":
|
|
|
|
|
|
cascade = true;
|
|
|
|
|
|
break;
|
2016-05-29 13:31:22 -07:00
|
|
|
|
case "-clean":
|
|
|
|
|
|
case "--clean":
|
|
|
|
|
|
clean = true;
|
|
|
|
|
|
break;
|
2016-04-21 13:32:35 -07:00
|
|
|
|
case "-dd":
|
|
|
|
|
|
case "--dedup":
|
|
|
|
|
|
dedup = true;
|
|
|
|
|
|
break;
|
2016-04-20 00:50:31 -07:00
|
|
|
|
case "-df":
|
|
|
|
|
|
case "--disable-force":
|
2016-04-20 11:27:17 -07:00
|
|
|
|
disableForce = true;
|
|
|
|
|
|
break;
|
2016-04-21 13:32:35 -07:00
|
|
|
|
case "-di":
|
|
|
|
|
|
case "--diff":
|
|
|
|
|
|
diff = true;
|
|
|
|
|
|
break;
|
2016-04-20 11:27:17 -07:00
|
|
|
|
case "-es":
|
|
|
|
|
|
case "--ext-split":
|
|
|
|
|
|
extsplit = true;
|
2016-04-20 00:50:31 -07:00
|
|
|
|
break;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
case "-g":
|
|
|
|
|
|
case "--generate":
|
|
|
|
|
|
generate = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-ga":
|
|
|
|
|
|
case "--generate-all":
|
|
|
|
|
|
genall = true;
|
|
|
|
|
|
break;
|
2016-04-20 17:45:39 -07:00
|
|
|
|
case "-gp":
|
|
|
|
|
|
case "--game-prefix":
|
|
|
|
|
|
gamename = true;
|
|
|
|
|
|
break;
|
2016-05-22 12:45:20 -07:00
|
|
|
|
case "-hs":
|
|
|
|
|
|
case "--hash-split":
|
|
|
|
|
|
hashsplit = true;
|
|
|
|
|
|
break;
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "-i":
|
|
|
|
|
|
case "--import":
|
|
|
|
|
|
import = true;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
break;
|
2016-05-28 16:36:39 -07:00
|
|
|
|
case "-ig":
|
|
|
|
|
|
case "--ignore":
|
|
|
|
|
|
ignore = true;
|
|
|
|
|
|
break;
|
2016-05-26 21:57:36 -07:00
|
|
|
|
case "-ip":
|
|
|
|
|
|
case "--inplace":
|
|
|
|
|
|
inplace = true;
|
|
|
|
|
|
break;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
case "-lso":
|
|
|
|
|
|
case "--list-sources":
|
|
|
|
|
|
listsrc = true;
|
|
|
|
|
|
break;
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "-lsy":
|
|
|
|
|
|
case "--list-systems":
|
|
|
|
|
|
listsys = true;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
break;
|
2016-04-21 13:32:35 -07:00
|
|
|
|
case "-m":
|
|
|
|
|
|
case "--merge":
|
|
|
|
|
|
merge = true;
|
|
|
|
|
|
break;
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "-nr":
|
|
|
|
|
|
case "--no-rename":
|
|
|
|
|
|
norename = true;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
break;
|
2016-04-20 21:55:28 -07:00
|
|
|
|
case "-o":
|
|
|
|
|
|
case "--old":
|
2016-04-19 01:57:29 -07:00
|
|
|
|
old = true;
|
|
|
|
|
|
break;
|
2016-06-10 01:38:58 -07:00
|
|
|
|
case "-oc":
|
|
|
|
|
|
case "--output-cmp":
|
|
|
|
|
|
outputCMP = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-om":
|
|
|
|
|
|
case "--output-miss":
|
|
|
|
|
|
outputMiss = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-or":
|
|
|
|
|
|
case "--output-rc":
|
|
|
|
|
|
outputRC = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-os":
|
|
|
|
|
|
case "--output-sd":
|
|
|
|
|
|
outputSD = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-ox":
|
|
|
|
|
|
case "--output-xml":
|
|
|
|
|
|
outputXML = true;
|
|
|
|
|
|
break;
|
2016-04-20 15:09:26 -07:00
|
|
|
|
case "-q":
|
|
|
|
|
|
case "--quotes":
|
|
|
|
|
|
quotes = true;
|
|
|
|
|
|
break;
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "-r":
|
2016-04-20 15:09:26 -07:00
|
|
|
|
case "--roms":
|
|
|
|
|
|
usegame = false;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-rm":
|
2016-04-20 00:15:02 -07:00
|
|
|
|
case "--remove":
|
|
|
|
|
|
rem = true;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
break;
|
2016-05-16 22:13:59 -07:00
|
|
|
|
case "-ro":
|
|
|
|
|
|
case "--romba":
|
|
|
|
|
|
romba = true;
|
|
|
|
|
|
break;
|
2016-05-17 23:29:03 -07:00
|
|
|
|
case "-sd":
|
|
|
|
|
|
case "--superdat":
|
|
|
|
|
|
superdat = true;
|
|
|
|
|
|
break;
|
2016-05-27 09:38:25 -07:00
|
|
|
|
case "-si":
|
|
|
|
|
|
case "--single":
|
|
|
|
|
|
single = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "-st":
|
|
|
|
|
|
case "--stats":
|
|
|
|
|
|
stats = true;
|
|
|
|
|
|
break;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
case "--skip":
|
|
|
|
|
|
skip = true;
|
|
|
|
|
|
break;
|
2016-04-20 01:27:15 -07:00
|
|
|
|
case "-tm":
|
|
|
|
|
|
case "--trim-merge":
|
|
|
|
|
|
trim = true;
|
|
|
|
|
|
break;
|
2016-05-29 00:44:37 -07:00
|
|
|
|
case "-tsv":
|
|
|
|
|
|
case " --tsv":
|
|
|
|
|
|
tsv = true;
|
|
|
|
|
|
break;
|
2016-04-21 13:32:35 -07:00
|
|
|
|
case "-u":
|
|
|
|
|
|
case "--unzip":
|
|
|
|
|
|
forceunpack = true;
|
|
|
|
|
|
break;
|
2016-06-10 01:38:58 -07:00
|
|
|
|
case "-ud":
|
|
|
|
|
|
case "--update":
|
|
|
|
|
|
update = true;
|
|
|
|
|
|
break;
|
2016-04-19 01:57:29 -07:00
|
|
|
|
default:
|
2016-04-20 15:09:26 -07:00
|
|
|
|
if (arg.StartsWith("-ae=") || arg.StartsWith("--add-ext="))
|
|
|
|
|
|
{
|
|
|
|
|
|
addext = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-04-21 13:32:35 -07:00
|
|
|
|
else if (arg.StartsWith("-au=") || arg.StartsWith("--author="))
|
|
|
|
|
|
{
|
|
|
|
|
|
author = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-06-10 01:38:58 -07:00
|
|
|
|
else if (arg.StartsWith("-ca=") || arg.StartsWith("--category="))
|
|
|
|
|
|
{
|
|
|
|
|
|
category = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-co=") || arg.StartsWith("--comment="))
|
|
|
|
|
|
{
|
|
|
|
|
|
comment = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-da=") || arg.StartsWith("--date="))
|
|
|
|
|
|
{
|
|
|
|
|
|
date = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-de=") || arg.StartsWith("--desc="))
|
2016-04-21 13:32:35 -07:00
|
|
|
|
{
|
2016-06-10 01:38:58 -07:00
|
|
|
|
description = arg.Split('=')[1];
|
2016-04-21 13:32:35 -07:00
|
|
|
|
}
|
2016-06-10 01:38:58 -07:00
|
|
|
|
else if (arg.StartsWith("-em=") || arg.StartsWith("--email="))
|
2016-04-21 13:32:35 -07:00
|
|
|
|
{
|
2016-06-10 01:38:58 -07:00
|
|
|
|
email = arg.Split('=')[1];
|
2016-04-21 13:32:35 -07:00
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-exta="))
|
2016-04-20 11:27:17 -07:00
|
|
|
|
{
|
|
|
|
|
|
exta = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-extb="))
|
2016-04-20 11:27:17 -07:00
|
|
|
|
{
|
|
|
|
|
|
extb = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-06-10 01:38:58 -07:00
|
|
|
|
else if (arg.StartsWith("-f=") || arg.StartsWith("--filename="))
|
|
|
|
|
|
{
|
|
|
|
|
|
filename = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-fm=") || arg.StartsWith("--forcemerge="))
|
|
|
|
|
|
{
|
|
|
|
|
|
forcemerge = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-fn=") || arg.StartsWith("--forcend="))
|
|
|
|
|
|
{
|
|
|
|
|
|
forcend = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-fp=") || arg.StartsWith("--forcepack="))
|
|
|
|
|
|
{
|
|
|
|
|
|
forcepack = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-h=") || arg.StartsWith("--header="))
|
|
|
|
|
|
{
|
|
|
|
|
|
header = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-hp=") || arg.StartsWith("--homepage="))
|
|
|
|
|
|
{
|
|
|
|
|
|
homepage = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-input="))
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
2016-04-28 16:10:22 -07:00
|
|
|
|
inputs.Add(arg.Split('=')[1].Replace("\"", ""));
|
2016-04-19 01:57:29 -07:00
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-manu=") && manu == "")
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
2016-04-20 00:15:02 -07:00
|
|
|
|
manu = arg.Split('=')[1];
|
2016-04-19 01:57:29 -07:00
|
|
|
|
}
|
2016-04-21 13:32:35 -07:00
|
|
|
|
else if (arg.StartsWith("-n=") || arg.StartsWith("--name="))
|
|
|
|
|
|
{
|
|
|
|
|
|
name = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-out=") && outdir == "")
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
|
|
|
|
|
outdir = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-04-20 15:09:26 -07:00
|
|
|
|
else if (arg.StartsWith("-post=") || arg.StartsWith("--postfix="))
|
|
|
|
|
|
{
|
|
|
|
|
|
postfix = arg.Split('=')[1];
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (arg.StartsWith("-pre=") || arg.StartsWith("--prefix="))
|
|
|
|
|
|
{
|
|
|
|
|
|
prefix = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-source=") && sources == "")
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
2016-04-20 00:15:02 -07:00
|
|
|
|
sources = arg.Split('=')[1];
|
2016-04-19 01:57:29 -07:00
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-system=") && systems == "")
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
2016-04-20 00:15:02 -07:00
|
|
|
|
systems = arg.Split('=')[1];
|
2016-04-19 01:57:29 -07:00
|
|
|
|
}
|
2016-04-20 15:09:26 -07:00
|
|
|
|
else if (arg.StartsWith("-rd=") || arg.StartsWith("--root-dir="))
|
2016-04-20 00:50:31 -07:00
|
|
|
|
{
|
|
|
|
|
|
root = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-04-20 15:09:26 -07:00
|
|
|
|
else if (arg.StartsWith("-re=") || arg.StartsWith("--rep-ext="))
|
|
|
|
|
|
{
|
|
|
|
|
|
repext = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-06-10 01:38:58 -07:00
|
|
|
|
else if (arg.StartsWith("-u=") || arg.StartsWith("--url="))
|
|
|
|
|
|
{
|
|
|
|
|
|
url = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-05-04 15:09:31 -07:00
|
|
|
|
else if (arg.StartsWith("-url=") && url == "")
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
2016-04-20 00:15:02 -07:00
|
|
|
|
url = arg.Split('=')[1];
|
2016-04-19 01:57:29 -07:00
|
|
|
|
}
|
2016-04-21 13:32:35 -07:00
|
|
|
|
else if (arg.StartsWith("-v=") || arg.StartsWith("--version="))
|
|
|
|
|
|
{
|
|
|
|
|
|
version = arg.Split('=')[1];
|
|
|
|
|
|
}
|
2016-04-28 16:10:22 -07:00
|
|
|
|
else if (File.Exists(arg.Replace("\"", "")) || Directory.Exists(arg.Replace("\"", "")))
|
2016-04-19 01:57:29 -07:00
|
|
|
|
{
|
2016-04-20 00:15:02 -07:00
|
|
|
|
inputs.Add(arg);
|
2016-04-19 01:57:29 -07:00
|
|
|
|
}
|
2016-04-20 21:17:23 -07:00
|
|
|
|
else
|
|
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Error("Invalid input detected: " + arg);
|
2016-04-20 21:17:23 -07:00
|
|
|
|
Console.WriteLine();
|
|
|
|
|
|
Build.Help();
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Close();
|
2016-04-20 21:17:23 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2016-04-19 01:57:29 -07:00
|
|
|
|
break;
|
|
|
|
|
|
}
|
2016-03-24 13:23:25 -07:00
|
|
|
|
}
|
2016-03-18 01:17:39 -07:00
|
|
|
|
|
2016-03-29 21:23:22 -07:00
|
|
|
|
// If skip is set, it's being called from the UI so we just exit
|
|
|
|
|
|
if (skip)
|
|
|
|
|
|
{
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-03-24 16:29:27 -07:00
|
|
|
|
// If more than one switch is enabled or help is set, show the help screen
|
2016-06-10 01:38:58 -07:00
|
|
|
|
if (help || !(add ^ extsplit ^ generate ^ genall ^ hashsplit ^ import ^ listsrc ^ listsys ^ (merge || diff) ^
|
|
|
|
|
|
(update || outputCMP || outputRC || outputSD || outputXML || outputMiss || romba) ^ rem ^ stats ^ trim))
|
2016-04-20 00:50:31 -07:00
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Error("Only one feature switch is allowed at a time");
|
2016-04-20 00:50:31 -07:00
|
|
|
|
Build.Help();
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Close();
|
2016-04-20 00:50:31 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// If a switch that requires a filename is set and no file is, show the help screen
|
2016-06-10 01:38:58 -07:00
|
|
|
|
if (inputs.Count == 0 && (update || (outputMiss || romba) || outputCMP || outputRC || outputSD
|
|
|
|
|
|
|| outputXML || extsplit || hashsplit || (merge || diff) || stats || trim))
|
2016-03-24 13:23:25 -07:00
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Error("This feature requires at least one input");
|
2016-04-06 14:19:01 -07:00
|
|
|
|
Build.Help();
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Close();
|
2016-03-24 13:23:25 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2016-03-18 01:17:39 -07:00
|
|
|
|
|
2016-03-24 13:23:25 -07:00
|
|
|
|
// Now take care of each mode in succesion
|
|
|
|
|
|
|
|
|
|
|
|
// Import a file or folder
|
|
|
|
|
|
if (import)
|
|
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
InitImport(ignore);
|
2016-03-24 13:23:25 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Generate a DAT
|
|
|
|
|
|
else if (generate)
|
|
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
InitImport(ignore);
|
|
|
|
|
|
InitGenerate(systems, norename, old);
|
2016-03-24 13:23:25 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
2016-03-28 19:44:10 -07:00
|
|
|
|
// Generate all DATs
|
|
|
|
|
|
else if (genall)
|
|
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
InitImport(ignore);
|
|
|
|
|
|
InitGenerateAll(norename, old);
|
2016-03-28 19:44:10 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
2016-03-24 13:23:25 -07:00
|
|
|
|
// List all available sources
|
|
|
|
|
|
else if (listsrc)
|
|
|
|
|
|
{
|
2016-03-24 22:25:56 -07:00
|
|
|
|
ListSources();
|
2016-03-24 13:23:25 -07:00
|
|
|
|
}
|
2016-03-18 01:17:39 -07:00
|
|
|
|
|
2016-03-24 13:23:25 -07:00
|
|
|
|
// List all available systems
|
|
|
|
|
|
else if (listsys)
|
|
|
|
|
|
{
|
2016-03-24 22:25:56 -07:00
|
|
|
|
ListSystems();
|
2016-03-24 13:23:25 -07:00
|
|
|
|
}
|
2016-03-19 02:16:26 -07:00
|
|
|
|
|
2016-06-10 01:38:58 -07:00
|
|
|
|
// Convert or update a DAT or folder of DATs
|
|
|
|
|
|
else if (update || outputCMP || outputMiss || outputRC || outputSD || outputXML || romba)
|
2016-04-20 15:09:26 -07:00
|
|
|
|
{
|
|
|
|
|
|
foreach (string input in inputs)
|
|
|
|
|
|
{
|
2016-06-10 01:38:58 -07:00
|
|
|
|
InitUpdate(input, filename, name, description, category, version, date, author, email, homepage, url, comment, header,
|
|
|
|
|
|
superdat, forcemerge, forcend, forcepack, outputCMP, outputMiss, outputRC, outputSD, outputXML, usegame, prefix,
|
|
|
|
|
|
postfix, quotes, repext, addext, gamename, romba, tsv, outdir, clean);
|
2016-04-20 00:15:02 -07:00
|
|
|
|
}
|
2016-03-24 22:25:56 -07:00
|
|
|
|
}
|
2016-03-29 03:09:45 -07:00
|
|
|
|
|
|
|
|
|
|
// Add a source or system
|
|
|
|
|
|
else if (add)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (manu != "" && systems != "")
|
|
|
|
|
|
{
|
|
|
|
|
|
InitAddSystem(manu, systems);
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (sources != "" && url != "")
|
|
|
|
|
|
{
|
|
|
|
|
|
InitAddSource(manu, systems);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2016-04-06 14:19:01 -07:00
|
|
|
|
Build.Help();
|
2016-03-29 03:09:45 -07:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Remove a source or system
|
|
|
|
|
|
else if (rem)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (systems != "")
|
|
|
|
|
|
{
|
|
|
|
|
|
InitRemoveSystem(systems);
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (sources != "")
|
|
|
|
|
|
{
|
|
|
|
|
|
InitRemoveSource(sources);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2016-04-06 14:19:01 -07:00
|
|
|
|
Build.Help();
|
2016-03-29 03:09:45 -07:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-20 00:50:31 -07:00
|
|
|
|
// Consolodate and trim DAT
|
2016-04-20 01:27:15 -07:00
|
|
|
|
else if (trim)
|
2016-04-20 00:50:31 -07:00
|
|
|
|
{
|
|
|
|
|
|
foreach (string input in inputs)
|
|
|
|
|
|
{
|
2016-04-20 01:27:15 -07:00
|
|
|
|
InitTrimMerge(input, root, !norename, !disableForce);
|
2016-04-20 00:50:31 -07:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-04-20 11:37:20 -07:00
|
|
|
|
// Split a DAT by extension
|
2016-04-20 11:42:18 -07:00
|
|
|
|
else if (extsplit)
|
|
|
|
|
|
{
|
|
|
|
|
|
foreach (string input in inputs)
|
|
|
|
|
|
{
|
|
|
|
|
|
InitExtSplit(input, exta, extb, outdir);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2016-04-20 11:37:20 -07:00
|
|
|
|
|
2016-04-21 13:32:35 -07:00
|
|
|
|
// Merge, diff, and dedupe at least 2 DATs
|
2016-05-10 15:56:05 -07:00
|
|
|
|
else if (merge || diff)
|
2016-04-21 13:32:35 -07:00
|
|
|
|
{
|
2016-06-10 01:38:58 -07:00
|
|
|
|
InitMergeDiff(inputs, name, description, category, version, author, diff, dedup, bare, forceunpack, old, superdat, cascade, inplace, outdir, clean);
|
2016-04-21 13:32:35 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
2016-05-22 12:45:20 -07:00
|
|
|
|
// Split a DAT by available hashes
|
|
|
|
|
|
else if (hashsplit)
|
|
|
|
|
|
{
|
|
|
|
|
|
InitHashSplit(inputs, outdir);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-05-27 09:38:25 -07:00
|
|
|
|
// Get statistics on input files
|
|
|
|
|
|
else if (stats)
|
|
|
|
|
|
{
|
|
|
|
|
|
InitStats(inputs, single);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-06-09 23:35:12 -07:00
|
|
|
|
// If nothing is set, show the help
|
2016-06-10 01:38:58 -07:00
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
Build.Help();
|
|
|
|
|
|
}
|
2016-06-09 23:35:12 -07:00
|
|
|
|
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Close();
|
2016-03-24 22:25:56 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2016-05-28 16:36:39 -07:00
|
|
|
|
#region Helper methods
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Perform initial setup for the program
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private static void Setup()
|
|
|
|
|
|
{
|
|
|
|
|
|
Remapping.CreateRemappings();
|
2016-05-29 00:07:07 -07:00
|
|
|
|
Build.Start("DATabase");
|
2016-05-28 16:36:39 -07:00
|
|
|
|
|
|
|
|
|
|
// Perform initial database and folder setup
|
|
|
|
|
|
if (!Directory.Exists(_datroot))
|
|
|
|
|
|
{
|
|
|
|
|
|
Directory.CreateDirectory(_datroot);
|
|
|
|
|
|
}
|
|
|
|
|
|
if (!Directory.Exists(_outroot))
|
|
|
|
|
|
{
|
|
|
|
|
|
Directory.CreateDirectory(_outroot);
|
|
|
|
|
|
}
|
|
|
|
|
|
DBTools.EnsureDatabase(_dbName, _connectionString);
|
|
|
|
|
|
|
|
|
|
|
|
using (SqliteConnection dbc = new SqliteConnection(_connectionString))
|
|
|
|
|
|
{
|
|
|
|
|
|
dbc.Open();
|
|
|
|
|
|
|
|
|
|
|
|
string query = "SELECT * FROM system";
|
|
|
|
|
|
using (SqliteCommand slc = new SqliteCommand(query, dbc))
|
|
|
|
|
|
{
|
|
|
|
|
|
using (SqliteDataReader sldr = slc.ExecuteReader())
|
|
|
|
|
|
{
|
|
|
|
|
|
while (sldr.Read())
|
|
|
|
|
|
{
|
|
|
|
|
|
int systemid = sldr.GetInt32(0);
|
|
|
|
|
|
string system = _datroot + Path.DirectorySeparatorChar + sldr.GetString(1) + " - " + sldr.GetString(2);
|
|
|
|
|
|
system = system.Trim();
|
|
|
|
|
|
|
|
|
|
|
|
if (!Directory.Exists(system))
|
|
|
|
|
|
{
|
|
|
|
|
|
Directory.CreateDirectory(system);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2016-04-21 13:32:35 -07:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// List sources in the database
|
|
|
|
|
|
/// </summary>
|
2016-05-28 16:36:39 -07:00
|
|
|
|
/// <remarks>This does not have an analogue in DATabaseTwo</remarks>
|
2016-05-29 13:06:58 -07:00
|
|
|
|
private static void ListSources()
|
2016-04-21 13:32:35 -07:00
|
|
|
|
{
|
|
|
|
|
|
string query = @"
|
2016-05-29 13:06:58 -07:00
|
|
|
|
SELECT DISTINCT source.id, source.name, source.url
|
|
|
|
|
|
FROM source
|
|
|
|
|
|
ORDER BY source.name";
|
2016-04-21 13:32:35 -07:00
|
|
|
|
using (SqliteConnection dbc = new SqliteConnection(_connectionString))
|
|
|
|
|
|
{
|
|
|
|
|
|
dbc.Open();
|
|
|
|
|
|
using (SqliteCommand slc = new SqliteCommand(query, dbc))
|
|
|
|
|
|
{
|
|
|
|
|
|
using (SqliteDataReader sldr = slc.ExecuteReader())
|
|
|
|
|
|
{
|
|
|
|
|
|
// If nothing is found, tell the user and exit
|
|
|
|
|
|
if (!sldr.HasRows)
|
|
|
|
|
|
{
|
2016-05-29 13:06:58 -07:00
|
|
|
|
_logger.Warning("No sources found! Please add a system and then try again.");
|
2016-04-21 13:32:35 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("Available Sources (id <= name):\n");
|
|
|
|
|
|
while (sldr.Read())
|
|
|
|
|
|
{
|
2016-05-29 13:06:58 -07:00
|
|
|
|
Console.WriteLine(sldr.GetInt32(0) + "\t<=\t" + sldr.GetString(1) + (!String.IsNullOrEmpty(sldr.GetString(2)) ? " (" + sldr.GetString(2) + ")" : ""));
|
2016-04-21 13:32:35 -07:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// List systems in the database
|
|
|
|
|
|
/// </summary>
|
2016-05-28 16:36:39 -07:00
|
|
|
|
private static void ListSystems()
|
2016-04-21 13:32:35 -07:00
|
|
|
|
{
|
|
|
|
|
|
string query = @"
|
2016-05-28 16:36:39 -07:00
|
|
|
|
SELECT DISTINCT system.id, system.manufacturer, system.name
|
|
|
|
|
|
FROM system
|
|
|
|
|
|
ORDER BY system.manufacturer, system.name";
|
2016-04-21 13:32:35 -07:00
|
|
|
|
using (SqliteConnection dbc = new SqliteConnection(_connectionString))
|
|
|
|
|
|
{
|
|
|
|
|
|
dbc.Open();
|
|
|
|
|
|
using (SqliteCommand slc = new SqliteCommand(query, dbc))
|
|
|
|
|
|
{
|
|
|
|
|
|
using (SqliteDataReader sldr = slc.ExecuteReader())
|
|
|
|
|
|
{
|
|
|
|
|
|
// If nothing is found, tell the user and exit
|
|
|
|
|
|
if (!sldr.HasRows)
|
|
|
|
|
|
{
|
2016-05-28 16:36:39 -07:00
|
|
|
|
_logger.Warning("No systems found! Please add a system and then try again.");
|
2016-04-21 13:32:35 -07:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("Available Systems (id <= name):\n");
|
|
|
|
|
|
while (sldr.Read())
|
|
|
|
|
|
{
|
|
|
|
|
|
Console.WriteLine(sldr.GetInt32(0) + "\t<=\t" + sldr.GetString(1) + " - " + sldr.GetString(2));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
2016-03-18 01:17:39 -07:00
|
|
|
|
}
|
|
|
|
|
|
}
|