Winify

Subversion Repositories:
Compare Path: Rev
With Path: Rev
?path1? @ 37  →  ?path2? @ 38
/trunk/Winify/Utilities/Miscellaneous.cs
@@ -17,30 +17,32 @@
 
public static bool LaunchOnBootSet(bool enable)
{
using var key = Registry.CurrentUser.OpenSubKey
("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run", true);
using (var key = Registry.CurrentUser.OpenSubKey
("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run", true))
{
if (key == null) return false;
 
if (key == null) return false;
switch (enable)
{
case true:
key.SetValue(Constants.AssemblyName, Assembly.GetEntryAssembly().Location);
break;
default:
key.DeleteValue(Constants.AssemblyName, false);
break;
}
 
switch (enable)
{
case true:
key.SetValue(Constants.AssemblyName, Assembly.GetEntryAssembly().Location);
break;
default:
key.DeleteValue(Constants.AssemblyName, false);
break;
return true;
}
 
return true;
}
 
public static bool LaunchOnBootGet()
{
using var key = Registry.CurrentUser.OpenSubKey
("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run", true);
 
return key?.GetValue(Constants.AssemblyName) != null;
using (var key = Registry.CurrentUser.OpenSubKey
("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run", true))
{
return key?.GetValue(Constants.AssemblyName) != null;
}
}
 
/// <summary>
@@ -64,11 +66,13 @@
public static async Task<Icon> CreateIconFromResource(string resource)
{
var iconBytes = await LoadResource(resource);
using var iconMemoryStream = new MemoryStream(iconBytes);
var bitmap = (Bitmap)Image.FromStream(iconMemoryStream);
var bitmapIntPtr = bitmap.GetHicon();
var icon = Icon.FromHandle(bitmapIntPtr);
return icon;
using (var iconMemoryStream = new MemoryStream(iconBytes))
{
var bitmap = (Bitmap)Image.FromStream(iconMemoryStream);
var bitmapIntPtr = bitmap.GetHicon();
var icon = Icon.FromHandle(bitmapIntPtr);
return icon;
}
}
 
public static async Task<byte[]> LoadResource(string resource)
@@ -75,17 +79,18 @@
{
var assembly = Assembly.GetExecutingAssembly();
 
using var manifestResourceStream = assembly.GetManifestResourceStream(resource);
using (var manifestResourceStream = assembly.GetManifestResourceStream(resource))
{
if (manifestResourceStream == null) return null;
 
if (manifestResourceStream == null) return null;
var memoryStream = new MemoryStream();
 
var memoryStream = new MemoryStream();
await manifestResourceStream.CopyToAsync(memoryStream);
 
await manifestResourceStream.CopyToAsync(memoryStream);
memoryStream.Position = 0L;
 
memoryStream.Position = 0L;
 
return memoryStream.ToArray();
return memoryStream.ToArray();
}
}
 
public static void InvokeIfRequired<T>(this T control, Action<T> action) where T : Control
/trunk/Winify/Utilities/Serialization/Serialization.cs
@@ -49,26 +49,29 @@
 
settings.Schemas.Add(targetNamespace, schemeUri);
 
using var fileStream =
await Miscellaneous.GetFileStream(file, FileMode.Open, FileAccess.Read, FileShare.Read,
cancellationToken);
using (var fileStream =
await Miscellaneous.GetFileStream(file, FileMode.Open, FileAccess.Read, FileShare.Read,
cancellationToken))
{
using (var xmlReader = XmlReader.Create(fileStream,
settings))
{
var stringBuilder = new StringBuilder();
 
using var xmlReader = XmlReader.Create(fileStream,
settings);
using (var stringWriter = new StringWriter(stringBuilder))
{
while (await xmlReader.ReadAsync())
await stringWriter.WriteAsync(await xmlReader.ReadOuterXmlAsync());
}
 
var stringBuilder = new StringBuilder();
 
using (var stringWriter = new StringWriter(stringBuilder))
{
while (await xmlReader.ReadAsync())
await stringWriter.WriteAsync(await xmlReader.ReadOuterXmlAsync());
using (var stringReader = new StringReader(stringBuilder.ToString()))
{
servers =
(T)xmlSerializer
.Deserialize(stringReader);
}
}
}
 
using var stringReader = new StringReader(stringBuilder.ToString());
 
servers =
(T)xmlSerializer
.Deserialize(stringReader);
}
catch (Exception exception)
{
@@ -90,30 +93,36 @@
 
try
{
using var memoryStream = new MemoryStream();
using var xmlWriter =
XmlWriter.Create(memoryStream,
new XmlWriterSettings
{
Async = true,
Indent = true,
IndentChars = " ",
OmitXmlDeclaration = false
});
await xmlWriter.WriteDocTypeAsync(name,
null,
null,
subset);
using (var memoryStream = new MemoryStream())
{
using (var xmlWriter =
XmlWriter.Create(memoryStream,
new XmlWriterSettings
{
Async = true,
Indent = true,
IndentChars = " ",
OmitXmlDeclaration = false
}))
{
await xmlWriter.WriteDocTypeAsync(name,
null,
null,
subset);
 
xmlSerializer.Serialize(xmlWriter, servers);
xmlSerializer.Serialize(xmlWriter, servers);
 
using var fileStream =
await Miscellaneous.GetFileStream(file, FileMode.Create, FileAccess.Write, FileShare.Write,
cancellationToken);
using (var fileStream =
await Miscellaneous.GetFileStream(file, FileMode.Create, FileAccess.Write,
FileShare.Write,
cancellationToken))
{
memoryStream.Position = 0L;
 
memoryStream.Position = 0L;
 
await memoryStream.CopyToAsync(fileStream);
await memoryStream.CopyToAsync(fileStream);
}
}
}
}
catch (Exception exception)
{