Fix libarchive usage

main
Simon Quigley 4 days ago
parent 0ba157d434
commit 33678a6c0e

@ -14,12 +14,16 @@ pkg_check_modules(LIBGIT2 REQUIRED IMPORTED_TARGET libgit2)
find_package(CURL REQUIRED) find_package(CURL REQUIRED)
find_library(UUID_LIB uuid) find_library(UUID_LIB uuid)
find_package(ZLIB REQUIRED) find_package(ZLIB REQUIRED)
pkg_check_modules(LIBARCHIVE REQUIRED libarchive) pkg_check_modules(LIBARCHIVE REQUIRED libarchive)
include_directories(${LIBARCHIVE_INCLUDE_DIRS})
link_directories(${LIBARCHIVE_LIBRARY_DIRS})
add_definitions(${LIBARCHIVE_CFLAGS_OTHER})
include_directories(/srv/lubuntu-ci/repos/ci-tools/include/launchpadlib-cpp) include_directories(/srv/lubuntu-ci/repos/ci-tools/include/launchpadlib-cpp)
add_library(lubuntuci SHARED common.cpp utilities.cpp) add_library(lubuntuci SHARED common.cpp utilities.cpp)
target_include_directories(lubuntuci PUBLIC ${CMAKE_CURRENT_SOURCE_DIR} PRIVATE ${LIBARCHIVE_INCLUDE_DIRS}) target_include_directories(lubuntuci PUBLIC ${CMAKE_CURRENT_SOURCE_DIR} ${LIBARCHIVE_INCLUDE_DIRS})
target_link_libraries(lubuntuci PUBLIC yaml-cpp::yaml-cpp PRIVATE CURL::libcurl ${LIBARCHIVE_LIBRARIES} /srv/lubuntu-ci/repos/ci-tools/lib/liblaunchpad.so) target_link_libraries(lubuntuci PUBLIC yaml-cpp::yaml-cpp PRIVATE CURL::libcurl ${LIBARCHIVE_LIBRARIES} /srv/lubuntu-ci/repos/ci-tools/lib/liblaunchpad.so)
add_library(update_maintainer_lib STATIC update-maintainer-lib.cpp) add_library(update_maintainer_lib STATIC update-maintainer-lib.cpp)

@ -119,13 +119,32 @@ void create_tarball(const std::string& tarballPath, const std::string& directory
std::cout << "[INFO] Creating tarball: " << tarballPath << std::endl; std::cout << "[INFO] Creating tarball: " << tarballPath << std::endl;
struct archive* a = archive_write_new(); struct archive* a = archive_write_new();
if (!a) {
throw std::runtime_error("Failed to create a new archive.");
}
struct archive_entry* entry = nullptr; struct archive_entry* entry = nullptr;
// Initialize the tarball // Initialize the tarball
archive_write_add_filter_gzip(a); if (archive_write_add_filter_gzip(a) != ARCHIVE_OK) {
archive_write_set_format_pax_restricted(a); std::string err = "Failed to add gzip filter: ";
err += archive_error_string(a);
archive_write_free(a);
throw std::runtime_error(err);
}
if (archive_write_set_format_pax_restricted(a) != ARCHIVE_OK) {
std::string err = "Failed to set format: ";
err += archive_error_string(a);
archive_write_free(a);
throw std::runtime_error(err);
}
if (archive_write_open_filename(a, tarballPath.c_str()) != ARCHIVE_OK) { if (archive_write_open_filename(a, tarballPath.c_str()) != ARCHIVE_OK) {
throw std::runtime_error("Could not open tarball for writing: " + std::string(archive_error_string(a))); std::string err = "Could not open tarball for writing: ";
err += archive_error_string(a);
archive_write_free(a);
throw std::runtime_error(err);
} }
for (const auto& file : fs::recursive_directory_iterator(directory)) { for (const auto& file : fs::recursive_directory_iterator(directory)) {
@ -144,17 +163,36 @@ void create_tarball(const std::string& tarballPath, const std::string& directory
if (!fs::is_directory(path)) { if (!fs::is_directory(path)) {
// Add the file to the tarball // Add the file to the tarball
entry = archive_entry_new(); entry = archive_entry_new();
if (!entry) {
std::string err = "Failed to create archive entry: ";
err += archive_error_string(a);
archive_write_free(a);
throw std::runtime_error(err);
}
archive_entry_set_pathname(entry, relativePath.c_str()); archive_entry_set_pathname(entry, relativePath.c_str());
archive_entry_set_size(entry, fs::file_size(path)); archive_entry_set_size(entry, fs::file_size(path));
archive_entry_set_filetype(entry, AE_IFREG); archive_entry_set_filetype(entry, AE_IFREG);
archive_entry_set_perm(entry, static_cast<mode_t>(fs::status(path).permissions())); archive_entry_set_perm(entry, static_cast<mode_t>(fs::status(path).permissions()));
archive_write_header(a, entry); if (archive_write_header(a, entry) != ARCHIVE_OK) {
std::string err = "Failed to write header: ";
err += archive_error_string(a);
archive_entry_free(entry);
archive_write_free(a);
throw std::runtime_error(err);
}
// Write file contents // Write file contents
std::ifstream fileStream(path, std::ios::binary); std::ifstream fileStream(path, std::ios::binary);
std::vector<char> buffer((std::istreambuf_iterator<char>(fileStream)), std::istreambuf_iterator<char>()); std::vector<char> buffer((std::istreambuf_iterator<char>(fileStream)), std::istreambuf_iterator<char>());
archive_write_data(a, buffer.data(), buffer.size()); if (archive_write_data(a, buffer.data(), buffer.size()) < 0) {
std::string err = "Failed to write data: ";
err += archive_error_string(a);
archive_entry_free(entry);
archive_write_free(a);
throw std::runtime_error(err);
}
archive_entry_free(entry); archive_entry_free(entry);
} }

Loading…
Cancel
Save