Book Image

WiX 3.6: A Developer's Guide to Windows Installer XML

Book Image

WiX 3.6: A Developer's Guide to Windows Installer XML

Overview of this book

The cryptic science of Windows Installer can seem far off from the practical task of simply getting something installed. Luckily, we have WiX to simplify the matter. WiX is an XML markup, distributed with an open-source compiler and linker, used to produce a Windows Installer package. It is used by Microsoft and by countless other companies around the world to simplify deployments. "WiX 3.6: A Developer's Guide to Windows Installer XML" promises a friendly welcome into the world of Windows Installer. Starting off with a simple, practical example and continuing on with increasingly advanced scenarios, the reader will have a well-rounded education by book's end. With the help of this book, you'll understand your installer better, create it in less time, and save money in the process. No one really wants to devote a lifetime to understanding how to create a hassle-free installer. Learn to build a sophisticated deployment solution targeting the Windows platform in no time with this hands-on practical guide. Here we speed you through the basics and zoom right into the advanced. You'll get comfortable with components, features, conditions and actions. By the end, you'll be boasting your latest deployment victories at the local pub. Once you've finished "WiX 3.6: A Developer's Guide to Windows Installer XML", you'll realize just how powerful and awesome an installer can really be.
Table of Contents (23 chapters)
WiX 3.6: A Developer's Guide to Windows Installer XML
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface
Index

Rollback boundaries


Let's say you've included three MSIs in your install chain. The user launches the bootstrapper, the first two MSIs install successfully but the third fails. You may decide to keep the first two but roll back only the third. By default, all three will roll back. Use RollbackBoundary elements to create checkpoints past which the install won't roll back. The following is an example:

<Chain>
   <MsiPackage... />
   <MsiPackage ... />
   <RollbackBoundary />
   <MsiPackage... />
</Chain>

If the third MSI package fails, only it will be rolled back. The first two packages will remain installed. Another scenario is to roll back a failed install and then skip past it to the next rollback boundary. In the next example, if the second MSI fails, it will skip forward to the next RollbackBoundary and continue. The key is to add the Vital attribute on a RollbackBoundary element, set to no, that precedes the MsiPackage element:

<Chain>
   <MsiPackage...