Struct LayoutVisual Studio Extension for C++ struct memory layout visualization. Visual Studio 2017/2019 Version MotivationIn C++, the structure layout can be affected by different factors. In order to produce performant data cache oriented code or reduce the structure memory footprint, it is important to be aware of the class layouts at the same spot where code is created, updated, removed or debugged. This extension allows programmers to visualize their structures within Visual Studio with just 1 click. FeaturesRight click on top of any C++ struct definition and select Show Struct Layout (or press Alt+L) in order to visualize the memory layout. Stack ModeIn this visualization mode the types with children are stacked in order to allow navigation in and out and get a better sense of overall structure. Flat ModeThe flat mode skips all groups and only shows one layer, producing a more compact view. How it worksStruct Layout can use different systems to parse the C++ files and extract the memory layout information. Depending on the complexity and quirks of the build system and Visual Studio setup one option will be more convinent than the others. The method used can be changed in the Extension Options Window When a Layout request is made the extension does the following:
Clang LibtoolingThis method will process the file location through a Clang LibTooling executable which will parse the current file and headers. This method can give really accurate results as it retrieves the data directly from the Clang AST but it will need the exact build context to be able to properly understand all the code. When a query to the clang libtooling is triggered the extension will try to gather the following data from the active project and configuration:
PDBThis method takes advantage of the fact that the pdb (Program DataBase) will most likely contain all the layout information for all user defined types. This application uses the DIA SDK (Debug Interface Access) to open and query the pdb. This system can be useful if our setup is not ready to be compiled with a Clang compiler, the build system is quite complex hitting some corner cases or we have some MSVC specific code. The caveat is that we would need to compile the projects before performing any queries keeping the pdbs up to date. Documentation |