We are excited to announce that the first preview of a rewrite of Microsoft.PowerShell.Archive, the module that lets you create and extract archives, is now available on the PowerShell Gallery.
This release is the first preview release of a rewrite of the module and is not feature complete. Please note that this release only contains the Compress-Archive
cmdlet and is only compatible with PowerShell 7.3.0-preview5 and up. For more information on what is proposed in this rewrite, or to give feedback on the design please refer to the RFC.
Goals of the 2.0 release
The goal for the Archive module is to build a high-performing and maintainable module that offers high utility and works cross-platform (especially with regard to file paths).
Currently, the archive module has a number of limitations. The module supports the zip32 format only. .NET 7 is planned to support the tar archive format, so there is an opportunity to support an additional archive format by taking advantage of these new APIs. Meanwhile, this opportunity can be leveraged not only to add tar support, but to rewrite the entire module in C# and address existing usability issues.
The module has limited performance compared to other archive software. Although performance is dictated by the .NET APIs, a rewrite of the module in C# can reduce the overhead from script modules and address performance issues to an extent.
The module has limited cross-platform support because archive entries are written in an OS-specific way due to different characters being used as directory separators in different OSs. This makes it difficult for Unix-based OS users to use archives compressed on a Windows computer or vice versa. The rewrite of the module can solve this problem by normalizing all paths to use Unix directory separators (the ‘/’ character) across all platforms.
There are a number of issues in regard to using wildcard characters in paths. For example, in some cases, wildcard characters are not interpreted literally, which makes it difficult to use paths containing wildcard characters to specify the location of the archive.
In some circumstances, error reporting can be improved and more descriptive. Compatibility with other archive software can also be improved as there are cases where an archive program may not recognize an archive produced by this module as valid. Interactions with other parts of PowerShell, such as the job system, advanced functions, and common parameters can be further improved, so that users can have a seamless experience when using the module.
Additionally, .NET has supported creating large archives and compressing large files, but the archive module has lacked support for this. It makes sense to support archive formats that are supported by .NET, such as zip64 and tar, and to provide options that .NET also provides. The next version of the archive module, Microsoft.PowerShell.Archive v2.0.0, plans on resolving these limitations and usability issues.
Installing the module
Please note that this release will only work with PowerShell 7.3.0-preview5 and up. Find and install the latest preview version of PowerShell here.
To install the Microsoft.PowerShell.Archive 2.0 preview 1 run the following command
Install-Module Microsoft.PowerShell.Archive -AllowPrerelease
Features of the release
This release is not feature complete and only contains the rewrite of the Compress-Archive
cmdlet.
This cmdlet contains two parameter sets
Compress-Archive [-Path] <string[]> [-DestinationPath] <string> [-WriteMode {Create | Update | Overwrite}] [-PassThru] [-CompressionLevel {Optimal | Fastest |
NoCompression | SmallestSize}] [-Format {zip}] [-WhatIf] [-Confirm] [<CommonParameters>]
Compress-Archive [-LiteralPath] <string[]> [-DestinationPath] <string> [-WriteMode {Create | Update | Overwrite}] [-PassThru] [-CompressionLevel {Optimal |
Fastest | NoCompression | SmallestSize}] [-Format {zip}] [-WhatIf] [-Confirm] [<CommonParameters>]
Some features to note of this release
- Support for zip32 & zip64
- Preserves relative path structure (when relative paths are specified)
- Improved performance from previous versions of the cmdlet
- New
-WriteMode
support in case of destination path collisions
Features of the next release
The next release will focus in the Expand-Archive
cmdlet. To track the progress of this release, look at this project in our GitHub repository.
Giving Feedback and Getting support
While we hope the new implementation provides a much better user experience, there are bound to be issues. Please let us know if you run into anything.
If you encounter any issues with the module or have feature requests, the best place to get support is through our GitHub repository.
Abdullah Yousuf
Sydney Smith
Excellent news. I have followed some of the various discussions around this module and the challenges you note in the article. The solutions sound really good - so pleased to see cross-platform a key priority.
I note that this preview is only usable on the latest preview and presumably also on the Daily Build (I install this most days as I like to live life in the edge). Will the released module be useable...
Sounds like a plan. I am looking forward to testing on Linux. Thanks for this.
If I could have the archive module of my dream, I’d ask for:
– Full support for .7z and .cab archives
– Cmdlets that could compress, extract, inspect, digitally sign, validate, and repair an archive
– Deduplication support in the compression cmdlet
Hooray and thank you! Any chance the the new version will be backported or partially powershell 5 compatible? (There’s still a lot of 2016 servers out there that won’t get PS7)
(By the time this is released to GA hopefully it won’t apply to us, but large archive support sure would have helped us over the past several months for a particular automation scenario.)