Exclusive WiX Custom Actions for Uninstall Operations: How-To Guide

Exclusive WiX Custom Actions for Uninstall Operations: How-To Guide

Donald Lv12

Exclusive WiX Custom Actions for Uninstall Operations: How-To Guide

Versus

Inno SetupInno SetupWiX ToolsetWiX ToolsetInstallShieldInstallShieldMSIX Packaging ToolMSIX Packaging Tool

icon subscribe mail

Check your inbox and confirm the
subscription

Exclusive NewsletterExclusive Newsletter

Exclusive NewsletterExclusive Newsletter

Get the latest WiX insights direct to your inbox. Subscribe now!

Disclaimer: This post includes affiliate links

If you click on a link and make a purchase, I may receive a commission at no extra cost to you.

How to set a WiX Toolset custom action to run only on uninstall

When you create an installer using the WiX Toolset, there are instances where you may want to set a custom action to run under specific conditions, such as uninstalling an application, installing an application, or running a custom script.

In this article, we’ll see how you can set a custom action to run when uninstalling an application using WiX Toolset.

https://techidaily.com

Understanding Custom Action conditions

Every event defined in the install sequences runs under more or less specific conditions.

These conditions can target more than one installer property. For this specific example, you may need to understand how the values of the “Installed”, and “REMOVE” properties are perceived by the installer’s runs.

You can have a look at the table below:

Property Name Install Uninstall Change Repair Upgrade
Installed False True True True True
REINSTALL False False False True False
UPGRADINGPRODUCTCODE False False False False True
REMOVE False True False False True

Remember that property names are case sensitive.

1. Create a new “C# Custom Action Project for WiX v3 ” in your Visual Studio solution.

Here is a basic custom action snippet which will write “Hello World!” in the installation log.

using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.Deployment.WindowsInstaller;
namespace CustomAction

public class CustomActions 

[CustomAction] 
public static ActionResult CustomAction(Session session) 

session.Log("Hello World!"); 
return ActionResult.Success; 

Copy

2. You can change the name of the function to a name that suits your function.

3. Then, you have to reference this custom action in your WiX setup project.

To do that, right click the “References” folder on your WiX setup project and choose “Add Reference…

4. Following up, click on the “Projects” tab and choose your custom action project.

Choose Custom Action Project

https://techidaily.com

How to declare the WiX custom action

Now, we need to actually declare the custom action in the “Product.wxs” file. For that, you need to add the following code under the Product Tag:

Copy

In order for it to work, you have to change the following names:

“CUSTOMACTIONSNAME” The name of the custom action that was added in the references folder
“CUSTOMACTIONNAME” The name of your choice
“CUSTOMACTIONFUNCTION” Your custom action project’s function name that you want to call
https://techidaily.com

Adding the custom action to the Install Execute Sequence

In order for your custom action to be called when the installer is running, you need to add it to the install sequence.

Insert the custom action into the Install Execute Sequence as follows:

Installed AND REMOVE=”ALL”

Copy

TipThe Installed AND REMOVE=”ALL” condition will make sure that the custom action will run only when uninstalling the application.

https://techidaily.com

How to set a custom action to run only on uninstall using Advanced Installer?

Using Advanced Installer, you can automatically set custom actions to run only on uninstall directly from its GUI - NO need to write any code.

NoteCustom Actions are available for Professional, Enterprise and Architect project types in Advanced Installer. Have a look at how custom actions work in Advanced Installer through our 30-day full featured trial . (No credit card required)

1. To add a new custom action, go to the Custom Actions page and add a new custom action to your project.

NoteYou can use the same custom action DLL as before by adding a “Call function from attached native DLL” custom action.

Call Function from Attached Native DLL Custom Action

2. In the Properties section, under the Function field, select the function you want your custom action to call.

Custom Action Function

3. Now, in the Execution Stage Condition section, uncheck the Install and Maintenance checkboxes. That will make sure that your custom action will run only when you uninstall the application.

Execution Stage Condition

And that’s it! As you could see, setting a custom action through Advanced Installer intuitive GUI requires no code skills allowing you to be time efficient when configuring your application.

Conclusion

In this article, we presented two approaches for configuring a custom action to run on uninstall.As we’ve seen, WiX is not GUI-based and sometimes it can be challenging to achieve specific tasks, having to create custom scripts from scratch. On the other hand, the process of adding custom actions is much simpler and quicker using Advanced Installer which offers a dedicated GUI for adding and defining custom actions.

We hope you like it! For more topic suggestions, leave a comment below.

Advanced Installer #1 alternative to the WiX Toolset

We decided to focus on our main goal to save precious time of our developers.

HANS-LEO TEULINGS
PHD – CEO, NEUROSCRIPT, LLC

You might find useful:

Get the most from packaging with Advanced Installer

Try the 30-day fully-featured edition absolutely free!

Download Free Trial

No credit card required

Also read:

  • Title: Exclusive WiX Custom Actions for Uninstall Operations: How-To Guide
  • Author: Donald
  • Created at : 2024-09-27 19:27:34
  • Updated at : 2024-10-03 17:24:47
  • Link: https://some-tips.techidaily.com/exclusive-wix-custom-actions-for-uninstall-operations-how-to-guide/
  • License: This work is licensed under CC BY-NC-SA 4.0.