diff options
author | Jan200101 <sentrycraft123@gmail.com> | 2020-08-18 23:58:16 +0200 |
---|---|---|
committer | Jan200101 <sentrycraft123@gmail.com> | 2020-08-18 23:58:16 +0200 |
commit | d53109eaa890ab807b66961a89291cea3cd3c003 (patch) | |
tree | a62382b32014266f5aecb6f639d0962bb1682bf0 /src/tar.c | |
parent | 1753e2b151cbb4af75a4e9ea61720b3704b03805 (diff) | |
download | polecat-d53109eaa890ab807b66961a89291cea3cd3c003.tar.gz polecat-d53109eaa890ab807b66961a89291cea3cd3c003.zip |
first part of a proper lutris implementation and cleanup0.1.4
- remove all old build platform related variables
- change behavior of clean
- change tabs into spaces
- make XDG fetching method static
- replace strcpy and cat with strn alternative with proper bounds checking
- add cache dir
- reenable dxvk and download from ram
- completely rework lutris fetching and convert it into an interal struct
- only show http errors in debug
- add sanity checks to methods with possible NULL return
- change extracting methods to extract tar from ram
Diffstat (limited to 'src/tar.c')
-rw-r--r-- | src/tar.c | 10 |
1 files changed, 7 insertions, 3 deletions
@@ -3,6 +3,10 @@ #include <archive.h> #include <archive_entry.h> #include <fcntl.h> +#include <linux/limits.h> + +#include "common.h" +#include "tar.h" static int copy_data(struct archive* ar, struct archive* aw) { @@ -25,9 +29,9 @@ static int copy_data(struct archive* ar, struct archive* aw) } } -void extract(const char* filename, const char* outputdir) +void extract(const struct MemoryStruct* tar, const char* outputdir) { - char cwd[256]; + char cwd[PATH_MAX]; void* err = getcwd(cwd, sizeof(cwd)); if (chdir(outputdir) < 0) @@ -55,7 +59,7 @@ void extract(const char* filename, const char* outputdir) archive_write_disk_set_options(ext, flags); archive_write_disk_set_standard_lookup(ext); - if ((r = archive_read_open_filename(a, filename, 0x4000))) return; + if ((r = archive_read_open_memory(a, tar->memory, tar->size))) return; for (;;) { |