From c773fbbe70ac8b867a4d77a261f9afd0fd69b647 Mon Sep 17 00:00:00 2001 From: "Azamat H. Hackimov" Date: Sun, 28 Jul 2024 04:54:53 +0300 Subject: [PATCH] Isolate unzip module Update unzip module, minor cleanups. --- unzip/CMakeLists.txt | 8 +++++-- unzip/unzip.cpp | 49 +++++++++++++++++++++--------------------- {lib => unzip}/unzip.h | 21 +++++++++--------- 3 files changed, 40 insertions(+), 38 deletions(-) rename {lib => unzip}/unzip.h (93%) diff --git a/unzip/CMakeLists.txt b/unzip/CMakeLists.txt index cc071a39..58fd4937 100644 --- a/unzip/CMakeLists.txt +++ b/unzip/CMakeLists.txt @@ -1,6 +1,10 @@ -set(HEADERS) set(CPPS unzip.cpp) add_library(unzip STATIC ${HEADERS} ${CPPS}) -target_link_libraries(unzip ZLIB::ZLIB) +target_link_libraries(unzip PRIVATE ZLIB::ZLIB) +target_include_directories(unzip PUBLIC + $ +) diff --git a/unzip/unzip.cpp b/unzip/unzip.cpp index d69beae6..dcb389e7 100644 --- a/unzip/unzip.cpp +++ b/unzip/unzip.cpp @@ -1,5 +1,5 @@ /* -* Descent 3 +* Descent 3 * Copyright (C) 2024 Parallax Software * * This program is free software: you can redistribute it and/or modify @@ -35,16 +35,15 @@ * $NoKeywords: $ */ -#include -#include -#include +#include +#include +#include +#include #include #include "unzip.h" -#include - #define INFLATE_INPUT_BUFFER_MAX 16384 #define DATA_CHUNK_SIZE 1024 @@ -123,11 +122,11 @@ bool ZIP::FindECDSignature(char *buffer, int buflen, int *offset) { return false; } -int ZIP::ReadECD(void) { +int ZIP::ReadECD() { char *buf; int buf_length = 1024; - while (1) { + while (true) { int offset; if (buf_length > m_length) @@ -247,7 +246,7 @@ bool ZIP::OpenZip(const char *zipfile) { } // reset zip entry - m_ent.name = NULL; + m_ent.name = nullptr; // rewind to the begining of central dir m_cd_pos = 0; @@ -266,7 +265,7 @@ bool ZIP::OpenZip(const char *zipfile) { } // closes an open zip file -void ZIP::CloseZip(void) { +void ZIP::CloseZip() { if (!m_open) return; @@ -286,13 +285,13 @@ void ZIP::CloseZip(void) { // Reads the current zip entry from the zip file (and moves // to the next entry). Returns NULL if there are no more entries -zipentry *ZIP::ReadNextZipEntry(void) { +zipentry *ZIP::ReadNextZipEntry() { if (!m_open) - return NULL; + return nullptr; // make sure we aren't at the end if (m_cd_pos >= m_size_of_cent_dir) - return NULL; + return nullptr; m_ent.cent_file_header_sig = get_buffer_int(m_cd + m_cd_pos + ZIPCD_CENSIG); m_ent.version_made_by = *(m_cd + m_cd_pos + ZIPCD_CVER); @@ -316,14 +315,14 @@ zipentry *ZIP::ReadNextZipEntry(void) { // Make sure the filename isn't too long if (m_cd_pos + ZIPCD_CFN + m_ent.filename_length > m_size_of_cent_dir) { - return NULL; + return nullptr; } if (m_ent.name) free(m_ent.name); m_ent.name = (char *)malloc(m_ent.filename_length + 1); if (!m_ent.name) - return NULL; + return nullptr; memcpy(m_ent.name, m_cd + m_cd_pos + ZIPCD_CFN, m_ent.filename_length); m_ent.name[m_ent.filename_length] = '\0'; @@ -334,7 +333,7 @@ zipentry *ZIP::ReadNextZipEntry(void) { } // Resets a ZIP file to the first entry -void ZIP::Rewind(void) { +void ZIP::Rewind() { if (!m_open) return; m_cd_pos = 0; @@ -531,11 +530,11 @@ int ZIP::InflateFile(FILE *in_file, unsigned in_size, uint8_t *out_data, unsigne uint8_t *in_buffer; z_stream d_stream; - d_stream.zalloc = 0; - d_stream.zfree = 0; - d_stream.opaque = 0; + d_stream.zalloc = nullptr; + d_stream.zfree = nullptr; + d_stream.opaque = nullptr; - d_stream.next_in = 0; + d_stream.next_in = nullptr; d_stream.avail_in = 0; d_stream.next_out = out_data; d_stream.avail_out = out_size; @@ -598,13 +597,13 @@ int ZIP::InflateFileToFile(FILE *in_file, unsigned in_size, FILE *file, unsigned uint8_t *next_out; z_stream d_stream; - d_stream.zalloc = 0; - d_stream.zfree = 0; - d_stream.opaque = 0; + d_stream.zalloc = nullptr; + d_stream.zfree = nullptr; + d_stream.opaque = nullptr; - d_stream.next_in = NULL; + d_stream.next_in = nullptr; d_stream.avail_in = 0; - d_stream.next_out = NULL; + d_stream.next_out = nullptr; d_stream.avail_out = 0; d_stream.total_out = 0; d_stream.total_in = 0; diff --git a/lib/unzip.h b/unzip/unzip.h similarity index 93% rename from lib/unzip.h rename to unzip/unzip.h index fb0fb489..60320852 100644 --- a/lib/unzip.h +++ b/unzip/unzip.h @@ -1,5 +1,5 @@ /* -* Descent 3 +* Descent 3 * Copyright (C) 2024 Parallax Software * * This program is free software: you can redistribute it and/or modify @@ -35,12 +35,11 @@ * $NoKeywords: $ */ -#ifndef __UNZIP_H -#define __UNZIP_H +#ifndef UNZIP_H +#define UNZIP_H #include -#include -#include "pstypes.h" +#include struct zipentry { uint32_t cent_file_header_sig; @@ -77,14 +76,14 @@ public: bool OpenZip(const char *path); // closes an open zip file - void CloseZip(void); + void CloseZip(); // Reads the current zip entry from the zip file (and moves // to the next entry). Returns NULL if there are no more entries - zipentry *ReadNextZipEntry(void); + zipentry *ReadNextZipEntry(); // Resets a ZIP file to the first entry - void Rewind(void); + void Rewind(); // Reads a file from the given zip entry into a buffer in memory // -1 : no ZIP file open @@ -110,7 +109,7 @@ public: private: bool FindECDSignature(char *buffer, int buflen, int *offset); - int ReadECD(void); + int ReadECD(); int ReadZipData(zipentry *ent, char *data); int ReadZipDataToFile(zipentry *ent, FILE *file); int SeekToCompressedData(zipentry *ent); @@ -119,8 +118,8 @@ private: private: bool m_open; - char *m_zip; // zip name - FILE *m_fp; // zip handler + char *m_zip; // zip name + FILE *m_fp; // zip handler int32_t m_length; // length of zip file char *m_ecd; // end_of_cent_dir data