forked from XenHat/TrayReader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProgram.cs
224 lines (197 loc) · 8.47 KB
/
Program.cs
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
// This is an open source non-commercial project. Dear PVS-Studio, please check it.
// PVS-Studio Static Code Analyzer for C, C++ and C#: http://www.viva64.com
// Based on https://www.codeproject.com/Articles/290013/Formless-System-Tray-Application
using System;
using System.Diagnostics;
using System.Reflection;
using System.Threading;
using System.Windows.Forms;
namespace TrayApp
{
internal static class Helper
{
public static System.Collections.Generic.List<string> Convert(System.Collections.Specialized.StringCollection collection)
{
System.Collections.Generic.List<string> list = new System.Collections.Generic.List<string>();
foreach (string item in collection)
{
list.Add(item);
}
return list;
}
public static System.Collections.Specialized.StringCollection Convert(System.Collections.Generic.List<string> list)
{
System.Collections.Specialized.StringCollection collection = new System.Collections.Specialized.StringCollection();
foreach (string item in list)
{
collection.Add(item);
}
return collection;
}
public static bool ValidateInput(string url)
{
return !url.EndsWith(".exe");
}
}
internal static class Program
{
public static bool isTimerRunning = false;
public static string ProductName = ((AssemblyProductAttribute)Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyProductAttribute), true)[0]).Product;
/// <summary>
/// Static instance of the Tray Icon
/// </summary>
public static NotifyIcon sTrayIcon = new NotifyIcon();
private static Stopwatch stopWatch;
public static void DoIdleTasks()
{
stopWatch.Reset();
if (TrayApp.Properties.Settings.Default.KillOnIdle)
{
// NOTE: I would prefer to check the process' GPU usage but this appears to be
// difficult to obtain.
//if (CPUStats.currentCPUUsage < 30.0)
{
ProcessDestroyer.KillProcessByName(TrayApp.Properties.Settings.Default.KnownGPUProcesses);
}
}
if (TrayApp.Properties.Settings.Default.ForceOnDemandPowerPlan)
{
// FIXME: This spawns a command window
Integration.SetPowerPlanToOnDemand();
}
}
public static void ExceptionHandler(Exception exception)
{
// Meep.
System.Windows.Forms.MessageBox.Show(
exception.ToString(), ":( Sortahandled Exception! - " + ((AssemblyProductAttribute)Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyProductAttribute), true)[0]).Product.ToString(),
System.Windows.Forms.MessageBoxButtons.OK, System.Windows.Forms.MessageBoxIcon.Error);
}
public static void OnTimedEvent(Object state)
{
// TODO: check for user input
if (stopWatch.Elapsed.Minutes >= 30)
{
DoIdleTasks();
}
}
/// <summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
private static void Main()
{
// Quit if already running https://stackoverflow.com/a/6392264
Mutex mutex = new System.Threading.Mutex(false, ProductName);
try
{
if (mutex.WaitOne(0, false))
{
// Show the system tray icon.
Application.EnableVisualStyles();
//Application.SetCompatibleTextRenderingDefault(true);
// Attach a context menu.
MenuGenerator.ContextMenus.RegenerateMenu();
stopWatch = Stopwatch.StartNew();
SettingsManager.LoadSettings();
// Put the icon in the system tray
sTrayIcon.Icon = TrayApp.Properties.Resources.GPUIdleHelper;
sTrayIcon.Text = "GPUIdleHelper";
sTrayIcon.Visible = true;
// Create an AutoResetEvent to signal the timeout threshold in the
// timer callback has been reached.
var autoEvent = new AutoResetEvent(false);
System.Threading.Timer gTimer = new System.Threading.Timer(OnTimedEvent, autoEvent, 0, 5000);
isTimerRunning = true;
// Make sure the application runs!
Application.Run();
}
}
finally
{
if (mutex != null)
{
mutex.Close();
mutex = null;
}
}
}
//private class CPUStats
//{
// public static float currentCPUUsage;
// protected static PerformanceCounter cpuCounter;
// protected static PerformanceCounter ramCounter;
// private static List<float> AvailableCPU = new List<float>();
// private static List<float> AvailableRAM = new List<float>();
// private static int cores = 0;
// private static List<PerformanceCounter> cpuCounters = new List<PerformanceCounter>();
// public static void ConsumeCPU()
// {
// int percentage = 60;
// if (percentage < 0 || percentage > 100) //-V3022
// throw new ArgumentException("percentage");
// Stopwatch watch = new Stopwatch();
// watch.Start();
// while (true)
// {
// // Make the loop go on for "percentage" milliseconds then sleep the remaining
// // percentage milliseconds. So 40% utilization means work 40ms and sleep 60ms
// if (watch.ElapsedMilliseconds > percentage)
// {
// Thread.Sleep(100 - percentage);
// watch.Reset();
// watch.Start();
// }
// }
// }
// public static void TimerElapsed(object source, ElapsedEventArgs e)
// {
// float cpu = cpuCounter.NextValue();
// float sum = 0;
// foreach (PerformanceCounter c in cpuCounters)
// {
// sum = sum + c.NextValue();
// }
// sum = sum / (cores);
// float ram = ramCounter.NextValue();
// Console.WriteLine(string.Format("CPU Value 1: {0}, cpu value 2: {1} ,ram value: {2}", sum, cpu, ram));
// AvailableCPU.Add(sum);
// AvailableRAM.Add(ram);
// currentCPUUsage = sum;
// }
// private static void Main(string[] args)
// {
// cpuCounter = new PerformanceCounter();
// cpuCounter.CategoryName = "Processor";
// cpuCounter.CounterName = "% Processor Time";
// cpuCounter.InstanceName = "_Total";
// foreach (var item in new System.Management.ManagementObjectSearcher("Select * from Win32_Processor").Get())
// {
// cores = cores + int.Parse(item["NumberOfCores"].ToString());
// }
// ramCounter = new PerformanceCounter("Memory", "Available MBytes");
// int procCount = System.Environment.ProcessorCount;
// for (int i = 0; i < procCount; i++)
// {
// System.Diagnostics.PerformanceCounter pc = new System.Diagnostics.PerformanceCounter("Processor", "% Processor Time", i.ToString());
// cpuCounters.Add(pc);
// }
// Thread c = new Thread(ConsumeCPU);
// c.IsBackground = true;
// c.Start();
// try
// {
// System.Timers.Timer t = new System.Timers.Timer(1200);
// t.Elapsed += new ElapsedEventHandler(TimerElapsed);
// t.Start();
// Thread.Sleep(10000);
// }
// catch (Exception e)
// {
// ExceptionHandler(e);
// }
// Console.ReadLine();
// }
//}
}
}