Fixed some issues with SettingsDictionary

This commit is contained in:
2024-04-19 00:57:28 +03:00
parent 780614e1e7
commit cadf500400
5 changed files with 45 additions and 88 deletions

View File

@@ -23,8 +23,6 @@ public class Program
{ {
PreLoadComponents(args).Wait(); PreLoadComponents(args).Wait();
if (!AppSettings.ContainsKey("ServerID") || !AppSettings.ContainsKey("token") || !AppSettings.ContainsKey("prefix")) if (!AppSettings.ContainsKey("ServerID") || !AppSettings.ContainsKey("token") || !AppSettings.ContainsKey("prefix"))
Installer.GenerateStartupConfig().Wait(); Installer.GenerateStartupConfig().Wait();

View File

@@ -59,7 +59,6 @@ public class Config
AppSettings["LogFolder"] = _LogsFolder; AppSettings["LogFolder"] = _LogsFolder;
AppSettings["PluginFolder"] = _PluginsFolder; AppSettings["PluginFolder"] = _PluginsFolder;
AppSettings["ArchiveFolder"] = _ArchivesFolder; AppSettings["ArchiveFolder"] = _ArchivesFolder;
AppSettings["PluginDatabase"] = _PluginsDatabaseFile; AppSettings["PluginDatabase"] = _PluginsDatabaseFile;
if (!File.Exists(_PluginsDatabaseFile)) if (!File.Exists(_PluginsDatabaseFile))

View File

@@ -47,7 +47,8 @@ public class PluginsManager
List<PluginOnlineInfo> result = await JsonManager.ConvertFromJson<List<PluginOnlineInfo>>(jsonText); List<PluginOnlineInfo> result = await JsonManager.ConvertFromJson<List<PluginOnlineInfo>>(jsonText);
var currentOS = OperatingSystem.IsWindows() ? OSType.WINDOWS : var currentOS = OperatingSystem.IsWindows() ? OSType.WINDOWS :
OperatingSystem.IsLinux() ? OSType.LINUX : OSType.MACOSX; OperatingSystem.IsLinux() ? OSType.LINUX :
OperatingSystem.IsMacOS() ? OSType.MACOSX : OSType.NONE;
return result.FindAll(pl => (pl.SupportedOS & currentOS) != 0); return result.FindAll(pl => (pl.SupportedOS & currentOS) != 0);
} }

View File

@@ -41,11 +41,13 @@ public class JsonManager
text = new MemoryStream(await File.ReadAllBytesAsync(input)); text = new MemoryStream(await File.ReadAllBytesAsync(input));
else else
text = new MemoryStream(Encoding.ASCII.GetBytes(input)); text = new MemoryStream(Encoding.ASCII.GetBytes(input));
text.Position = 0; text.Position = 0;
var obj = await JsonSerializer.DeserializeAsync<T>(text); var obj = await JsonSerializer.DeserializeAsync<T>(text);
await text.FlushAsync(); await text.FlushAsync();
text.Close(); text.Close();
return (obj ?? default)!; return (obj ?? default)!;
} }
} }

View File

