[video member=cmuratori stream_platform=twitch stream_username=handmade_hero project=code title="Introduction to Debug Infrastructure" vod_platform=youtube id=vhSIwxAWDIY annotator=Miblo annotator=debiatan]
[1:07][Plan for today]
[2:34][Test-driven development doesn't help solving the harder problems of game programming]
[4:59][Purpose of debug services]
[6:33][1) Coaxing bugs to the surface]
[8:00][2) Locating bugs that are clearly present but difficult to pinpoint]
[11:58][We'll focus on versatile debug services aimed at solving difficult bugs]
[13:21][Logs. Example of debugging framerate problems]
[15:49][We could start by recording our debug timers on each frame]
[16:35][Simplifying the usage of our debug timers]
[17:38][We could combine the log and the looped live code editing replay system]
[20:01][Limitations of this approach - Is not particularly good for multithreading problems]
[21:23][Necessary components: counter log, replay system, log of memory consumption and diagramming]
[22:16][Diagramming]
[25:57][We want all the debugging subsystems going through the same log]
[27:14][We want to avoid having to change the code in order to debug it...]
[29:11][...and also avoid having to remove debug calls once we're done]
[31:44][Review of desired features for our debug system]
[32:56][Will we need tuning/fiddling support?]
[36:40][Let's start building the debug system]
[38:05][The old debug cycle counters were lousy on purpose]
[43:00][Improving the interface of the cycle counters]
[43:27][Abusing constructor/destructor pairs to achieve that better interface]
[54:49][We shouldn't need to store values anywhere to make paired calls at the beginning and end of a frame]
[57:11]["I just kind of ruined The Variable"][quote 202]
[1:01:03][Review of the inner workings of the new cycle counter interface]
[1:02:15][Testing that the code still runs after today's changes]
[1:02:37][Q&A][:speech]
[1:03:22][@SoysauceTheKid][Is there a way to determine how much overhead the debug takes when it is enabled? (Or is there such a thing as debug levels?)]
[1:04:48][@Psi9][Why not use a simple template? That would remove storing the ID, e.g. template<int ID> struct timed_block {};]
[1:05:50][@insofaras][Would you agree that there is a similarity between test driven development and "writing the usage code first"?]
[1:06:32][@ChaiLatteQuinoa][Would you consider functional programming for game development?]
[1:08:01][@ingenero][How does the StartCycleCount get stored in the struct when you don't explicitly set StartCycleCount = StartCycleCountInit or something what you did with the ID?]
[1:08:55][@jfcatalan][Do you get Heisenbugs, where the bug happens only when there's not any debug code running?]
[1:10:18][@InstantKafka][So the destructor gets called right when it goes out of scope?][quote 203]
[1:14:08][@abnercoimbre][Community fight]
[1:14:25][Close this down and wrap up another episode of Handmade Hero][:speech]
[/video]