mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Force no quotes on size and hashes for CMP (fixes #39)
This commit is contained in:
@@ -612,8 +612,8 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
var disk = datItem as Disk;
|
var disk = datItem as Disk;
|
||||||
cmpw.WriteStartElement("disk");
|
cmpw.WriteStartElement("disk");
|
||||||
cmpw.WriteRequiredAttributeString("name", disk.Name);
|
cmpw.WriteRequiredAttributeString("name", disk.Name);
|
||||||
cmpw.WriteOptionalAttributeString("md5", disk.MD5?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("md5", disk.MD5?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha1", disk.SHA1?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha1", disk.SHA1?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("flags", disk.ItemStatus.FromItemStatus(false));
|
cmpw.WriteOptionalAttributeString("flags", disk.ItemStatus.FromItemStatus(false));
|
||||||
cmpw.WriteEndElement();
|
cmpw.WriteEndElement();
|
||||||
break;
|
break;
|
||||||
@@ -622,9 +622,9 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
var media = datItem as Media;
|
var media = datItem as Media;
|
||||||
cmpw.WriteStartElement("media");
|
cmpw.WriteStartElement("media");
|
||||||
cmpw.WriteRequiredAttributeString("name", media.Name);
|
cmpw.WriteRequiredAttributeString("name", media.Name);
|
||||||
cmpw.WriteOptionalAttributeString("md5", media.MD5?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("md5", media.MD5?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha1", media.SHA1?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha1", media.SHA1?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha256", media.SHA256?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha256", media.SHA256?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("spamsum", media.SpamSum?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("spamsum", media.SpamSum?.ToLowerInvariant());
|
||||||
cmpw.WriteEndElement();
|
cmpw.WriteEndElement();
|
||||||
break;
|
break;
|
||||||
@@ -644,14 +644,14 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
var rom = datItem as Rom;
|
var rom = datItem as Rom;
|
||||||
cmpw.WriteStartElement("rom");
|
cmpw.WriteStartElement("rom");
|
||||||
cmpw.WriteRequiredAttributeString("name", rom.Name);
|
cmpw.WriteRequiredAttributeString("name", rom.Name);
|
||||||
cmpw.WriteOptionalAttributeString("size", rom.Size?.ToString());
|
cmpw.WriteOptionalAttributeString("size", rom.Size?.ToString(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("crc", rom.CRC?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("crc", rom.CRC?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("md5", rom.MD5?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("md5", rom.MD5?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha1", rom.SHA1?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha1", rom.SHA1?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha256", rom.SHA256?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha256", rom.SHA256?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha384", rom.SHA384?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha384", rom.SHA384?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("sha512", rom.SHA512?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("sha512", rom.SHA512?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("spamsum", rom.SpamSum?.ToLowerInvariant());
|
cmpw.WriteOptionalAttributeString("spamsum", rom.SpamSum?.ToLowerInvariant(), quoteOverride: false);
|
||||||
cmpw.WriteOptionalAttributeString("date", rom.Date);
|
cmpw.WriteOptionalAttributeString("date", rom.Date);
|
||||||
cmpw.WriteOptionalAttributeString("flags", rom.ItemStatus.FromItemStatus(false));
|
cmpw.WriteOptionalAttributeString("flags", rom.ItemStatus.FromItemStatus(false));
|
||||||
cmpw.WriteEndElement();
|
cmpw.WriteEndElement();
|
||||||
|
|||||||
@@ -200,18 +200,18 @@ namespace SabreTools.IO.Writers
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Write the start of an attribute node
|
/// Write the start of an attribute node
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void WriteStartAttribute(string name)
|
public void WriteStartAttribute(string name, bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// If we're writing quotes, don't write out quote characters internally
|
// If we're writing quotes, don't write out quote characters internally
|
||||||
if (Quotes)
|
if ((quoteOverride == null && Quotes) || (quoteOverride == true))
|
||||||
name = name.Replace("\"", "''");
|
name = name.Replace("\"", "''");
|
||||||
|
|
||||||
AutoComplete(Token.StartAttribute);
|
AutoComplete(Token.StartAttribute);
|
||||||
sw.Write(name);
|
sw.Write(name);
|
||||||
sw.Write(" ");
|
sw.Write(" ");
|
||||||
if (Quotes)
|
if ((quoteOverride == null && Quotes) || (quoteOverride == true))
|
||||||
sw.Write("\"");
|
sw.Write("\"");
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
@@ -224,11 +224,11 @@ namespace SabreTools.IO.Writers
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Write the end of an attribute node
|
/// Write the end of an attribute node
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void WriteEndAttribute()
|
public void WriteEndAttribute(bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
AutoComplete(Token.EndAttribute);
|
AutoComplete(Token.EndAttribute, quoteOverride);
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
{
|
{
|
||||||
@@ -240,28 +240,28 @@ namespace SabreTools.IO.Writers
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Write a complete attribute with content
|
/// Write a complete attribute with content
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void WriteAttributeString(string name, string value)
|
public void WriteAttributeString(string name, string value, bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
WriteStartAttribute(name);
|
WriteStartAttribute(name, quoteOverride);
|
||||||
WriteString(value);
|
WriteString(value);
|
||||||
WriteEndAttribute();
|
WriteEndAttribute(quoteOverride);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Ensure writing writing null values as empty strings
|
/// Ensure writing writing null values as empty strings
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void WriteRequiredAttributeString(string name, string value)
|
public void WriteRequiredAttributeString(string name, string value, bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
WriteAttributeString(name, value ?? string.Empty);
|
WriteAttributeString(name, value ?? string.Empty, quoteOverride);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Write an attribute, if the value is not null or empty
|
/// Write an attribute, if the value is not null or empty
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void WriteOptionalAttributeString(string name, string value)
|
public void WriteOptionalAttributeString(string name, string value, bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrEmpty(value))
|
if (!string.IsNullOrEmpty(value))
|
||||||
WriteAttributeString(name, value);
|
WriteAttributeString(name, value, quoteOverride);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -386,7 +386,7 @@ namespace SabreTools.IO.Writers
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Prepare for the next token to be written
|
/// Prepare for the next token to be written
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void AutoComplete(Token token)
|
private void AutoComplete(Token token, bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
// Handle the error cases
|
// Handle the error cases
|
||||||
if (currentState == State.Closed)
|
if (currentState == State.Closed)
|
||||||
@@ -405,7 +405,7 @@ namespace SabreTools.IO.Writers
|
|||||||
case Token.Standalone:
|
case Token.Standalone:
|
||||||
if (currentState == State.Attribute)
|
if (currentState == State.Attribute)
|
||||||
{
|
{
|
||||||
WriteEndAttributeQuote();
|
WriteEndAttributeQuote(quoteOverride);
|
||||||
WriteEndStartTag(false);
|
WriteEndStartTag(false);
|
||||||
}
|
}
|
||||||
else if (currentState == State.Element)
|
else if (currentState == State.Element)
|
||||||
@@ -421,7 +421,7 @@ namespace SabreTools.IO.Writers
|
|||||||
case Token.EndElement:
|
case Token.EndElement:
|
||||||
case Token.LongEndElement:
|
case Token.LongEndElement:
|
||||||
if (currentState == State.Attribute)
|
if (currentState == State.Attribute)
|
||||||
WriteEndAttributeQuote();
|
WriteEndAttributeQuote(quoteOverride);
|
||||||
|
|
||||||
if (currentState == State.Content)
|
if (currentState == State.Content)
|
||||||
token = Token.LongEndElement;
|
token = Token.LongEndElement;
|
||||||
@@ -433,7 +433,7 @@ namespace SabreTools.IO.Writers
|
|||||||
case Token.StartAttribute:
|
case Token.StartAttribute:
|
||||||
if (currentState == State.Attribute)
|
if (currentState == State.Attribute)
|
||||||
{
|
{
|
||||||
WriteEndAttributeQuote();
|
WriteEndAttributeQuote(quoteOverride);
|
||||||
sw.Write(' ');
|
sw.Write(' ');
|
||||||
}
|
}
|
||||||
else if (currentState == State.Element)
|
else if (currentState == State.Element)
|
||||||
@@ -444,7 +444,7 @@ namespace SabreTools.IO.Writers
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Token.EndAttribute:
|
case Token.EndAttribute:
|
||||||
WriteEndAttributeQuote();
|
WriteEndAttributeQuote(quoteOverride);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Token.Content:
|
case Token.Content:
|
||||||
@@ -513,9 +513,9 @@ namespace SabreTools.IO.Writers
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Internal helper to write the end of an attribute
|
/// Internal helper to write the end of an attribute
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void WriteEndAttributeQuote()
|
private void WriteEndAttributeQuote(bool? quoteOverride = null)
|
||||||
{
|
{
|
||||||
if (Quotes)
|
if ((quoteOverride == null && Quotes) || (quoteOverride == true))
|
||||||
sw.Write("\"");
|
sw.Write("\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user