TLDR:
Showing references in Understand graphical trees is a great way to hone in on the calls that built the tree as you debug or try to comprehend source code.
Details:
Here is the butterfly graph showing the Call and CallBys for the function AssignPeopleToPlaces() of the Imperial College COVID model that I’ve looked at in prior articles.
data:image/s3,"s3://crabby-images/8a312/8a312cabf41e22785a0448c6975eac7fb1574841" alt=""
I’ve circled an area of interest, but where the graph is kind of confusing to read:
data:image/s3,"s3://crabby-images/c764b/c764bc34b4bcd94bfa112078bd1f40d5410500cd" alt=""
We already covered a way to demystify a confusing graph – the “Relationship Graph“. I’m going to do one of those between my function of interest and “exp()”:
data:image/s3,"s3://crabby-images/d5ccc/d5ccc00c6c9efc9477f20d27fbc03183dbb86941" alt=""
That’s better… this shows how the code can get from AssignPeopleToPlaces() to exp(), but what are those #’s on the edges of the graph?
They are the number of call references made in the calling function to the next function down the graph. The # is interesting, for sure, but what would really be interesting as I walk this code are the actual calls.
No problem… just Right Click on the # and the references magically appear:
data:image/s3,"s3://crabby-images/d45d5/d45d5fd64c4382ec30f6d0cad657863e623750ef" alt=""
Now using a tool layout I showed you in my “Setup Understand for Awesome Code Browsing” article, I’ve got the Source Previewer (via View->Previewer) docked over on the right side, and [x] Sync and [Prefer] have it grabbing all the requests to show source.
And now as I walk thru this reduced tree, right-clicking, I can visit each of the references for the call relationship between each node in the graph, seeing what the actual source code action looks like as I walk down the graph:
data:image/s3,"s3://crabby-images/4ead3/4ead3356e68f080ed630bb1b5cfd51058e1c5014" alt=""
Summary:
I made a Call/CallBy butterfly graph of a function of interest, then reduced it using the “Relationship Graph”, and then walked the references that built the reduced graph showing the source for each reference as we go. Nice!