Object - ToDateTimeOffSetOrDefault
An object extension method that converts this object to a date time off set or default.
public static void Main() { object val1 = "06 July 2008 7:32:47 AM"; object val2 = "17:32:47.003"; object thisInvalid = "FizzBuzz"; DateTimeOffset defaultVal = "1/1/2000 12:00:00 AM".ToDateTime(); string format = "{0, -30} {1, -15}"; Console.WriteLine(format, "Object", "ToDateTimeOffSetOrDefault"); Console.WriteLine(format, "------", "-------------------------"); // C# Extension Method: Object - ToDateTimeOffSetOrDefault Console.WriteLine(format, val1, val1.ToDateTimeOffSetOrDefault()); Console.WriteLine(format, val2, val2.ToDateTimeOffSetOrDefault()); Console.WriteLine(format, thisInvalid, thisInvalid.ToDateTimeOffSetOrDefault()); Console.WriteLine(format, thisInvalid, thisInvalid.ToDateTimeOffSetOrDefault(defaultVal)); Console.WriteLine(format, thisInvalid, thisInvalid.ToDateTimeOffSetOrDefault(() => defaultVal)); }
View Source
using System; public static partial class Extensions { /// <summary> /// An object extension method that converts this object to a date time off set or default. /// </summary> /// <param name="this">The @this to act on.</param> /// <returns>The given data converted to a DateTimeOffset.</returns> public static DateTimeOffset ToDateTimeOffSetOrDefault(this object @this) { try { return new DateTimeOffset(Convert.ToDateTime(@this), TimeSpan.Zero); } catch (Exception) { return default(DateTimeOffset); } } /// <summary> /// An object extension method that converts this object to a date time off set or default. /// </summary> /// <param name="this">The @this to act on.</param> /// <param name="defaultValue">The default value.</param> /// <returns>The given data converted to a DateTimeOffset.</returns> public static DateTimeOffset ToDateTimeOffSetOrDefault(this object @this, DateTimeOffset defaultValue) { try { return new DateTimeOffset(Convert.ToDateTime(@this), TimeSpan.Zero); } catch (Exception) { return defaultValue; } } /// <summary> /// An object extension method that converts this object to a date time off set or default. /// </summary> /// <param name="this">The @this to act on.</param> /// <param name="defaultValue">The default value.</param> /// <param name="useDefaultIfNull">true to use default if null.</param> /// <returns>The given data converted to a DateTimeOffset.</returns> public static DateTimeOffset ToDateTimeOffSetOrDefault(this object @this, DateTimeOffset defaultValue, bool useDefaultIfNull) { if (useDefaultIfNull && @this == null) { return defaultValue; } try { return new DateTimeOffset(Convert.ToDateTime(@this), TimeSpan.Zero); } catch (Exception) { return defaultValue; } } /// <summary> /// An object extension method that converts this object to a date time off set or default. /// </summary> /// <param name="this">The @this to act on.</param> /// <param name="defaultValueFactory">The default value factory.</param> /// <returns>The given data converted to a DateTimeOffset.</returns> public static DateTimeOffset ToDateTimeOffSetOrDefault(this object @this, Func<DateTimeOffset> defaultValueFactory) { try { return new DateTimeOffset(Convert.ToDateTime(@this), TimeSpan.Zero); } catch (Exception) { return defaultValueFactory(); } } /// <summary> /// An object extension method that converts this object to a date time off set or default. /// </summary> /// <param name="this">The @this to act on.</param> /// <param name="defaultValueFactory">The default value factory.</param> /// <param name="useDefaultIfNull">true to use default if null.</param> /// <returns>The given data converted to a DateTimeOffset.</returns> public static DateTimeOffset ToDateTimeOffSetOrDefault(this object @this, Func<DateTimeOffset> defaultValueFactory, bool useDefaultIfNull) { if (useDefaultIfNull && @this == null) { return defaultValueFactory(); } try { return new DateTimeOffset(Convert.ToDateTime(@this), TimeSpan.Zero); } catch (Exception) { return defaultValueFactory(); } } }