Skip to content

Configurations

Ramon Viladomat edited this page Nov 17, 2020 · 19 revisions

Struct Layout Options & Configurations

This is the help section to setup the Extension options.

Because each solution might need different extra parameters and different needs, the parser options with the extra parameters are stored in a file called StructLayoutSettings.json next to the solution.

The options page can be opened from:

Extensions Menu

Extensions

Bottom-left corner in the Tool Window

Extensions

The options contain the following properties:

Property Description Macros
Automatic Extraction If true, it will try to extract from the current solution the architecture, include paths, preprocessor definitions... No
Extra Preprocessor Defintions Additional preprocessor definitions on top of the auto extracted form the project configuration. Yes
Extra Include Dirs Additional include directories on top of the auto extracted form the project configuration. Yes
Extra Force Includes Additional files to force include on top of the auto extracted form the project configuration. Yes
Extra Parser Args Additional command line arguments passed in to the clang parser. Yes
Enable Warnings If true, the clang parser will output the warnings found. No

Some fields accept macros in the form $(MACRO). The valid macros will depend on the nature of the solution, check below for allowed macros.

The additional include directories, force includes and preprocessor definitions can be typed in following the same format as the Visual Studio properties (; separated). Example:

includePathA;${SolutionDir}Folder/;${ProjectDir}...

The extra arguments will be appended at the end. Example:

-std=c++17 -ftime-trace -I${SolutionDir}Folder/

Remember to use the Save button to apply your changes.

Projects

⚠️ If the project is using PCHs, due to the fact that most of the struct definitions are in header files, the precompiled headers might need to be forced included.

⚠️ Structs within inline files (.inl) might not work due their nature. Being usually part of another header file, the inline file itself may lack dependency information.

⚠️ Some big projects use Unity builds or similar. This might lead to ill-formed dependency trees in some files, leading to parsing errors when attempting to parse a single unit.

Visual Studio Projects

For Visual Studio Projects the Automatic Extraction extracts:

  • Active Configuration: x64 or x86
  • Active Project Properties: VC++ Directories -> Include Directories
  • Active Project Properties: VC++ Directories -> Exclude Directories
  • Active Project Properties: C/C++ -> Language -> C++ Language Standard
  • Active Project Properties: C/C++ -> General -> Additional Include Directories
  • Active Project Properties: C/C++ -> Preprocessor -> Preprocessor Definitions
  • Active Project Properties: Advanced -> Forced Include File
  • Active Project Properties: NMake -> Additional Include Directories
  • Active Project Properties: NMake -> Additional Force Includes
  • Active Project Properties: NMake -> Additional Preprocessor Definitions
  • Active File Properties: C/C++ -> General -> Additional Include Directories
  • Active File Properties: C/C++ -> Preprocessor -> Preprocessor Definitions
  • Active File Properties: Advanced -> Forced Include File

Macros available: All MSBuild macros.

There is a basic Visual Studio solution for testing at TestProjects/Regular

Unreal Engine 4

THIS SETUP ONLY WORKS FOR UE4.sln - A different approach is on the works at the moment.

When dealing with UE4 projects you also have the following extra macros available:

Name Description
UE4ModuleName Fetches the Name of the module that contains the Active File. This is done by moving up folders until finding a folder with a matching .Build.cs. This assumption might be wrong, please feel free to add an issue if there is a better way to detect this.

The recommended default configuration is the following:

Automatic Extraction: Yes
Extra Preprocessor Defintions: UNREAL_CODE_ANALYZER
Extra Force Includes: $(SolutionDir)Engine\Intermediate\Build\Win64\UE4Editor\Development\$(UE4ModuleName)\Definitions.$(UE4ModuleName).h 

Can also be downloaded directly from here.

CMake Projects

When dealing with CMake projects within Visual Studio add the following CMake flag:

CMAKE_EXPORT_COMPILE_COMMANDS / -DCMAKE_EXPORT_COMPILE_COMMANDS=1

The Extension needs to be able to find those compile commands, it will try to figure out its location automatically, but it can also be set explicitly in the options window.

The visual studio default configuration is the following:

Automatic Extraction: Yes
CMake Commands File: $(SolutionDir)out\build\$(Configuration)\compile_commands.json

Whenever a file is queried, the app will parse the compile commands list trying to find the best candidate file to extract the parameters from. Cpp files should just pick the same translation unit commands, but header files will try to match a similar file in the same directory or with the same name.

This is an assumption that should work for most of the use cases but it is not guarantee. If anyone has a better solution I would love to hear about it.

Due to the fact that the project does not have an explicit VS project, the MSBuild macros can't be queried, still a small subset has been implemented:

Macros available:

Name Description
SolutionDir Opened folder path
Configuration The name of the active configuration

There is a basic CMake project for testing at TestProjects/CMake

Clone this wiki locally