mirror of
https://github.com/spectreconsole/spectre.console.git
synced 2025-12-29 17:28:06 +01:00
Removed the verbs from all extension methods that manipulate properties which makes the API more succinct and easier to read. Also added implicit conversion from string to Style. As a good OSS citizen, I've obsoleted the old methods with a warning for now, so this shouldn't break anyone using the old methods.
67 lines
2.2 KiB
C#
67 lines
2.2 KiB
C#
using System;
|
|
using System.Globalization;
|
|
|
|
namespace Spectre.Console
|
|
{
|
|
/// <summary>
|
|
/// Contains extension methods for <see cref="IHasCulture"/>.
|
|
/// </summary>
|
|
public static class HasCultureExtensions
|
|
{
|
|
/// <summary>
|
|
/// Sets the culture.
|
|
/// </summary>
|
|
/// <typeparam name="T">An object type with a culture.</typeparam>
|
|
/// <param name="obj">The object to set the culture for.</param>
|
|
/// <param name="culture">The culture to set.</param>
|
|
/// <returns>The same instance so that multiple calls can be chained.</returns>
|
|
public static T Culture<T>(this T obj, CultureInfo culture)
|
|
where T : class, IHasCulture
|
|
{
|
|
if (obj is null)
|
|
{
|
|
throw new ArgumentNullException(nameof(obj));
|
|
}
|
|
|
|
if (culture is null)
|
|
{
|
|
throw new ArgumentNullException(nameof(culture));
|
|
}
|
|
|
|
obj.Culture = culture;
|
|
return obj;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets the culture.
|
|
/// </summary>
|
|
/// <typeparam name="T">An object type with a culture.</typeparam>
|
|
/// <param name="obj">The object to set the culture for.</param>
|
|
/// <param name="name">The culture to set.</param>
|
|
/// <returns>The same instance so that multiple calls can be chained.</returns>
|
|
public static T Culture<T>(this T obj, string name)
|
|
where T : class, IHasCulture
|
|
{
|
|
if (name is null)
|
|
{
|
|
throw new ArgumentNullException(nameof(name));
|
|
}
|
|
|
|
return Culture(obj, CultureInfo.GetCultureInfo(name));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets the culture.
|
|
/// </summary>
|
|
/// <typeparam name="T">An object type with a culture.</typeparam>
|
|
/// <param name="obj">The object to set the culture for.</param>
|
|
/// <param name="culture">The culture to set.</param>
|
|
/// <returns>The same instance so that multiple calls can be chained.</returns>
|
|
public static T Culture<T>(this T obj, int culture)
|
|
where T : class, IHasCulture
|
|
{
|
|
return Culture(obj, CultureInfo.GetCultureInfo(culture));
|
|
}
|
|
}
|
|
}
|