Commit graph

75 commits

Author SHA1 Message Date
c7c4043108 fix: Using snprintf while ignoring its return value could lead to valid inputs getting truncated. 2023-03-09 22:35:03 +00:00
9211bc3351 fix: Initialise array pointers to 0 before performing check on them. 2023-03-09 22:35:03 +00:00
bcae64e023 chore: Also renamed structs to follow naming conventions. 2023-03-09 22:35:03 +00:00
03bae82569 refactor: Added free function for package struct.
While going through with the renaming, I saw that I actually forgot to implement that part.
2023-03-09 22:35:03 +00:00
76e4adae92 chore: Package module now follows the naming and structure conventions of libvieter. 2023-03-09 22:35:03 +00:00
1ccd4101af refactor: Subsituted old hash generation with a proper implementation. 2023-03-09 22:35:03 +00:00
bbdc2fbd6e fix: strcat can not be used on uninitialised strings in non-musl environments. 2023-03-09 22:35:03 +00:00
d11a9d3638 chore: fix merge marker in makefile 2023-03-09 22:35:03 +00:00
d0914adbb5 fix: Somehow, test file changed line endings to CRLF. Changed it back to LF. 2023-03-09 22:35:03 +00:00
fbbc15cf73 chore: Rebase to dev branch with binomial heap PR. 2023-03-09 22:35:03 +00:00
660e711b17 refactor: Added SHA256 to package description file. 2023-03-09 22:35:03 +00:00
7561a74793 refactor: Decided to not return char** in function that creates the package description after all, now returns char*.
The method I was trying started to irk me when I thought of creating a test unit for it. Also fixed some other issues I found in the package_to_description function (SHA256SUM section still missing).
2023-03-09 22:35:03 +00:00
01688fd546 fix: Took a very long time finding a very annyoing bug because realloc is the devil. 2023-03-09 22:35:03 +00:00
edca243331 refactor: Created function that will return the char ** (originally char *) that will be used to make the description file. Also removed free that was resulting in a crash. 2023-03-09 22:35:03 +00:00
4309ad8cc5 refactor: Modified .PKGINFO parser not to rely on gotos and continues. Parser is now optimistic and assumes .PKGINFO file is valid.
After my changes to the macros, they still feel a bit hacky, but I'm content with them. I also changed the parser to assume the .PKGINFO files are always valid because they are automatically generated. The parser also assumes the same fields will always appear in the same fixed order. I made this change after checking how makepkg generated this file.
2023-03-09 22:35:03 +00:00
c2313fe0be refactor: Add original .c package files by Jef. 2023-03-09 22:35:03 +00:00
f376aedaee Merge pull request 'Red-black tree' (#5) from Chewing_Bever/libvieter:red-black-tree into dev
Reviewed-on: vieter-v/libvieter#5
2023-03-07 12:08:49 +01:00
38e84afd1d
fix: also lint internal header files 2023-02-23 10:13:58 +01:00
d9402ced54 test(tree): add random insert test 2023-02-02 15:52:59 +01:00
a6ed89d8cd
feat(tree): add tree iterator 2023-02-02 14:10:35 +01:00
ef5037f941
chore(tree): some small cleanups 2023-02-01 23:24:22 +01:00
bee520a781
fix(tree): working balanced remove 2023-02-01 23:04:35 +01:00
70217bee21
fix(tree): fix wrong rotation function 2023-02-01 22:12:34 +01:00
17c2e15385 feat(tree): first attempt at wikipedia pseudo code 2023-01-30 12:28:08 +01:00
1d458c68a4
feat(tree): start of balanced removal 2023-01-29 21:34:44 +01:00
b74a4e9326
refactor(tree): bit more cleanup 2023-01-29 21:08:17 +01:00
e5130a6383
feat(tree): bit flag so children know which child they are 2023-01-29 20:57:08 +01:00
193fc4b454
refactor(tree): store children as static array instead 2023-01-29 20:33:11 +01:00
06fca6f5ae
refactor(tree): better testing code 2023-01-29 17:32:27 +01:00
3fb027715c
test(tree): validation function to use in testing 2023-01-28 19:28:35 +01:00
89d1c9cdca chore: add license 2023-01-28 12:02:52 +01:00
3bf3150b4a
test: rename some stuff; separate cron part tests 2023-01-28 09:30:35 +01:00
adfdca18da
docs(tree): add function docstrings 2023-01-28 09:09:17 +01:00
e4e92b3e57
refactor(tree): proper filenames 2023-01-27 22:37:57 +01:00
1ce3b47edf
feat(tree): remove works 2023-01-27 22:37:57 +01:00
1c591ac423
feat(tree): first attempt at balanced inserts 2023-01-27 22:37:55 +01:00
41bc6516fa
feat(tree): add node bit flags support 2023-01-27 22:37:24 +01:00
910d7bc3bb
feat(tree): implement free function 2023-01-27 22:37:24 +01:00
935a610b7e
feat(tree): initially working binary tree 2023-01-27 22:37:23 +01:00
98f158e1f5
feat(tree): started standard binary tree 2023-01-27 22:35:06 +01:00
df50f96983
feat: begin binary tree implementation 2023-01-27 22:34:16 +01:00
379a05a7b6 Merge pull request 'Binomial heap' (#4) from Chewing_Bever/libvieter:min-heap into dev
Reviewed-on: vieter-v/libvieter#4
2023-01-27 22:32:02 +01:00
167611e6fa
test(heap): test insert after every pop just in case 2023-01-27 21:59:09 +01:00
5b2ce6acaa
feat(heap): thread-safety features 2023-01-27 21:23:32 +01:00
d77b3e4fee
chore: some nitpicking 2023-01-27 20:50:23 +01:00
ab418e57b3
test: also test with -O3 which can produce extra errors 2023-01-26 12:24:34 +01:00
a6bdd39776
docs(heap): add readme 2023-01-26 11:03:41 +01:00
05b96d1fd6
fix(heap): finally fixed that pop bug 2023-01-26 10:21:30 +01:00
3ec2e76af9
refactor(heap): some better variable names; some more tests 2023-01-25 22:12:22 +01:00
dc557f57ab
test(heap): some more tests to expose flaws 2023-01-25 20:49:18 +01:00