1ac4592503
Aparrently, the act docker container does not have cmake installed.
...
Adding this should not make a significant impact on workflow
performance.
2025-09-15 09:35:59 +02:00
4da02373a5
disable fail fast, so feedback is provided for all matrix combinations
2025-09-15 09:25:18 +02:00
c724ff0449
remove explicit definition for repository, since it messes with act
...
`act` allows to debug github workflows before sending them to the
server, allowing to test some behaviour, before pushing.
2025-09-15 09:20:07 +02:00
348c4e484c
fix: clean-libs can fail when it shouldn't
2025-09-13 21:44:46 +02:00
1140bd97bf
fix: linking library glfw, whilst the library compilation produces libglfw3.
...
This slight discrepancy is a tad annoying, since it doesn't work
backwards so it uses my system's version. But we'll figure something for
that out later... probably.
2025-09-13 21:32:33 +02:00
997b15c640
fix: obj/res/ path did not create a directory, so likely failed to place anything there.
2025-09-13 21:17:07 +02:00
f481af7e78
fix: incorrect gl.c path
2025-09-13 21:16:33 +02:00
1169ca98b1
use threaded makefile for more efficiency.
2025-09-13 21:11:58 +02:00
75ebff9071
remove pointer arithmatic warnings, since they are just useful
2025-09-13 21:11:38 +02:00
4f081e7f3e
remove usage of mempcpy; this is apart of GNU C
2025-09-13 21:09:56 +02:00
8a1ed6e3c4
attempt without including windows
2025-09-13 21:04:29 +02:00
a7678c874c
write a CI workflow for multiple OSes, that compile and test the code using the makefile.
2025-09-13 20:57:54 +02:00
d9ddae770a
fix: just use compiler builtins with endianess
...
this is the most portable and clean approach. Compiler built-ins should
always be present regardless, and is more maintainable, since we're not
trying to keep up with various versions of this header.
2025-09-13 20:25:38 +02:00
c2e1b67b4c
seperate out library compilation from general compilation
...
This can help with a more nuanced compilation. (eg. use system libraries
rather than compile our own)
Furthermore, it decreases the needed compilation time, since we needn't
recompile the whole thing when having cleaned out our local sources.
2025-09-13 20:25:38 +02:00
8548c2d037
fix: log macros were using GNU extensions without them needing them.
...
We can optionally add `,` utilising the `__VA_OPT__` macro. However,
this lead to the next problem, which is that an empty vardiac parameter
is a C23 extension. This was solved by dropping the string parameter,
making it be part of the vardiac parameters.
2025-09-13 20:25:38 +02:00
7ec6a3b91a
fix: using __bswap_X functions over bswap_X macros, which we should be using.
2025-09-13 20:25:38 +02:00
3f48a7abb2
add compile commands events to gitignore
2025-09-13 20:25:38 +02:00
667814fb72
rework makefile to put extera emphasis on us no longer performing cross-platform compilation
...
Furthermore, we removed a bunch of behaviour that wasn't needed, and
simplified the bunch.
2025-09-13 20:25:38 +02:00
23fda298e6
fix: makefile had some duplicate configurations
2025-09-11 23:28:58 +02:00
03c76b0be6
rename makefile to Makefile, to reflect how everyone seems to name their makefile.
...
it just makes sense, and I might as well do it like this to prevent
confusing people.
2025-09-11 23:28:58 +02:00
f0d14e76b2
write decompression logic up to the point of hanelling the buffer.
2025-09-10 12:52:35 +02:00
07f4ea34d2
macro flipped const char
2025-09-10 12:07:00 +02:00
5de0c77992
start writing code for decompressing chunk data.
...
I still haven't much of an idea where I'll take this, but it's a start.
I know it is needed for block filtering and such, I still need to find a
way how I'll actually implement it.
2025-09-10 11:37:20 +02:00
2cfae0fce4
rework error.h, to decrease impact on binary size.
...
We were statically creating a new string per log message, so re-using
the same message would cause duplicate byte sizes.
Now, all prefixes / suffixes are only defined once, the file name is
defined once per file, the line number should be defined once per unique
line.
This just saves some memory in the final binary, allowing things to be
optimised a little better.
2025-09-10 11:37:20 +02:00
d933931829
fix: shouldn't multiply by CHUNKS, but by SECTOR
2025-09-10 10:13:26 +02:00
f020347f71
change mvchunks parameter order, to be a bit more clear and consistent with functions such as memmove
2025-09-10 10:13:26 +02:00
b13de01f24
fix: violating strict aliasing rules in most areas in the new code.
...
Yes, I am aware there are plenty of violations in `conf.c`, but I'll
likely fix/rewrite those when I will use it. Since there are some other
changes I think I'll want to make.
2025-09-10 10:13:26 +02:00
3a0704710c
add a flag when debugging to generate SIGFPE when signed integer overflow occurs. (this is UB)
2025-09-10 10:13:26 +02:00
b72b8eaee1
add comments to point at where strict aliasing rule violations occur in data scripts
...
this is definitely not all of them, a thorough rewrite must take place
to fix as many as we can.
2025-09-10 10:13:26 +02:00
55635d44ae
delete redundant COLOUR32 definitions
2025-09-10 10:13:26 +02:00
4fa0b41e7a
add quit in main.c to atexit, for added safety
2025-09-10 10:13:26 +02:00
8a5afd6915
write a portable version of endian.h, to replace the system's endian.h.
...
utilising GNU C standard library for some of the functionality, or GNU C
extensions.
2025-09-10 10:13:26 +02:00
8b952fb86f
edit makefile to remove redundant flags, and make clean task more conditional
2025-08-29 11:47:46 +02:00
0baadfca75
update copyright information in all files
...
the comment was using single-line comments, I prefer multi-line comments
now.
This bothered me for much too long.
2025-08-29 09:36:55 +02:00
9a45294e56
write some constants for mcx.c, so things are less error-prone.
2025-08-29 09:35:02 +02:00
5b5f1f54af
remove unneeded code
2025-08-28 16:46:27 +02:00
f1141e0db4
fix: not moving chunks correctly in mcx_delchunk_range
2025-08-28 10:59:30 +02:00
15942b47f5
fix: assertion was inverted
2025-08-28 10:57:00 +02:00
bc8803525d
update comments and a parameter name in mcx.h
2025-08-27 14:57:34 +02:00
7531d786be
add a function for range deleting chunks
2025-08-27 14:50:35 +02:00
2c5b9def28
should set the spare chunk to 0x400, not 0
2025-08-27 14:50:35 +02:00
cd277873b5
split apart the moving of the data, for further flexibility
2025-08-27 14:50:35 +02:00
f203cabad9
fix: endianess was (often) converted after performing computations or missing completely.
2025-08-27 14:47:50 +02:00
28dd8af353
add comments
2025-08-27 14:38:30 +02:00
9c690eb327
add NONNULL attributes to chunk deletion functions
2025-08-27 12:58:59 +02:00
af8211c5ce
write function for bulk removal of chunks
2025-08-27 12:58:28 +02:00
767f3a5c13
refactor of mcx_delchunk to make things a bit more clear and flexible
2025-08-27 12:30:38 +02:00
43e3e4fe85
fix: not converting big-endian numbers to host.
...
I swear I did have this here at some point... I've got no idea when I
removed it, or even why.
2025-08-27 12:30:38 +02:00
fad6f366b4
fix: mcx_delchunk was not updating the byte offset of affected chunks.
2025-08-27 12:30:38 +02:00
b7859d56d9
add function for computing the bytesize of the *.mcX file
2025-08-27 12:30:38 +02:00