Nimfilt is a collection of modules and scripts to help with analyzing Nim binaries. It started out as a CLI demangling tool inspired by c++filt. 
It evolved into a larger set of tools for analyzing Nim, but the original name stuck.
- nimfilt.py: a Python module that implements demangling for Nim. It can also be run as basic CLI tool.
- id_nim_binary.yar: a set of YARA rules to identify Nim ELF and PE binaries.
- nimimfilt_ida.py: Nimfilt for IDA, an IDApython script to help reverse-engineers handle Nim binaries.
Context
Nim is compiled to another language (usually C/C++) before being compiled to a native executable. It also doesn’t include a large runtime.
However, the process still leaves some Nim-specific artefacts and specificites in in the produced binary.
For one, method and module names are mangled using, Nim’s own name scheme which is distinct from C++’s.
This scheme isn’t documented so I relied on the source code of the Nim compiler.
Most of this name mangling in implemented in compiler/msgs.nim and compiler/ccgtypes.nim.
Nimfilt For IDA
The IDAPython script can be run as a one-off or installed as a plugin.
If running as a script, simply launch it from the Nimfilt project directory. It is recommended to do so after auto-analysis has completed and you’ve loaded any additional FLIRT signatures.
Plugin Setup Using Sark‘s Plugin Loader
Add <nimfilt_project_dir>/nimfilt_ida.py to your your plugins.list as per their instruction on installing plugins.
Manual Plugin Setup
- Copy nimfilt.pyto a directory that is included in your IDAPython’sPYTHONPATH(commonly<IDA_install_dir>/python/or%APPDATA%/Hex-Rays/IDA Pro/python/3/).
- Copy nimfilt_ida.pyto your IDAPython plugin directory (usually<IDA_install_dir>/plugins/)
Usage
*Note: The current version of Nimfilt for IDA only supports one command which runs all analyses. *
Navigate to Edit -> Plugins -> Nimfilt and click on it.
You can set Nimfilt to automatically execute when a loaded file is recognized as a Nim binary. To do so, set the AUTO_RUN global variable to True in nimfilt_ida.py
Features
Current features include:
- Identifying if a loaded file is a Nim binary.
- Demangling Nim function and package names.
- Demangling Nim package init function names.
- Organizing functions into directories by package.
- Identifying, typing and renaming Nim strings.
 
	