pef: Micro-optimizations to LogItem and IcdXmlAttribute equality

This commit is contained in:
Chris Cameron
2018-08-01 10:41:56 -04:00
parent 84fa69d3e0
commit 5e80ddcc16
2 changed files with 22 additions and 13 deletions

View File

@@ -7,7 +7,7 @@ namespace ICD.Common.Utils.Services.Logging
/// <summary>
/// Log Entry Item
/// </summary>
public struct LogItem
public struct LogItem : IEquatable<LogItem>
{
private readonly string m_Message;
private readonly eSeverity m_Severity;
@@ -93,7 +93,14 @@ namespace ICD.Common.Utils.Services.Logging
/// <returns></returns>
public static bool operator !=(LogItem a1, LogItem a2)
{
return !(a1 == a2);
return !a1.Equals(a2);
}
public bool Equals(LogItem other)
{
return m_Severity == other.m_Severity &&
m_Timestamp == other.m_Timestamp &&
m_Message == other.m_Message;
}
/// <summary>
@@ -103,10 +110,7 @@ namespace ICD.Common.Utils.Services.Logging
/// <returns></returns>
public override bool Equals(object other)
{
if (other == null || GetType() != other.GetType())
return false;
return GetHashCode() == ((LogItem)other).GetHashCode();
return other is LogItem && Equals((LogItem)other);
}
/// <summary>

View File

@@ -1,9 +1,11 @@
namespace ICD.Common.Utils.Xml
using System;
namespace ICD.Common.Utils.Xml
{
/// <summary>
/// IcdXmlAttribute represents an attribute="value" pair from xml.
/// </summary>
public struct IcdXmlAttribute
public struct IcdXmlAttribute : IEquatable<IcdXmlAttribute>
{
private readonly string m_Name;
private readonly string m_Value;
@@ -41,7 +43,13 @@
/// <returns></returns>
public static bool operator !=(IcdXmlAttribute a1, IcdXmlAttribute a2)
{
return !(a1 == a2);
return !a1.Equals(a2);
}
public bool Equals(IcdXmlAttribute other)
{
return m_Name == other.m_Name &&
m_Value == other.m_Value;
}
/// <summary>
@@ -51,10 +59,7 @@
/// <returns></returns>
public override bool Equals(object other)
{
if (other == null || GetType() != other.GetType())
return false;
return GetHashCode() == ((IcdXmlAttribute)other).GetHashCode();
return other is IcdXmlAttribute && Equals((IcdXmlAttribute)other);
}
/// <summary>