data:image/s3,"s3://crabby-images/ffa0a/ffa0a47e2ec6dc27680ff0e94671e82e416f544b" alt="Ida hex rays decompiler"
data:image/s3,"s3://crabby-images/9a716/9a716722b0d3c36398ae9bfbcc7376c8de454aa4" alt="ida hex rays decompiler ida hex rays decompiler"
Additionally, the user can also shrink their database by manually purging all caches via Edit->Other->Reset decompiler information., the All caches checkbox. Regardless of caches, Hex-Rays will still re-analyze previously seen functions sometimes.
data:image/s3,"s3://crabby-images/f99bc/f99bcf71853b2e96a6e1d5a2427791d76b41aa07" alt="ida hex rays decompiler ida hex rays decompiler"
That said, these are just caches they can be evicted for reasons such as the user changing the type of a function or global data item used by the cached function.
data:image/s3,"s3://crabby-images/bb8e2/bb8e2cf0dd95a99f360476115f022dd26f72da0e" alt="ida hex rays decompiler ida hex rays decompiler"
The past few versions of Hex-Rays have introduced caches for the decompilation results, particularly the mba_t and cfunc_t structures from the SDK, to speed up displaying decompilation for functions that have recently been analyzed. That's because Hex-Rays often decompiles the same function more than once - numerous times, actually - throughout the course of the user's analysis session. You have probably noticed that Hex-Rays might - or might not - pause noticeably when decompiling a large function that you have already decompiled some time ago. It sounds like you know how to use Hex-Rays to a non-trivial extent.
data:image/s3,"s3://crabby-images/ffa0a/ffa0a47e2ec6dc27680ff0e94671e82e416f544b" alt="Ida hex rays decompiler"