Winify

Subversion Repositories:
Compare Path: Rev
With Path: Rev
?path1? @ 37  →  ?path2? @ 38
/trunk/Winify/Utilities/Miscellaneous.cs
@@ -17,9 +17,9 @@
 
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;
 
switch (enable)
@@ -34,14 +34,16 @@
 
return true;
}
}
 
public static bool LaunchOnBootGet()
{
using var key = Registry.CurrentUser.OpenSubKey
("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run", true);
 
using (var key = Registry.CurrentUser.OpenSubKey
("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run", true))
{
return key?.GetValue(Constants.AssemblyName) != null;
}
}
 
/// <summary>
/// Enable double buffering for an arbitrary control.
@@ -64,19 +66,21 @@
public static async Task<Icon> CreateIconFromResource(string resource)
{
var iconBytes = await LoadResource(resource);
using var iconMemoryStream = new MemoryStream(iconBytes);
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)
{
var assembly = Assembly.GetExecutingAssembly();
 
using var manifestResourceStream = assembly.GetManifestResourceStream(resource);
 
using (var manifestResourceStream = assembly.GetManifestResourceStream(resource))
{
if (manifestResourceStream == null) return null;
 
var memoryStream = new MemoryStream();
@@ -87,6 +91,7 @@
 
return memoryStream.ToArray();
}
}
 
public static void InvokeIfRequired<T>(this T control, Action<T> action) where T : Control
{
/trunk/Winify/Utilities/Serialization/Serialization.cs
@@ -49,13 +49,13 @@
 
settings.Schemas.Add(targetNamespace, schemeUri);
 
using var fileStream =
using (var fileStream =
await Miscellaneous.GetFileStream(file, FileMode.Open, FileAccess.Read, FileShare.Read,
cancellationToken);
 
using var xmlReader = XmlReader.Create(fileStream,
settings);
 
cancellationToken))
{
using (var xmlReader = XmlReader.Create(fileStream,
settings))
{
var stringBuilder = new StringBuilder();
 
using (var stringWriter = new StringWriter(stringBuilder))
@@ -64,12 +64,15 @@
await stringWriter.WriteAsync(await xmlReader.ReadOuterXmlAsync());
}
 
using var stringReader = new StringReader(stringBuilder.ToString());
 
using (var stringReader = new StringReader(stringBuilder.ToString()))
{
servers =
(T)xmlSerializer
.Deserialize(stringReader);
}
}
}
}
catch (Exception exception)
{
return new SerializationFailure(exception, validationEventArgs);
@@ -90,8 +93,9 @@
 
try
{
using var memoryStream = new MemoryStream();
using var xmlWriter =
using (var memoryStream = new MemoryStream())
{
using (var xmlWriter =
XmlWriter.Create(memoryStream,
new XmlWriterSettings
{
@@ -99,7 +103,8 @@
Indent = true,
IndentChars = " ",
OmitXmlDeclaration = false
});
}))
{
await xmlWriter.WriteDocTypeAsync(name,
null,
null,
@@ -107,14 +112,18 @@
 
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;
 
await memoryStream.CopyToAsync(fileStream);
}
}
}
}
catch (Exception exception)
{
return new SerializationFailure(exception);