SmartAssembly
Latest version: 6.7
SmartAssembly stack trace is invalid when Method Parent Obfuscation is enabled
Date: 1/30/2012
Product: SmartAssembly
This article only applies if you built your product with SmartAssembly 6.6.0 and Method Parent Obfuscation was enabled. The problem should be fixed in SmartAssembly 6.6.1.
If you built your assembly with SmartAssembly 6.6.0 and Method Parent Obfuscation was enabled, the SmartAssembly map file may be be corrupt. If you are affected, when you view error reports submitted from your application, the type names shown in the stack trace are incorrect.
We have released a patch to solve this problem, which you should run on all builds created with SmartAssembly 6.6.0.
Before you start
Before you start, you will need to know where your SmartAssembly map files are saved.
Map files are located by default in the following location:
- On Windows Vista and later: %ProgramData%\Red Gate\SmartAssembly\Maps\
- On earlier versions of Windows: %ProgramFiles%\Red Gate\SmartAssembly 6\Maps\
If you have changed the default map files location, or if you are using SmartAssembly with a shared SQL server database, open SmartAssembly and click Options. The map file path is shown in the Reports Database Options section.

Fixing the map file
To correct the map file:
- Download the patch from http://downloads.red-gate.com/EAP/Smartassembly/SmartAssembly_6.6.0.144_FixMpoMapFile.exe.
- At a command prompt, type:
SmartAssembly_6.6.0.144_FixMpoMapFile "path\to\outputassembly.exe" "\\path\to\mapfiles"
- Replace "path\to\outputassembly.exe" with the obfuscated assembly that was built by SmartAssembly.
- Replace "\\path\to\mapfiles" with the path where the map files are saved.
- Repeat for each assembly that was built with SmartAssembly 6.6.0.
If your map files are stored in a shared network location, you only need to run the command once per build from one computer. You do not need to run the patch on every computer which has SmartAssembly installed.
The map file is rewritten correctly, and a backup copy of the corrupt version is created in case of further problems.
The type names shown in the stack traces in newly-received error reports are now correct. It is not possible to recover the type names from error reports that were received while the map file was corrupt.
Was this article helpful?
SmartAssembly
- Using Smartassembly to obfuscate a windows service
- Obfuscation not renaming identically-named methods in different classes
- Serialization exceptions occurring in obfuscated assemblies
- SmartAssembly skipping obfuscation of some classes in your assembly
- SmartAssembly is not merging or embedding all assembly dependencies
- Can I customize the path to the MDB database?
- System.InvalidOperationException when attempting to connect to local SmartAssembly database
- Protecting website code using SmartAssembly
- Visual Studio Deployment Projects including unprotected builds
- SmartAssembly MSBUILD tasks failing because of difference in log4net assembly
- SmartAssembly Error Reporting: This application has submitted too many reports
- The assembly is being merged, but the dependent assembly isn't
- ERR 2002: Server did not recognize the value of HTTP Header SOAPAction
- The error report is not associated with a valid project ID - SmartAssembly
- Application built with an evaluation edition of SmartAssembly
- How end users can change their participation in Feature Usage Reporting
- Log file for SmartAssembly
- Moving SmartAssembly to another computer
- 'Using JET databases is not possible in 64-bit applications' error when using MSBuild or TFS
- SmartAssembly stack trace is invalid when Method Parent Obfuscation is enabled
- Upgrading SmartAssembly version 4.x to version 5
- Upgrading SmartAssembly Standard to Professional
- Problems building WPF applications with SmartAssembly 6.7
all products
- Some Red Gate products identified as containing a trojan by Anti-Virus software
- Activation may fail with Unknown Error -1
- Product uses web help although a CHM file is available locally
- Argument exception resulting from missing environment variable
- Check for updates may fail when used through proxies
- 'Unidentified Publisher' error when repairing or uninstalling
- Licensing activates product as standard edition
- Moving Red Gate software products to another machine
- Red Gate tools log locations
- The application UI opening slowly when there is no internet access
SmartAssembly
all products
- Red Gate product acknowledgements
- Activating your products
- Activating your products
- Red Gate bundle history
- Check for updates
- Troubleshooting Check for Updates errors
- Current versions
- Deactivating your products
- Installing Red Gate products from the .msi file
- Requesting additional activations
- Serial numbers for bundles
- Reactivating using a different serial number
- Extending your trial
- Finding your serial numbers
- Moving a serial number from one computer to another
- No response received for manual activation
- Licensing and activation resources
- Licensing and activation resources
- Troubleshooting licensing and activation errors
- Licensing and activation FAQs
- Red Gate tools log file locations
- Download old versions of products
- Download product prerequisites & utilities
- Support & upgrades
- Upgrading your software
- Upgrading FAQs

Using SmartAssembly for obfuscation