diff options
| author | Xavier Del Campo Romero <xavi92@disroot.org> | 2025-10-06 23:02:51 +0200 |
|---|---|---|
| committer | Xavier Del Campo Romero <xavi92@disroot.org> | 2025-10-08 02:03:05 +0200 |
| commit | 00dd37604d50cbf3fb27ec0631b4d4b6d2ee893a (patch) | |
| tree | 81f9546b168078aa9bf54d4298aa76e99bb229af /CMakeLists.txt | |
| parent | 4ab3ee681607f0cc75cf56e4fcbeae85594bb630 (diff) | |
| download | slcl-00dd37604d50cbf3fb27ec0631b4d4b6d2ee893a.tar.gz | |
Implement directory download as ZIP
Thanks to the fdzipstream library [1] and zlib [2], it is possible to
generate ZIP files on-the-fly, therefore requiring no extra disk space
usage and only a small amount of memory.
Unfortunately, as of the time of this writing fdzipstream is not
packaged by any distributions yet [3], so it had to be imported as a git
submodule as a workaround.
While libarchive [4] could be an interesting alternative, writing ZIP
files is only supported by very recent versions (>= 3.8.0), which are
still not packaged by many distributions [5], either.
Moreover, libarchive is a package with several dependencies other than
zlib and is significantly larger compared to fdzipstreams, so
fdzipstreams was ultimately considered a better fit for this purpose.
[1]: https://github.com/CTrabant/fdzipstream.git
[2]: http://zlib.net/
[3]: https://repology.org/projects/?search=fdzipstream
[4]: https://www.libarchive.org/
[5]: https://repology.org/project/libarchive/versions
Diffstat (limited to 'CMakeLists.txt')
| -rw-r--r-- | CMakeLists.txt | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index d34a876..4d234c3 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -10,6 +10,7 @@ add_executable(${PROJECT_NAME} main.c page.c style.c + zip.c ) target_compile_options(${PROJECT_NAME} PRIVATE -Wall) target_compile_definitions(${PROJECT_NAME} PRIVATE _FILE_OFFSET_BITS=64) @@ -26,7 +27,15 @@ endif() find_package(cJSON 1.0 REQUIRED) find_package(OpenSSL 1.0 REQUIRED) -target_link_libraries(${PROJECT_NAME} PRIVATE web dynstr cjson OpenSSL::SSL) +find_package(fdzipstream) + +if(NOT fdzipstream_FOUND) + message(STATUS "Using in-tree fdzipstream") + add_subdirectory(fdzipstream) +endif() + +target_link_libraries(${PROJECT_NAME} PRIVATE web dynstr cjson OpenSSL::SSL + fdzipstream) install(TARGETS ${PROJECT_NAME}) install(FILES usergen TYPE BIN |
