forked from fatalis/SourceSplit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUtil.cs
86 lines (74 loc) · 3.04 KB
/
Util.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
using System;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Runtime.CompilerServices;
namespace LiveSplit.SourceSplit
{
public class Util
{
/// <summary>
/// Checks if the process is associated with a VAC protected game.
/// We don't want to touch them. Even though reading a VAC process'
/// memory is said to be perfectly fine and only writing is bad.
/// </summary>
public static bool IsVACProtectedProcess(Process p)
{
// http://forums.steampowered.com/forums/showthread.php?t=2465755
// http://en.wikipedia.org/wiki/Valve_Anti-Cheat#Games_that_support_VAC
string[] badExes = { "csgo", "dota2", "swarm", "left4dead",
"left4dead2", "dinodday", "insurgency", "nucleardawn", "ship" };
string[] badMods = { "cstrike", "dods", "hl2mp", "insurgency", "tf", "zps" };
string[] badRootDirs = { "Dark Messiah of Might and Magic Multi-Player" };
if (badExes.Contains(p.ProcessName.ToLower()))
return true;
if (p.ProcessName.ToLower() == "hl2" || p.ProcessName.ToLower() == "mm")
{
// it's too difficult to get another process' start arguments, so let's scan the dir
// http://stackoverflow.com/questions/440932/reading-command-line-arguments-of-another-process-win32-c-code
try
{
string dir = Path.GetDirectoryName(p.MainModule.FileName);
if (dir == null)
return true;
if (new DirectoryInfo(dir).GetDirectories().Any(di => badMods.Contains(di.Name.ToLower())))
return true;
string root = new DirectoryInfo(dir).Name.ToLower();
if (badRootDirs.Any(badRoot => badRoot.ToLower() == root))
return true;
}
catch (Exception ex)
{
Trace.WriteLine(ex.ToString());
return true;
}
}
return false;
}
}
// prepends update count and tick count to every Debug.WriteLine
public class TimedTraceListener : DefaultTraceListener
{
private static TimedTraceListener _instance;
public static TimedTraceListener Instance => _instance ?? (_instance = new TimedTraceListener());
private TimedTraceListener() { }
public int TickCount
{
[MethodImpl(MethodImplOptions.Synchronized)]
get;
[MethodImpl(MethodImplOptions.Synchronized)]
set;
}
public int UpdateCount
{
[MethodImpl(MethodImplOptions.Synchronized)]
get;
[MethodImpl(MethodImplOptions.Synchronized)]
set;
}
public override void WriteLine(string message)
{
base.WriteLine("SourceSplit: " + this.UpdateCount + " " + this.TickCount + " " + message);
}
}
}