From b408fe77f792650ef569f9852165759f960fd52f Mon Sep 17 00:00:00 2001 From: Michael Lutz Date: Sun, 6 Dec 2020 21:11:50 +0100 Subject: Codechange: Use std::string in file scanners. --- src/tar_type.h | 18 ++++-------------- 1 file changed, 4 insertions(+), 14 deletions(-) (limited to 'src/tar_type.h') diff --git a/src/tar_type.h b/src/tar_type.h index e428bc249..c4e72df85 100644 --- a/src/tar_type.h +++ b/src/tar_type.h @@ -12,30 +12,20 @@ #include #include +#include #include "fileio_type.h" -/** The define of a TarList. */ -struct TarListEntry { - const char *filename; - const char *dirname; - - /* MSVC goes copying around this struct after initialisation, so it tries - * to free filename, which isn't set at that moment... but because it - * initializes the variable with garbage, it's going to segfault. */ - TarListEntry() : filename(nullptr), dirname(nullptr) {} - ~TarListEntry() { free(this->filename); free(this->dirname); } -}; struct TarFileListEntry { - const char *tar_filename; + std::string tar_filename; size_t size; size_t position; }; -typedef std::map TarList; +typedef std::map TarList; ///< Map of tar file to tar directory. typedef std::map TarFileList; -extern TarList _tar_list[NUM_SUBDIRS]; +extern std::array _tar_list; extern TarFileList _tar_filelist[NUM_SUBDIRS]; #define FOR_ALL_TARS(tar, sd) for (tar = _tar_filelist[sd].begin(); tar != _tar_filelist[sd].end(); tar++) -- cgit v1.2.3-54-g00ecf