- What is an ARP Entry?
- What is the difference between a Marketing Version and Package Version?
- How do I submit a package?
- How do I get the AppsAndFeaturesEntries for an installer?
- What should I do if a package is being published by a new publisher?
- How long do packages take to be published?
- What does this label on my PR mean?
- Why does a package have the version "Unknown"?
- My applications keep upgrading even when up to date!
- How can I use PowerShell to parse the output from winget?
ARP stands for A
dd and R
emove P
rograms. In Windows, installer files put information about the package they have installed into the Windows Registry. This information is used to tell Windows exactly what a program is and how to uninstall or modify it. Users can view these entries through the Add and Remove Programs option in Control Panel, or by running appwiz.cpl
. Alternatively, the Apps & features
menu in Windows Settings can be used to view the entries. Each entry in the table is an ARP Entry, and the Windows Package Manager uses these entries to help determine which applications are currently installed on your system.
Sometimes publishers use two different versions to refer to software. The version most commonly seen on the website or download page for a package is the Marketing Version. This is generally is used for the PackageVersion
field of manifests, but there are exceptions. The Package Version, sometimes referred to as Build Version
,Actual Version
, or DisplayVersion
is the version which is written to the ARP entry. This value is what the Windows Package Manager uses to determine which version of an application is currently installed on your system, and should be mapped to the AppsAndFeaturesEntries >> DisplayVersion
in a manifest.
Getting started is the hard part. There are several tools which we recommend for both creating and submitting packages.
First is the Windows Package Manager Manifest Creator (a.k.a Winget-Create). Winget-Create is a command line tool that will prompt you for relevant metadata related to your package. Once you are done, Winget-Create will validate your manifest to verify that it is correct and allow you to submit your newly-created manifest directly to the winget-pkgs repository by linking your GitHub account.
Second is the YamlCreate PowerShell Script. This tool is great for those who are technically inclined and understand the basics of forking, cloning, and commits. YamlCreate iterates much faster than Winget-Create but has largely the same functionality. More information on YamlCreate can be found in the Script Documentation.
Need more information? Take a look at the document on Authoring Manifests and the Microsoft Documentation Site.
The best way to get the AppsAndFeaturesEntries, or the ARP Entries, for an installer is to run the installer inside of the Windows Sandbox. Instructions on how to enable the sandbox can be found at the link above, or in the SandboxTest PowerShell Script Documentation. The SandboxTest PowerShell Script is a great way to get the AppsAndFeaturesEntries for a manifest you have already created. The SandboxTest Script will validate and test the manifest by downloading and installing the package in the Sandbox and comparing the ARP Entries before and after the installation. For the technically savvy, @jedieaston has created an Add-ARPEntries Script which uses Docker to populate the AppsAndFeaturesEntries for an existing manifest. Please note, however, that only the ARP Entry for the Primary Component should be added when a package installs multiple components.
The best practice for this is to create a situation where the package automatically switches to the new publisher using the ARP Entries for the package. To do this, two copies of the package must be added to the repository - one under the original package identifier and one under a new package identifier for the new publisher. This will cause anyone on a package published by the old publisher to be updated to the new version, at which point the ARP Entries will cause the Windows Package Manager to match the package to the new publisher and all future updates will be taken from the new package identifier.
For the package version added under the old publisher, the metadata should be updated to be accurate to the new publisher, with the exception of the Publisher
field, which should remain as the old publisher. Additionally, the AppsAndFeaturesEntries
should be added for each installer node, being sure to keep the Publisher
entry as the old publisher. The ProductCode
entries should not be specified under this version.
For the package version added under the new package identifier, the metadata should be complete and accurate. Additionally, the AppsAndFeaturesEntries
should be added for each installer node. The ProductCode
entries should be specified under this version.
Additional Notes: While this is currently the best practice, this may change in the future with the implementation of microsoft/winget-cl#1899 and microsoft/winget-cl#1900. The origination of this best practice can be foud here
The answer to this question depends on multiple factors. First, the pull request approval. When submitting a package to the repository, your pull request will go through a series of automated checks in the validation pipeline. You will see labels applied to your pull request based on the results of the validation. Secondly, all pull requests must be reviewed and approved by one of our community moderators. Finally, the pull request must be merged and pass through the publishing pipeline. Once the publishing pipeline has succeeded for your pull request, you will see a comment and a label indicating this status.
After your PR is approved and merged, the changes are generally published within one hour. If you are not seeing the changes published after your pull request has been merged, check the WinGetSvc-Publish Pipeline for errors. If the pipeline is erroring, please check to see if any issues have been opened regarding the failures and create a new issue if there isn't one already.
During the automated validation process, labels are added to pull request to help the bots which manage the repository and to manage the status of open requests. All of these labels are described in more detail on the Microsoft Documentation Site
When a package has the version "Unknown" it means that Windows Package Manager has detected that the package is installed, but the publisher is not providing Windows with the version of the package. If you are using Windows Package Manager v1.2, these packages will always be re-installed when running winget upgrade
; however, as of Windows Package Manager v1.3, packages with unknown version are excluded from upgrade by default, but can be included by using the switch --include-unknown
. If a package you use frequently has an unknown version, we recommend reaching out to the publisher of the application and asking them to set the DisplayVersion
registry key in their installer.
There are two primary causes for packages to continually update. Most commonly, this is due to a package having an unknown version, although this has been fixed in Windows Package Manager v1.3. The second reason packages may continually update is due to there being multiple versions of the same application on your system. This is referred to as a side-by-side installation. The best examples of this are the Visual C Redistributables and the .NET Desktop Runtimes. Each of these packages can have multiple versions installed side-by-side and often multiple versions are required for other applications to run correctly. Because there are versions installed which are not the latest version, the Windows Package Manager believes they need to be upgraded and will attempt to upgrade them; however, these upgrades often install side-by-side also, causing the upgrade loop to continue. Future work is planned to resolve this issue, and is being tracked through microsoft/winget-cli#2345 and microsoft/winget-cli#1413
The Windows Package Manager is still in development and does not yet support emitting rich data objects as output. There are a few issues tracking this feature request. Please add your thumbs up to these issues as the reactions are used to help prioritize which features are implemented next.
- Add Native PowerShell Support - microsoft/winget-cli#221
- Add list option to format output as JSON - microsoft/winget-cli#2032
Also, take a look at the discussions based around PowerShell support!