Menu

[r404]: / trunk / GoogleContactsSync / ErrorHandler.cs  Maximize  Restore  History

Download this file

76 lines (68 with data), 3.1 kB

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
using System;
using System.Windows.Forms;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Threading;
using System.Globalization;
namespace GoContactSyncMod
{
static class ErrorHandler
{
private static string OSInfo
{
get
{
return VersionInformation.GetWindowsMainVersion().ToString();
}
}
private static string OutlookInfo
{
get
{
return VersionInformation.GetOutlookVersion(Syncronizer.OutlookApplication).ToString();
}
}
// TODO: Write a nice error dialog, that maybe supports directly E-Mail sending as bugreport
public static void Handle(Exception ex)
{
Logger.Log(ex.Message, EventType.Error);
//AppendSyncConsoleText(Logger.GetText());
Logger.Log("Sync failed.", EventType.Error);
try
{
SettingsForm.Instance.ShowBalloonToolTip("Error", ex.Message, ToolTipIcon.Error, 5000, true);
/*
Program.Instance.notifyIcon.BalloonTipTitle = "Error";
Program.Instance.notifyIcon.BalloonTipText = ex.Message;
Program.Instance.notifyIcon.BalloonTipIcon = ToolTipIcon.Error;
Program.Instance.notifyIcon.ShowBalloonTip(5000);
*/
}
catch (Exception exc)
{
// this can fail if form was disposed or not created yet, so catch the exception - balloon is not that important to risk followup error
Logger.Log("Error showing Balloon: " + exc.Message, EventType.Error);
}
string message = "Sorry, an unexpected error occured.\nPlease support us fixing this problem.\n\n1. Ensure that you use the latest release of GCSM. You can download the latest version here:\nhttps://sourceforge.net/projects/googlesyncmod/files/latest/download.\n\n2.If the problem still exists, go to\nhttps://sourceforge.net/projects/googlesyncmod/ and use the Tracker!\nPlease check first if error has already been reported.\nProgram Version: {0}\n\nError Details:\n{1}\n\nOS Version: {2}\nOutlook Version: {3}";
message = string.Format(message, AssemblyVersion, ex.ToString(), OSInfo, OutlookInfo);
try
{
Clipboard.SetText(message);
message += "/n/nHint: This error message is automatically copied to the clipboard.\n";
}
catch (Exception e)
{
Logger.Log("Message couldn't be copied to clipboard: " + e.Message, EventType.Debug);
}
//Logger.Log(message, EventType.Debug);
MessageBox.Show(message, Application.ProductName);
}
private static string AssemblyVersion
{
get
{
return Assembly.GetExecutingAssembly().GetName().Version.ToString();
}
}
}
}
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.