mirror of
https://github.com/PredatH0r/ChanSort.git
synced 2026-01-13 19:02:05 +01:00
- LG GlobalClone: modified channel names were not written to the file - LG GlobalClone: ask whether the conflicting xx*.TLL files should be renamed so that the TV can import the GlobalClone file. - LG GlobalClone: improved support for old file format with may have caused errors due to invalid XML characters inside the file. - Panasonic: re-enabled channel lists with gaps in the numbers - Update-Check: looking for latest version at github.com - Detecting corrupted files with 0 size or all bytes with value 0 - upgraded to latest DevExpress version
137 lines
4.1 KiB
C#
137 lines
4.1 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Text;
|
|
|
|
namespace ChanSort.Api
|
|
{
|
|
public static class Tools
|
|
{
|
|
public static V TryGet<K, V>(this IDictionary<K, V> dict, K key)
|
|
{
|
|
V val;
|
|
dict.TryGetValue(key, out val);
|
|
return val;
|
|
}
|
|
|
|
#region GetAnalogChannelNumber()
|
|
public static string GetAnalogChannelNumber(int freq)
|
|
{
|
|
if (freq < 41) return "";
|
|
if (freq <= 68) return ((freq - 41)/7 + 1).ToString("d2"); // Band I (01-04)
|
|
if (freq < 105) return "";
|
|
if (freq <= 174) return "S" + ((freq - 105)/7 + 1).ToString("d2"); // Midband (S01-S10)
|
|
if (freq <= 230) return ((freq - 175)/7 + 5).ToString("d2"); // Band III (05-12)
|
|
if (freq <= 300) return "S" + ((freq - 231)/7 + 11); // Superband (S11-S20)
|
|
if (freq <= 469) return "S" + ((freq - 303)/8 + 21); // Hyperband (S21-S41)
|
|
if (freq <= 1000) return ((freq - 471)/8 + 21).ToString("d2"); // Band IV, V
|
|
return "";
|
|
}
|
|
#endregion
|
|
|
|
#region GetInt16/32()
|
|
|
|
public static int GetInt16(byte[] data, int offset, bool littleEndian)
|
|
{
|
|
return littleEndian ? BitConverter.ToInt16(data, offset) : (data[offset] << 8) + data[offset + 1];
|
|
}
|
|
|
|
public static int GetInt32(byte[] data, int offset, bool littleEndian)
|
|
{
|
|
return littleEndian ? BitConverter.ToInt32(data, offset) :
|
|
(data[offset] << 24) + (data[offset + 1] << 16) + (data[offset + 2] << 8) + data[offset + 3];
|
|
}
|
|
#endregion
|
|
|
|
#region SetInt16/32()
|
|
|
|
public static void SetInt16(byte[] data, int offset, int value, bool littleEndian = true)
|
|
{
|
|
if (littleEndian)
|
|
{
|
|
data[offset + 0] = (byte) value;
|
|
data[offset + 1] = (byte) (value >> 8);
|
|
}
|
|
else
|
|
{
|
|
data[offset + 0] = (byte)(value >> 8);
|
|
data[offset + 1] = (byte) value;
|
|
}
|
|
}
|
|
|
|
public static void SetInt32(byte[] data, int offset, int value, bool littleEndian = true)
|
|
{
|
|
if (littleEndian)
|
|
{
|
|
data[offset + 0] = (byte) value;
|
|
data[offset + 1] = (byte) (value >> 8);
|
|
data[offset + 2] = (byte) (value >> 16);
|
|
data[offset + 3] = (byte) (value >> 24);
|
|
}
|
|
else
|
|
{
|
|
data[offset + 0] = (byte)(value >> 24);
|
|
data[offset + 1] = (byte)(value >> 16);
|
|
data[offset + 2] = (byte)(value >> 8);
|
|
data[offset + 3] = (byte)value;
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region MemCopy(), MemSet()
|
|
|
|
public static void MemCopy(byte[] source, int sourceIndex, byte[] dest, int destIndex, int count)
|
|
{
|
|
for (int i = 0; i < count; i++)
|
|
dest[destIndex + i] = source[sourceIndex + i];
|
|
}
|
|
|
|
public static void MemSet(byte[] data, int offset, byte value, int count)
|
|
{
|
|
for (int i = 0; i < count; i++)
|
|
data[offset++] = value;
|
|
}
|
|
#endregion
|
|
|
|
#region ReverseByteOrder()
|
|
public static ushort ReverseByteOrder(ushort input)
|
|
{
|
|
return (ushort)(((input & 0x00FF) << 8) | (input >> 8));
|
|
}
|
|
|
|
public static uint ReverseByteOrder(uint input)
|
|
{
|
|
return ((input & 0x000000FF) << 24) | ((input & 0x0000FF00) << 8) | ((input & 0x00FF0000) >> 8) | ((input & 0xFF000000) >> 24);
|
|
}
|
|
#endregion
|
|
|
|
#region HexDecode()
|
|
public static byte[] HexDecode(string input)
|
|
{
|
|
var bytes = new byte[input.Length/2];
|
|
for (int i = 0, c = input.Length/2; i < c; i++)
|
|
{
|
|
char ch = Char.ToUpper(input[i*2]);
|
|
var high = Char.IsDigit(ch) ? ch - '0' : ch - 'A' + 10;
|
|
ch = Char.ToUpper(input[i*2 + 1]);
|
|
var low = Char.IsDigit(ch) ? ch - '0' : ch - 'A' + 10;
|
|
bytes[i] = (byte)((high << 4) | low);
|
|
}
|
|
return bytes;
|
|
}
|
|
#endregion
|
|
|
|
#region HexEncode()
|
|
public static string HexEncode(byte[] bytes, bool uppercase = false)
|
|
{
|
|
const string HexDigitsLower = "0123456789abcdef";
|
|
const string HexDigitsUpper = "0123456789ABCDEF";
|
|
var hexDigits = uppercase ? HexDigitsUpper : HexDigitsLower;
|
|
var sb = new StringBuilder(bytes.Length * 2);
|
|
foreach (byte b in bytes)
|
|
sb.Append(hexDigits[b >> 4]).Append(hexDigits[b & 0x0F]);
|
|
return sb.ToString();
|
|
}
|
|
#endregion
|
|
}
|
|
}
|