As of 2021, I needed to abandon this project. I moved on to other things and was unable maintain it any further. Luckily, GitHub user @win93 has kindly taken over maintenance over ruby-xz. The new repository for ruby-xz is here: https://github.com/win93/ruby-xz Please file any tickets or pull request at that repository. @win93 has also taken over the ruby-xz RubyGem with my permission.
This repository only remains for historical and archival purposes. Thanks to @win93 for taking over ruby-xz.
ruby-xz is a basic binding to the famous liblzma library, best known for the extreme compression-ratio it's native XZ format achieves. ruby-xz gives you the possibility of creating and extracting XZ archives on any platform where liblzma is installed. No compilation is needed, because ruby-xz is written on top of Ruby's “fiddle” library (part of the standard libary). ruby-xz does not have any dependencies other than Ruby itself.
ruby-xz supports both “intuitive” (de)compression by providing methods to directly operate on strings and files, but also allows you to operate directly on IO streams (see the various methods of the XZ module). On top of that, ruby-xz offers an advanced interface that allows you to treat XZ-compressed data as IO streams, both for reading and for writing. See the XZ::StreamReader and XZ::StreamWriter classes for more information on this.
Note: Version 1.0.0 breaks the API quite heavily. Refer to HISTORY.rdoc for details.
Install it the way you install all your gems.
$ gem install ruby-xz
Alternatively, you can clone the repository and build the most recent code yourself:
$ git clone git://git.guelker.eu/ruby-xz.git
$ cd ruby-xz
$ rake gem
$ gem install pkg/ruby-xz-*.gem
The documentation of the XZ module is well and you should be able to find everything you need to use ruby-xz. As said, it's not big, but powerful: You can create and extract whole archive files, compress or decompress streams of data or just plain strings.
You can read the documentation on your local gemserver, or browse it online.
You have to require the “xz.rb” file:
require "xz"
# Compress a file
XZ.compress_file("myfile.txt", "myfile.txt.xz")
# Decompress it
XZ.decompress_file("myfile.txt.xz", "myfile.txt")
# Compress everything you get from a socket (note that there HAS to be a EOF
# sometime, otherwise this will run infinitely)
XZ.compress_stream(socket){|chunk| opened_file.write(chunk)}
# Compress a string
comp = XZ.compress("Mydata")
# Decompress it
data = XZ.decompress(comp)
Have a look at the XZ module's documentation for an in-depth description of what is possible.
ruby-xz can be used together with the minitar library (formerly “archive-tar-minitar”) to create XZ-compressed tarballs. This works by employing the IO-like classes XZ::StreamReader and XZ::StreamWriter analogous to how one would use Ruby's “zlib” library together with “minitar”. Example:
require "xz"
require "minitar"
# Create an XZ-compressed tarball
XZ::StreamWriter.open("tarball.tar.xz") do |txz|
Minitar.pack("path/to/directory", txz)
end
# Unpack it again
XZ::StreamReader.open("tarball.tar.xz") do |txz|
Minitar.unpack(txz, "path/to/target/directory")
end
- Online documentation: https://rubydoc.info/gems/ruby-xz
- Code repository: https://github.com/Quintus/ruby-xz
- Issue tracker: https://github.com/Quintus/ruby-xz/issues
MIT license; see LICENSE for the full license text.