2017-04-17 11:31:46 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace SweetLib.Utils
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// A generic class containing useful methods.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static class SweetUtils
|
|
|
|
|
{
|
|
|
|
|
public static char DefaultFileNameReplaceChar { get; set; } = '-';
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Legalizes a file name with the <see cref="DefaultFileNameReplaceChar"/> character.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="fileName">File name to legalize.</param>
|
|
|
|
|
/// <returns>Legalized file name.</returns>
|
|
|
|
|
public static string LegalizeFilename(string fileName)
|
|
|
|
|
{
|
|
|
|
|
return LegalizeFilename(fileName, '-');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Legalizes a file name by a given replace character.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="fileName">File name to legalize.</param>
|
|
|
|
|
/// <param name="replaceChar">Character to be used as replace character.</param>
|
|
|
|
|
/// <returns>Legalized file name.</returns>
|
|
|
|
|
public static string LegalizeFilename(string fileName, char replaceChar)
|
|
|
|
|
{
|
|
|
|
|
var invalidChars = System.IO.Path.GetInvalidFileNameChars();
|
|
|
|
|
|
2017-05-20 10:17:59 +02:00
|
|
|
|
if (invalidChars.Contains(replaceChar))
|
2017-04-17 11:31:46 +02:00
|
|
|
|
throw new IOException($"Replace character {replaceChar} is an invalid file name character.");
|
|
|
|
|
|
|
|
|
|
return invalidChars.Aggregate(fileName, (current, c) => current.Replace(c, replaceChar));
|
|
|
|
|
}
|
2017-05-20 10:17:59 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Converts a <see cref="DateTime"/> into an Unix timestamp.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="date"><see cref="DateTime"/> to convert into Unix timestamp.</param>
|
2017-05-20 10:21:04 +02:00
|
|
|
|
/// <returns>Converted Unix timestamp.</returns>
|
2017-05-20 10:17:59 +02:00
|
|
|
|
public static double DateTimeToUnixTimeStamp(DateTime date)
|
|
|
|
|
{
|
|
|
|
|
return date.Subtract(new DateTime(1970, 1, 1)).TotalSeconds;
|
|
|
|
|
}
|
2017-05-20 10:21:04 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Converts an Unix timestamp into a <see cref="DateTime"/>.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="timestamp">Unix timestamp to convert.</param>
|
|
|
|
|
/// <returns>Converted <see cref="DateTime"/>.</returns>
|
|
|
|
|
public static DateTime UnixTimestampToDateTime(double timestamp)
|
|
|
|
|
{
|
|
|
|
|
return new DateTime(1970, 1, 1).AddMilliseconds(timestamp);
|
|
|
|
|
}
|
2017-04-17 11:31:46 +02:00
|
|
|
|
}
|
|
|
|
|
}
|