mirror of
https://github.com/ckaczor/FeedCenter.git
synced 2026-02-16 10:58:31 -05:00
Initial commit
This commit is contained in:
228
App.xaml.cs
Normal file
228
App.xaml.cs
Normal file
@@ -0,0 +1,228 @@
|
||||
using System;
|
||||
using System.Diagnostics;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Threading;
|
||||
using Microsoft.Win32;
|
||||
|
||||
using Common.Debug;
|
||||
using Common.Helpers;
|
||||
using Common.IO;
|
||||
using Common.Wpf.Extensions;
|
||||
using Common.Settings;
|
||||
|
||||
using FeedCenter.Properties;
|
||||
|
||||
namespace FeedCenter
|
||||
{
|
||||
public partial class App
|
||||
{
|
||||
#region Debug properties
|
||||
|
||||
public static bool UseDebugPath;
|
||||
|
||||
#endregion
|
||||
|
||||
#region Properties
|
||||
|
||||
public bool Restart;
|
||||
|
||||
#endregion
|
||||
|
||||
#region Main function
|
||||
|
||||
[STAThread]
|
||||
public static void Main()
|
||||
{
|
||||
// Create and initialize the app object
|
||||
App app = new App();
|
||||
app.InitializeComponent();
|
||||
|
||||
// Create an isolation handle to see if we are already running
|
||||
IDisposable isolationHandle = ApplicationIsolation.GetIsolationHandle(FeedCenter.Properties.Resources.ApplicationName);
|
||||
|
||||
// If there is another copy then pass it the command line and exit
|
||||
if (isolationHandle == null)
|
||||
{
|
||||
InterprocessMessageSender.SendMessage(FeedCenter.Properties.Resources.ApplicationName, Environment.CommandLine);
|
||||
return;
|
||||
}
|
||||
|
||||
// Use the handle over the lifetime of the application
|
||||
using (isolationHandle)
|
||||
{
|
||||
// Set the data directory based on debug or not
|
||||
AppDomain.CurrentDomain.SetData("DataDirectory",
|
||||
UseDebugPath
|
||||
? Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)
|
||||
: UserSettingsPath);
|
||||
|
||||
// Get the generic provider
|
||||
var genericProvider = (GenericSettingsProvider) Settings.Default.Providers[typeof(GenericSettingsProvider).Name];
|
||||
|
||||
if (genericProvider == null)
|
||||
return;
|
||||
|
||||
// Set the callbacks into the provider
|
||||
genericProvider.OpenDataStore = SettingsStore.OpenDataStore;
|
||||
genericProvider.CloseDataStore = SettingsStore.CloseDataStore;
|
||||
genericProvider.GetSettingValue = SettingsStore.GetSettingValue;
|
||||
genericProvider.SetSettingValue = SettingsStore.SetSettingValue;
|
||||
genericProvider.DeleteSettingsForVersion = SettingsStore.DeleteSettingsForVersion;
|
||||
genericProvider.GetVersionList = SettingsStore.GetVersionList;
|
||||
|
||||
// Initialize the tracer with the current process ID
|
||||
Tracer.Initialize(UserSettingsPath, FeedCenter.Properties.Resources.ApplicationName, Process.GetCurrentProcess().Id.ToString(CultureInfo.InvariantCulture), false);
|
||||
|
||||
Current.DispatcherUnhandledException += HandleCurrentDispatcherUnhandledException;
|
||||
AppDomain.CurrentDomain.UnhandledException += HandleCurrentDomainUnhandledException;
|
||||
|
||||
// Check if we need to upgrade settings from a previous version
|
||||
if (Settings.Default.FirstRun)
|
||||
{
|
||||
Settings.Default.Upgrade();
|
||||
Settings.Default.FirstRun = false;
|
||||
Settings.Default.Save();
|
||||
}
|
||||
|
||||
// Create the main window before the splash otherwise WPF gets messed up
|
||||
MainWindow mainWindow = new MainWindow();
|
||||
|
||||
// Show the splash window
|
||||
SplashWindow splashWindow = new SplashWindow();
|
||||
splashWindow.ShowDialog();
|
||||
|
||||
// If we don't need to restart then fire up the main window
|
||||
if (!app.Restart)
|
||||
{
|
||||
// Update the registry settings
|
||||
SetStartWithWindows(Settings.Default.StartWithWindows);
|
||||
SetDefaultFeedReader(Settings.Default.RegisterAsDefaultFeedReader);
|
||||
|
||||
// Initialize the window
|
||||
mainWindow.Initialize();
|
||||
|
||||
// Run the app
|
||||
app.Run(mainWindow);
|
||||
}
|
||||
|
||||
// If we need to restart
|
||||
if (app.Restart)
|
||||
{
|
||||
// Wait a bit to make sure any previous upgrade has settled
|
||||
Thread.Sleep(2000);
|
||||
|
||||
// Restart the application
|
||||
Current.Restart();
|
||||
}
|
||||
|
||||
// Terminate the tracer
|
||||
Tracer.Dispose();
|
||||
}
|
||||
}
|
||||
|
||||
private static void HandleCurrentDomainUnhandledException(object sender, UnhandledExceptionEventArgs e)
|
||||
{
|
||||
Tracer.WriteException((Exception) e.ExceptionObject);
|
||||
Tracer.Flush();
|
||||
}
|
||||
|
||||
private static void HandleCurrentDispatcherUnhandledException(object sender, System.Windows.Threading.DispatcherUnhandledExceptionEventArgs e)
|
||||
{
|
||||
Tracer.WriteException(e.Exception);
|
||||
Tracer.Flush();
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Helpers
|
||||
|
||||
public static string UserSettingsPath
|
||||
{
|
||||
get
|
||||
{
|
||||
// If we're running in debug mode then use a local path for the database and logs
|
||||
if (UseDebugPath)
|
||||
return Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location);
|
||||
|
||||
// Get the path to the local application data directory
|
||||
string path = Path.Combine(
|
||||
Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData),
|
||||
FeedCenter.Properties.Resources.ApplicationName);
|
||||
|
||||
// Make sure it exists - create it if needed
|
||||
if (!Directory.Exists(path))
|
||||
Directory.CreateDirectory(path);
|
||||
|
||||
return path;
|
||||
}
|
||||
}
|
||||
|
||||
public static void SetStartWithWindows(bool value)
|
||||
{
|
||||
// Get the application name
|
||||
string applicationName = FeedCenter.Properties.Resources.ApplicationDisplayName;
|
||||
|
||||
// Get application details
|
||||
string publisherName = applicationName;
|
||||
string productName = applicationName;
|
||||
string allProgramsPath = Environment.GetFolderPath(Environment.SpecialFolder.Programs);
|
||||
string shortcutPath = Path.Combine(allProgramsPath, publisherName);
|
||||
|
||||
// Build the auto start path
|
||||
shortcutPath = "\"" + Path.Combine(shortcutPath, productName) + ".appref-ms\"";
|
||||
|
||||
// Set auto start
|
||||
Current.SetStartWithWindows(applicationName, shortcutPath, value);
|
||||
}
|
||||
|
||||
public static void SetDefaultFeedReader(bool value)
|
||||
{
|
||||
// Get the location of the assembly
|
||||
string assemblyLocation = Assembly.GetExecutingAssembly().Location;
|
||||
|
||||
// Open the registry key (creating if needed)
|
||||
using (RegistryKey registryKey = Registry.CurrentUser.CreateSubKey("Software\\Classes\\feed", RegistryKeyPermissionCheck.ReadWriteSubTree))
|
||||
{
|
||||
if (registryKey == null)
|
||||
return;
|
||||
|
||||
// Write the handler settings
|
||||
registryKey.SetValue(string.Empty, "URL:Feed Handler");
|
||||
registryKey.SetValue("URL Protocol", string.Empty);
|
||||
|
||||
// Open the icon subkey (creating if needed)
|
||||
using (RegistryKey subKey = registryKey.CreateSubKey("DefaultIcon", RegistryKeyPermissionCheck.ReadWriteSubTree))
|
||||
{
|
||||
if (subKey != null)
|
||||
{
|
||||
// Write the assembly location
|
||||
subKey.SetValue(string.Empty, assemblyLocation);
|
||||
|
||||
// Close the subkey
|
||||
subKey.Close();
|
||||
}
|
||||
}
|
||||
|
||||
// Open the subkey for the command (creating if needed)
|
||||
using (RegistryKey subKey = registryKey.CreateSubKey("shell\\open\\command", RegistryKeyPermissionCheck.ReadWriteSubTree))
|
||||
{
|
||||
if (subKey != null)
|
||||
{
|
||||
// Write the assembly location and parameter
|
||||
subKey.SetValue(string.Empty, string.Format("\"{0}\" %1", assemblyLocation));
|
||||
|
||||
// Close the subkey
|
||||
subKey.Close();
|
||||
}
|
||||
}
|
||||
|
||||
// Close the registry key
|
||||
registryKey.Close();
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user