Commit Graph

67 Commits

Author SHA1 Message Date
7d4e774cf7
Rewrite the entire API just to eliminate heap allocations
Just bumping minor because nobody uses this and I don't want to jump up to 2.0.0
2022-12-25 14:33:47 +01:00
89bc990725
More optimization and heap elimination 2022-12-25 13:31:11 +01:00
555059a742
PERFORMANCE OPTIMIZATIONS 2022-12-25 13:21:09 +01:00
41a1e23abf
Remove -ansi and make it compile under TCC 2022-12-25 13:06:02 +01:00
51b09f35ad
MSVC does not have __attribute__((weak)) 2022-12-25 13:00:47 +01:00
a04af496f0
Use -ansi to build when using GCC/Clang 2022-12-25 12:59:09 +01:00
23c313d9cf
Get rid of libgen.h in favor of our own basename :) 2022-12-25 12:51:35 +01:00
4ab1cd42c9 Update README.md 2022-12-01 18:39:03 +00:00
c78566bb27 Split basename parsing into a helper function 2022-12-01 19:37:37 +01:00
125ec8f063 Provide strdup ourselves 2022-12-01 19:30:51 +01:00
aff867f667 Add references to minitar_find_by_path() in README.md 2022-11-30 19:32:21 +01:00
dd3d84be76 Update README.md 2022-11-30 19:25:55 +01:00
577f99cca6 Reorder function declarations in minitar.h 2022-11-30 11:20:36 +01:00
28d1eab1c1 Remove character and block devices from supported entry types
Closes #1.
2022-11-30 11:20:13 +01:00
eeb7bccda8 Skip null-terminating a result already null-terminated by strlcpy() 2022-11-30 11:14:11 +01:00
e922cfe8b9 read_contents(): shortcircuit if an entry is empty 2022-11-30 10:36:19 +01:00
e43f4d9a07 Add the root directory as an include directory for minitar.h 2022-11-23 21:22:40 +01:00
7b5e6196a7 Make some functions only used in util.c static 2022-11-23 20:59:15 +01:00
f156f8472e attempt_read_entry -> try_to_read_valid_entry 2022-11-23 20:56:57 +01:00
cdf1e0bcba Make minitar_read_contents cleaner 2022-11-23 20:56:08 +01:00
726afbae15 Update tar.h 2022-11-23 20:52:18 +01:00
400a51893e Update README.md 2022-11-23 20:50:40 +01:00
408342cb1d Remove shadow function 2022-11-23 20:41:44 +01:00
9420107a55 More commenting 2022-11-23 20:40:47 +01:00
9fe8159d5a More commenting + minitar_get_size_in_blocks -> minitar_align_up_to_block_size 2022-11-23 20:39:34 +01:00
653f9a90d0 Provide our own strndup + a lot more comments going on 2022-11-23 20:32:05 +01:00
f929a860c4 Be more explicit about "what" is necessary to read the file properly 2022-11-23 18:32:42 +01:00
fd85cf1c6a Full path is now metadata->path and basename metadata->name
Shouldn't have rushed to 1.0.0 so quickly. Oh well, I guess I can allow 1.1.0...
2022-11-23 18:32:10 +01:00
b7c27a25a6 Reorganize minitar_attempt_read_entry 2022-11-22 17:28:34 +01:00
ba7b77bdae Rename internal function minitar_parse_tar_header -> minitar_parse_metadata_from_tar_header 2022-11-22 17:28:15 +01:00
0fbcdde399 Return fclose's status code 2022-11-22 17:25:17 +01:00
d123c49946 Do not automatically read an entry's contents, leave it up to the user
This API change modifies minitar_read_entry to skip over the file's contents and instead store the current read position in the entry.

struct minitar_entry no longer has a ptr field, but has a position field (of type fpos_t) for internal use.

minitar_free_entry no longer frees entry->ptr.

A new function has been added, minitar_read_contents().
It reads a certain number of bytes from an entry (which is capped to the entry's size) into a user-provided buffer.
This function can be called at any time provided it is called with a valid archive stream and entry.
This is achieved by calling fgetpos() to store the start of the entry's contents in the entry's position field while reading it.
Then minitar_read_contents() will store the current position, rewind to the entry's position, read the chosen number of bytes from the archive, and then rewind back to the current position.

Since this is a breaking change, it needs a major version bump. Since there was no version, I bumped it to 1.0.0 :)
2022-11-21 20:20:37 +01:00
9695889040 Add FIXME 2022-11-21 19:17:29 +01:00
e3fae29713 Safer string copying 2022-11-21 19:15:52 +01:00
54e1473aee Remove one more line 2022-11-21 19:08:10 +01:00
6c696c67b1 Revert previous commit, but using strtoul(l) everywhere
I'm pretty sure every field in a tar header is unsigned octal...
2022-11-21 19:07:49 +01:00
30c7c0ad57 Determine the signedness of standard types 2022-11-21 19:01:12 +01:00
d97992c519 Remove Makefile 2022-11-21 18:17:39 +01:00
2aed955e94 Use const pointers when possible 2022-11-21 17:38:08 +01:00
1633012823 Provide a CMakeLists.txt to use minitar with CMake 2022-11-20 20:14:08 +01:00
363c01d6f8 Update README.md 2022-11-06 13:58:41 +00:00
df26e6d772 Rename minitar_read_file to minitar_read_file_contents 2022-11-06 14:23:35 +01:00
97da894c0f Make naming consistent across all files 2022-11-06 14:21:32 +01:00
4401b1ca3a Update README.md 2022-11-06 14:18:36 +01:00
28085731f1 Not all 0-sized reads are errors
If you requested 0 bytes, the kernel gives you 0 bytes back
2022-11-06 14:14:06 +01:00
fd32be351e Remove unnecessary include 2022-11-06 12:46:07 +01:00
7af3cfdfa0 Correct C++ signature 2022-11-06 12:39:17 +01:00
c8ef43e33b Make it C++-compatible 2022-11-06 12:35:30 +01:00
53723e6e2f Document how to override the default panic function 2022-11-06 12:34:49 +01:00
f2fdf726ce Add a way to override the panic function 2022-11-06 12:24:13 +01:00