-
Notifications
You must be signed in to change notification settings - Fork 129
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Should not collapse adjacent equivalently-named stacks in flame chart mode #185
Comments
Yeah, I agree this seems like a bug in flame chart mode. The merging code is not particularly readable, which stems from the fact that it was directly ported from the perl version (which is arguably even worse). I believe the issue arises here: inferno/src/flamegraph/merge.rs Line 43 in 432d653
Specifically, what happens is that the merge logic tries to find the shared prefix between two consecutive entries to determine what frames should be added or removed. In your case, the shared prefix is the entire entry, so the two entries are merged ( The simple solution here would be to notify this method that we're in flamechart mode, and then modify the code such that if That solution has a shortcoming though, which is that if given stacks like:
It'll render two |
Hm, interesting. I had not thought about the complication you note with determining where in the stack we should split. I suspect that the current textual format is just not capable of representing the desired information, the interface needs to represent a tree and that's not possible by just listing parents of nodes. That said, there is a workaround -- we can support some way of identifying nodes uniquely, e.g., |
In some sense, this gets back to the point I was making in #186 — inferno is currently built to match flamegraph very closely, and that includes its assumptions about how applications are profiled (by sampling) which are encoded all the way down to the input format (the "collapsed" text files). I think long term, the solution here is to try and move inferno away from the assumptions that flamegraph makes. The biggest thing here will be to make collapsing just one way to feed data to the flamegrapher. Essentially, we'd want #30 to give an API that give the caller more control over how time is measured and frames are rendered, and then implement an "adapter" that takes a collapsed text file and uses that API to produce what it does today. Whereas more sophisticated implementations (like yours) could use the API to render what they want. Now, realistically, that is a decent amount of effort. It's not even clear to me what such an API should look like. Maybe what we want is to add an additional "tree constructor stage", which consists essentially of the flamegraph collapse -> build tree -> graph tree In your case, you would forego the first two stages, and just directly graph your tree. For the |
Hm, actually, I think I found a solution -- sort of a hack, but it seems to work. Each distinct call stack can be delimited by a zero-width spacer which will not even be included in the final SVG, so is entirely transparent to the user I think. For example, if you had a calling b twice, which in turn called c, you would encode that like so:
But if a called b once, which then called c twice, then that would be encoded like this:
I don't know if it makes sense to document this somehow... |
Yes, I like that workaround! And best of all, it requires no changes :p I agree with you that it'd be good to document. Since there isn't really a library API at the moment, it's not quite clear where that documentation would go though. The crate-level documentation is currently mainly about the command-line interface, so that doesn't seem quite right. My inclination for now is to place it in the module docs for the |
For example, with the input of
I would expect 3 nodes in the output:
a
with width 2b
with width 1b
with width 1Currently, though, inferno combines the two
b
s into one. I wasn't able to quickly follow the merging code so not sure exactly what is causing this, but seems like a bug.The text was updated successfully, but these errors were encountered: