fix: Fixed a bug where CultureInfo was not being cloned correctly

This commit is contained in:
Chris Cameron
2019-09-10 17:16:31 -04:00
parent b6f64bb9b2
commit 0821dcb3ca
2 changed files with 46 additions and 39 deletions

View File

@@ -5,6 +5,7 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
## [Unreleased] ## [Unreleased]
### Added ### Added
- Added a method for converting 24 hour to 12 hour format - Added a method for converting 24 hour to 12 hour format
- Added a method for determining if a culture uses 24 hour format - Added a method for determining if a culture uses 24 hour format
@@ -13,6 +14,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
### Changed ### Changed
- The Root Config path in Net Standard will now be the ICD.Connect folder in the current environments ProgramData directory - The Root Config path in Net Standard will now be the ICD.Connect folder in the current environments ProgramData directory
- Fixed a bug where CultureInfo was not being cloned correctly
## [9.8.0] - 2019-09-03 ## [9.8.0] - 2019-09-03
### Added ### Added

View File

@@ -203,17 +203,18 @@ namespace ICD.Common.Utils.Globalization
public override DateTimeFormatInfo DateTimeFormat public override DateTimeFormatInfo DateTimeFormat
{ {
get get
{
if (m_DatetimeFormat == null)
{ {
if (m_IsResident) if (m_IsResident)
return base.DateTimeFormat; return base.DateTimeFormat;
ThrowIfNeutralCulture(this); ThrowIfNeutralCulture(this);
if (m_DatetimeFormat == null)
{
DateTimeFormatInfo dateTimeFormatInfo = GetDateTimeFormat(m_DatetimeFormatId); DateTimeFormatInfo dateTimeFormatInfo = GetDateTimeFormat(m_DatetimeFormatId);
if (IsReadOnly) if (IsReadOnly)
dateTimeFormatInfo = DateTimeFormatInfo.ReadOnly(dateTimeFormatInfo); dateTimeFormatInfo = DateTimeFormatInfo.ReadOnly(dateTimeFormatInfo);
m_DatetimeFormat = dateTimeFormatInfo; m_DatetimeFormat = dateTimeFormatInfo;
} }
return m_DatetimeFormat; return m_DatetimeFormat;
@@ -221,13 +222,13 @@ namespace ICD.Common.Utils.Globalization
set set
{ {
if (m_IsResident) if (m_IsResident)
{
base.DateTimeFormat = value; base.DateTimeFormat = value;
return;
}
ThrowIfReadOnly(); ThrowIfReadOnly();
if (value == null) if (value == null)
throw new ArgumentException("value"); throw new ArgumentException("value");
m_DatetimeFormat = value; m_DatetimeFormat = value;
} }
} }
@@ -245,17 +246,18 @@ namespace ICD.Common.Utils.Globalization
public override NumberFormatInfo NumberFormat public override NumberFormatInfo NumberFormat
{ {
get get
{
if (m_NumberFormat == null)
{ {
if (m_IsResident) if (m_IsResident)
return base.NumberFormat; return base.NumberFormat;
ThrowIfNeutralCulture(this); ThrowIfNeutralCulture(this);
if (m_NumberFormat == null)
{
NumberFormatInfo numberFormatInfo = GetNumberFormat(m_NumberFormatId); NumberFormatInfo numberFormatInfo = GetNumberFormat(m_NumberFormatId);
if (IsReadOnly) if (IsReadOnly)
numberFormatInfo = NumberFormatInfo.ReadOnly(numberFormatInfo); numberFormatInfo = NumberFormatInfo.ReadOnly(numberFormatInfo);
m_NumberFormat = numberFormatInfo; m_NumberFormat = numberFormatInfo;
} }
return m_NumberFormat; return m_NumberFormat;
@@ -263,13 +265,13 @@ namespace ICD.Common.Utils.Globalization
set set
{ {
if (m_IsResident) if (m_IsResident)
{
base.NumberFormat = value; base.NumberFormat = value;
return;
}
ThrowIfReadOnly(); ThrowIfReadOnly();
if (value == null) if (value == null)
throw new ArgumentException("value"); throw new ArgumentException("value");
m_NumberFormat = value; m_NumberFormat = value;
} }
} }
@@ -851,14 +853,14 @@ namespace ICD.Common.Utils.Globalization
try try
{ {
m_CompareInfo = ci.CompareInfo; m_CompareInfo = ci.CompareInfo;
goto IL_CE;
} }
catch (PlatformNotSupportedException) catch (PlatformNotSupportedException)
{ {
m_CompareInfo = CultureInfo.InvariantCulture.CompareInfo; m_CompareInfo = CultureInfo.InvariantCulture.CompareInfo;
goto IL_CE;
} }
} }
else
{
m_Calendar = icdCultureInfo.m_Calendar; m_Calendar = icdCultureInfo.m_Calendar;
m_CalendarType = icdCultureInfo.m_CalendarType; m_CalendarType = icdCultureInfo.m_CalendarType;
m_GregorianCalendarType = icdCultureInfo.m_GregorianCalendarType; m_GregorianCalendarType = icdCultureInfo.m_GregorianCalendarType;
@@ -868,7 +870,8 @@ namespace ICD.Common.Utils.Globalization
m_Parent = icdCultureInfo.m_Parent; m_Parent = icdCultureInfo.m_Parent;
m_TextInfo = icdCultureInfo.m_TextInfo; m_TextInfo = icdCultureInfo.m_TextInfo;
m_CompareInfo = icdCultureInfo.m_CompareInfo; m_CompareInfo = icdCultureInfo.m_CompareInfo;
IL_CE: }
m_EnglishName = ci.EnglishName; m_EnglishName = ci.EnglishName;
m_IsNeutralCulture = ci.IsNeutralCulture; m_IsNeutralCulture = ci.IsNeutralCulture;
m_Lcid = ci.LCID; m_Lcid = ci.LCID;
@@ -877,19 +880,21 @@ namespace ICD.Common.Utils.Globalization
m_ThreeLetterIsoLanguageName = ci.ThreeLetterISOLanguageName; m_ThreeLetterIsoLanguageName = ci.ThreeLetterISOLanguageName;
m_ThreeLetterWindowsLanguageName = ci.ThreeLetterWindowsLanguageName; m_ThreeLetterWindowsLanguageName = ci.ThreeLetterWindowsLanguageName;
m_TwoLetterIsoLanguageName = ci.TwoLetterISOLanguageName; m_TwoLetterIsoLanguageName = ci.TwoLetterISOLanguageName;
if (!m_IsNeutralCulture)
{ if (m_IsNeutralCulture)
return;
if (icdCultureInfo == null) if (icdCultureInfo == null)
{ {
m_DatetimeFormat = ci.DateTimeFormat; m_DatetimeFormat = ci.DateTimeFormat.Clone() as DateTimeFormatInfo;
m_NumberFormat = ci.NumberFormat; m_NumberFormat = ci.NumberFormat.Clone() as NumberFormatInfo;
return; return;
} }
m_DatetimeFormatId = icdCultureInfo.m_DatetimeFormatId; m_DatetimeFormatId = icdCultureInfo.m_DatetimeFormatId;
m_DatetimeFormat = icdCultureInfo.m_DatetimeFormat; m_DatetimeFormat = icdCultureInfo.m_DatetimeFormat.Clone() as DateTimeFormatInfo;
m_NumberFormatId = icdCultureInfo.m_NumberFormatId; m_NumberFormatId = icdCultureInfo.m_NumberFormatId;
m_NumberFormat = icdCultureInfo.m_NumberFormat; m_NumberFormat = icdCultureInfo.m_NumberFormat.Clone() as NumberFormatInfo;
}
} }
#region Methods #region Methods