/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); |