QArchive Save

Async C++ Cross-Platform library that modernizes libarchive using Qt :rocket:. Simply extracts 7z :hamburger:, Tarballs :8ball: and other supported formats by libarchive. :heart:

Project README

QArchive Logo

QArchive GitHub issues GitHub forks GitHub stars GitHub license Test and Deploy

QArchive is a cross-platform C++ library that modernizes libarchive , This library helps you to extract and compress archives supported by libarchive. The whole library itself is crafted to work perfectly well with the Qt event loop and thus its a perfect fit for your Qt projects.

I personally made this project to extract .7z archives in order to create a library that can update Qt Apps installed via Qt Installer Framework without using the updater tool provided by Qt , because I hated using sub-process and besides I wanted a in-built updater for my application and that's not possible with the already provided updater from Qt Installer Framework.

Features

  • Single threaded and Non-Blocking API - Using Qt's Event Loop. (you can optionally run in a different thread)

  • Easy to Use API - Made some effort to match Qt's style.

  • Cyclic API , No use of mutex - The whole library is fully cyclic and therefore no mutex is used.(Only signals and slots.)

  • Drink the Qt Kool-aid - In a positive way.

Witness it with your own eyes,

#include <QCoreApplication>
#include <QArchive/QArchive>

int main(int argc, char **argv)
{
    using QArchive::DiskExtractor;
    QCoreApplication app(argc, argv);
    DiskExtractor Extractor("Test.7z");
    
    /* Connect Signals and Slots. */
    QObject::connect(&Extractor , 
                     &DiskExtractor::finished , 
                     &app , 
                     &QCoreApplication::quit);
    
    Extractor.start();
    return app.exec();
}

Getting Started

Learn more about QArchive at the official documentation.

The documentation does not document any new changes that happen at the master branch and will only have information about the released version of the library. If you encounter API breaks in master branch, this is intentional, please use the release version. This situation will change soon in the future, so sorry for the inconvenience.

Qt6 Support

Starting from QArchive v2.2.3, Qt6 support exists, if you have only Qt6 installed in the system then QArchive's cmake should pick that up, if you have both Qt5 and Qt6, QArchive will pick Qt5, you can pass -DQARCHIVE_QT_VERSION_MAJOR=6 to cmake to force to build QArchive with Qt6 libs.

Conan

Thanks to Eric Riff.

Starting from version 2.0.1 QArchive is available on the Conan C/C++ package manager, which means you can download prebuilt packages for all major platforms (Windows, Linux, macOS, etc).

Find an example on how to consume Conan's precompiled packages in the examples folder.

Contributors QArchive Contributors

My utmost gratitude goes to these people! :heart:


Matthieu Petiot
💻

Adrien Bertrand
💻

Albert Huang
💻

Ichiro
💻

Long Nguyen
💻

g-fb
💻

Duilio Protti
💻

Eric Riff
💻

GGBond
💻

DeuxVis
💻

yosicovich
💻

tastytea
💻

M. Ludo
💻

Rosen Penev
💻

Anton
💻

Elizabeth
💻

You can also become one of them by contributing to this project , to know more read CONTRIBUTING.md.

Thank You Thank You

I really need to thank the developers of these libraries for creating it because QArchive is elegant because of them! :heart:

Support Twitter

If you think that this project is cool then you can give it a :star: or :fork_and_knife: it if you want to improve it with me. I really :heart: stars though!

License

The BSD 3-clause "New" or "Revised" License.

Copyright (C) 2017-present, QArchive Contributors and Antony J.R

All Rights Reserved.

Open Source Agenda is not affiliated with "QArchive" Project. README Source: antony-jr/QArchive

Open Source Agenda Badge

Open Source Agenda Rating