@@ -1,126 +1,83 @@
using System.Collections; using System.Collections;
using System.Collections.Generic; using System.Collections.Generic;
using System.IO; using System.IO;
using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
namespace PluginManager.Others; namespace PluginManager.Others;
public class SettingsDictionary<TKey, TValue>: IDictionary<TKey, TValue> public class SettingsDictionary<TKey, TValue>
{ {
public string? _file { get; } private string _File { get; }
private IDictionary<TKey, TValue>? _dictionary; private IDictionary<TKey, TValue> _Dictionary;
public SettingsDictionary(string? file) public SettingsDictionary(string file)
{ {
_file = file; this._File = file;
_Dictionary = null!;
} }
public async Task SaveToFile() public async Task SaveToFile()
{ {
if (!string.IsNullOrEmpty(_file)) if (!string.IsNullOrEmpty(_File))
await JsonManager.SaveToJsonFile(_file, _dictionary); await JsonManager.SaveToJsonFile(_File, _Dictionary);
}
public async Task<bool> LoadFromFile()
{
if (!string.IsNullOrEmpty(_file))
try
{
if (File.Exists(_file))
{
var FileContent = File.ReadAllText(_file);
if (string.IsNullOrEmpty(FileContent))
File.WriteAllText(_file, "{}");
if (!FileContent.Contains("{") || !FileContent.Contains("}"))
File.WriteAllText(_file, "{}");
}
else
File.WriteAllText(_file, "{}");
_dictionary = await JsonManager.ConvertFromJson<IDictionary<TKey, TValue>>(_file);
return true;
}
catch
{
return false;
}
return false;
} }
public IEnumerator<KeyValuePair<TKey, TValue>> GetEnumerator() public IEnumerator<KeyValuePair<TKey, TValue>> GetEnumerator()
{ {
return _dictionary!.GetEnumerator(); return _Dictionary.GetEnumerator();
} }
IEnumerator IEnumerable.GetEnumerator() public async Task<bool> LoadFromFile()
{ {
return ((IEnumerable)_dictionary!).GetEnumerator(); if (string.IsNullOrEmpty(_File))
} return false;
public void Add(KeyValuePair<TKey, TValue> item) if(!File.Exists(_File))
{ {
_dictionary!.Add(item); _Dictionary = new Dictionary<TKey, TValue>();
return true;
} }
public void Clear() string fileAsText = await File.ReadAllTextAsync(_File);
if(string.IsNullOrEmpty(fileAsText) || string.IsNullOrWhiteSpace(fileAsText))
{ {
_dictionary!.Clear(); _Dictionary = new Dictionary<TKey, TValue>();
return true;
} }
public bool Contains(KeyValuePair<TKey, TValue> item) _Dictionary = await JsonManager.ConvertFromJson<IDictionary<TKey,TValue>>(fileAsText);
{
return _dictionary!.Contains(item); return true;
} }
public void CopyTo(KeyValuePair<TKey, TValue>[] array, int arrayIndex)
{
_dictionary!.CopyTo(array, arrayIndex);
}
public bool Remove(KeyValuePair<TKey, TValue> item)
{
return _dictionary!.Remove(item);
}
public int Count => _dictionary!.Count;
public bool IsReadOnly => _dictionary!.IsReadOnly;
public void Add(TKey key, TValue value) public void Add(TKey key, TValue value)
{ {
_dictionary!.Add(key, value); _Dictionary.Add(key, value);
} }
public bool ContainsKey(TKey key) public bool ContainsKey(TKey key)
{ {
return _dictionary!.ContainsKey(key); return _Dictionary.ContainsKey(key);
} }
public bool Remove(TKey key) public bool Remove(TKey key)
{ {
return _dictionary!.Remove(key); return _Dictionary.Remove(key);
}
public bool TryGetValue(TKey key, out TValue value)
{
return _dictionary!.TryGetValue(key, out value);
} }
public TValue this[TKey key] public TValue this[TKey key]
{ {
get get
{ {
if (_dictionary!.ContainsKey(key)) if(!_Dictionary.ContainsKey(key))
if (_dictionary[key] is string s && !string.IsNullOrEmpty(s) && !string.IsNullOrWhiteSpace(s)) throw new System.Exception($"The key {key} ({typeof(TKey)}) was not present in the dictionary");
return _dictionary[key];
return default!; if(_Dictionary[key] is not TValue)
} throw new System.Exception("The dictionary is corrupted. This error is critical !");
set => _dictionary![key] = value;
}
public ICollection<TKey> Keys => _dictionary!.Keys; return _Dictionary[key];
public ICollection<TValue> Values => _dictionary!.Values; }
set => _Dictionary[key] = value;
}
} }