This is a utility with a graphical user interface and a command line interface that can be used to view and extract the contents of an MSI file.
To extract from the command line:
lessmsi x <msiFileName> [<outputDir>]
For more command line usage see CommandLine.
Install via Chocolatey (or download a zip).
Lessmsi also integrates with Windows Explorer so that you can right-click on a Windows Installer file (.msi file) and select "Extract Files" to extract it into a folder right there:
Just select Preferences from the Edit menu to enable (or disable) the explorer integration:
In addition to allowing you to extract files from the command line and from inside Windows Explorer, lessmsi has a graphical user interface that allows you to view detailed information about any MSI file.
Windows Installer (.msi files) are based on an internal database of tables. Lessmsi features a viewer for those tables. Useful for people who work a lot with installers.
If you have a problem please submit it by clicking in the Issue tracker and I'll look into it when I can.
You can donate in two ways:
- Donate at Tip4Commit (Bitcoin only) to fund a general fund. Each new commit to this repository receives a percentage of the available balance.
- Donate at IssueHunt to deposit your donation as a "bounty" against a specific issue or feature request. When a contributor resolves the issue they will earn the deposit for that issue.
Pull requests are welcome! Just make sure the Travis-CI build (compile only) passes and you run unit tests and I'll merge your contributions ASAP! The Issues app has an indication of some of the plans.
We're now tipping committers with bitcoin:
We're now registered at IssueHunt so contributors can earn the bounty on specific issues that users have deposited funds against.
To set up a free Windows development environment that works with Lessmsi:
- Install VMWare Fusion Player (using free "Player" version, only needed if developing on MacOS - homebrew also has a vmware-fusion formula)
- Download a Virtual Machine for Windows development that Microsoft provides at https://developer.microsoft.com/en-us/windows/downloads/virtual-machines/. These VMs include virtual machine with the latest versions of Windows, the developer tools, SDKs, and samples ready to go.
- Install chocolatey as described at https://chocolatey.org/install
- Install some things using the "Command Prompt" (
cmd
rather than "Power Shell"/ps
) andwinget
here):
# install git for windows (this also installs "bash" via "Git Bash")
$ winget install git.git
# install chocolatey (this is required to run the MSBuild script and create the chocolatey package that is deployed by CI)
$ winget install chocolatey
# NOTE: you'll need to close this window and open a new one to get the cpack and git on the path
Then you can switch to bash by typing "bash" in the start menu and selecting "Git Bash" and follow these steps:
# in Git Bash..., generate and ssh key for github:
$ ssh-keygen
# follow prompts...
# Print *public* ssh key to console, and register the printed value at github at https://github.com/settings/ssh/new by copying the key printed from the prior step into that box
$ cat ~/.ssh/id_ed25519.pub
# create directories for code and clone the repo:
$ mkdir /c/src
$ cd /c/src
$ git clone git@github.com:activescott/lessmsi.git
Now I switch back to a "Developer Command Prompt for Visual Studio" (i.e. cmd
with helpful PATH) to do a build since it is more CI-like:
$ cd \src\lessmsi\src
$ .\build.bat
# I usually start with 0.0.1 when prompted for a version number...
The latest versions of Lessmsi should support the oldest version of Windows that Microsoft still officially supports according to https://learn.microsoft.com/en-us/windows/release-health/supported-versions-windows-client That means we need to also target a .NET Framework version that is included in the oldest version Windows that Microsoft still supports which can be found at https://en.wikipedia.org/wiki/.NET_Framework_version_history
For example as of 2024, Windows 10 is the oldest version of Windows still supported and according to the Wikipedia article, .NET Framework 4.8 is included in Windows 10 (some reasonably current update to Windows 10), so targeting .NET Framework 4.8 is ideal since any reasonably up-to-date version of Windows 10 will have .NET Framework 4.8. Going further, as of April 2024, we see that while .NET Framework 4.8.1 is also available, it is only included in Widnows 11, and not included in any Windows 10 version, so we should not target .NET Framework 4.8.1 as some of our Windows 10 users may not yet have 4.8.1 installed.
New versions are published to GitHub Releases and Chocolatey via semantic-release to consistently release semver-compatible versions. Only the master branch is deployed.
To trigger a release just commit (or merge) to the master branch. All commits in master should use the Conventional Commits following Angular Commit Message Conventions.
Then the CI script in the repo at /appveyor.yml should build, test the code and if the build & tests succeed deploy it first to github and then to Chocolatey. Release configuration via semantic-release is in /release.config.js and the semantic-release-*.cmd
files in the /src/.build folder.
Originally from Scott Willeke's blog http://blogs.pingpoet.com/overflow and http://blog.scott.willeke.com. It was also called Less Msiérables as well as lessmsi.
Was featured in the book Windows Developer Power Tools as Less MSIérables.