summaryrefslogtreecommitdiff
path: root/Runtime/NavMesh/NavMeshProfiler.h
blob: 122b224666eb1e900e595a8a36a85c4add9cbf88 (plain)
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
#ifndef NAVMESHPROFILER_H
#define NAVMESHPROFILER_H

#include "Runtime/Profiler/Profiler.h"
#include "DetourContext.h"

PROFILER_INFORMATION (gCrowdManagerPathFinding, "CrowdManager.PathFinding", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerPathFollowing, "CrowdManager.PathFollowing", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerPathFollowingLate, "CrowdManager.PathFollowing.Late", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerAvoidance, "CrowdManager.Avoidance", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerAvoidanceSampling, "CrowdManager.Avoidance.Sampling", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerProximity, "CrowdManager.Proximity", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerProximityInsert, "CrowdManager.Proximity.Insert", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerProximityCollect, "CrowdManager.Proximity.Collect", kProfilerAI)
PROFILER_INFORMATION (gCrowdManagerCollision, "CrowdManager.Collision", kProfilerAI)

class CrowdProfiler : public dtContext
{
public:
	CrowdProfiler ()
	: dtContext (true)
	{
	}
	virtual ~CrowdProfiler ()
	{
	}

protected:
	virtual void doStartTimer (const dtTimerLabel label)
	{
		switch (label)
		{
		case DT_TIMER_UPDATE_PATHFINDING:
			PROFILER_BEGIN (gCrowdManagerPathFinding, NULL);
			break;
		case DT_TIMER_UPDATE_PATHFOLLOWING:
			PROFILER_BEGIN (gCrowdManagerPathFollowing, NULL);
			break;
		case DT_TIMER_UPDATE_PATHFOLLOWING_LATE:
			PROFILER_BEGIN (gCrowdManagerPathFollowingLate, NULL);
			break;
		case DT_TIMER_UPDATE_AVOIDANCE:
			PROFILER_BEGIN (gCrowdManagerAvoidance, NULL);
			break;
		case DT_TIMER_UPDATE_AVOIDANCE_SAMPLING:
			PROFILER_BEGIN (gCrowdManagerAvoidanceSampling, NULL);
			break;
		case DT_TIMER_UPDATE_PROXIMITY:
			PROFILER_BEGIN (gCrowdManagerProximity, NULL);
			break;
		case DT_TIMER_UPDATE_PROXIMITY_INSERT:
			PROFILER_BEGIN (gCrowdManagerProximityInsert, NULL);
			break;
		case DT_TIMER_UPDATE_PROXIMITY_COLLECT:
			PROFILER_BEGIN (gCrowdManagerProximityCollect, NULL);
			break;
		case DT_TIMER_UPDATE_COLLISION:
			PROFILER_BEGIN (gCrowdManagerCollision, NULL);
			break;
		default:
			break;
		}
	}

	virtual void doStopTimer (const dtTimerLabel /*label*/)
	{
		PROFILER_END
	}
};

#endif