These are a little difficult to track down because by default I'm drawing pretty close to the origin, so the relative positions are often very similar to the absolute ones. As a result, the bugs would appear inconsistently. I was attempting to fix these a little while after writing them, and so didn't have all the intentions behind each passed parameter cached in my brain. When stepping through the debugger, the points being passed didn't raise any red flags and so I didn't pay much attention to them. I thought the source of the problem was elsewhere.
Once I had fixed the first bug after an embarrassingly long time, the second time a similar bug came up went much quicker. Awareness is your best defence!
'Best'? Ok, probably not, but it's definitely helpful. There are also a few other potential solutions:
- Differentiating at runtime This involves adding more data to your vector/point structure that indicates which it is at any point during execution. You can look up the details if you're interested, but suffice it to say that I didn't feel like this bug warranted the memory cost. I believe the normal way to do this for 2D would amount to structs 50% larger.
- Language-level types Probably viable - if a little cumbersome - in C++, where types are differentiated basically if they have different names. (Un)fortunately, I'm working in C, not C++ where types are differentiated by structural similarity. i.e. because both types would look something like the following, they would both be allowed as parameters anyway.
- Be smarter and better at debugging Would probably be effective, unfortunately I can only really work with what I have.
- Hungarian notation (screams, babies crying, dramatic hellish music plays...) I happened to read Joel Spolsky's article 'Making Wrong Code Look Wrong' at around the time I had this issue. This probably won't be popular, but this is the route I have taken. Absolute positions/points are now prefixed with 'po', and I have currently left other vectors unprefixed.
1 2 3 4 | typedef struct { f32 X; f32 Y; } point/vector; |
So... just a quick reminder to try and reconsider what assumptions you're making when debugging is unproductive. Stay safe out there!