Skip to content

Async C++ Cross-Platform library that modernizes libarchive using Qt πŸš€. Simply extracts 7z πŸ”, Tarballs 🎱 and other supported formats by libarchive. ❀️

License

Notifications You must be signed in to change notification settings

antony-jr/QArchive

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

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! ❀️


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! ❀️

Support Twitter

If you think that this project is cool then you can give it a ⭐ or 🍴 it if you want to improve it with me. I really ❀️ stars though!

License

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

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

All Rights Reserved.