2020-01-01 21:29:24 +01:00
|
|
|
#ifndef BINARYBLOB_H
|
|
|
|
#define BINARYBLOB_H
|
|
|
|
|
2021-02-18 08:48:41 +01:00
|
|
|
#include <stddef.h>
|
2020-07-01 00:27:57 +02:00
|
|
|
|
2020-01-01 21:29:24 +01:00
|
|
|
/* Laaaazyyyyyyy -flibit */
|
|
|
|
// #define VVV_COMPILEMUSIC
|
|
|
|
|
2021-02-16 01:38:10 +01:00
|
|
|
#define TRACK_NAMES(blob) \
|
|
|
|
FOREACH_TRACK(blob, "data/music/0levelcomplete.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/1pushingonwards.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/2positiveforce.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/3potentialforanything.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/4passionforexploring.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/5intermission.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/6presentingvvvvvv.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/7gamecomplete.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/8predestinedfate.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/9positiveforcereversed.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/10popularpotpourri.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/11pipedream.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/12pressurecooker.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/13pacedenergy.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/14piercingthesky.ogg") \
|
|
|
|
FOREACH_TRACK(blob, "data/music/predestinedfatefinallevel.ogg")
|
2020-07-01 00:17:02 +02:00
|
|
|
|
2020-01-01 21:29:24 +01:00
|
|
|
struct resourceheader
|
|
|
|
{
|
|
|
|
char name[48];
|
2020-06-15 13:37:05 +02:00
|
|
|
int start_UNUSED;
|
2020-01-01 21:29:24 +01:00
|
|
|
int size;
|
|
|
|
bool valid;
|
|
|
|
};
|
|
|
|
|
|
|
|
class binaryBlob
|
|
|
|
{
|
|
|
|
public:
|
Explicitly declare void for all void parameter functions (#628)
Apparently in C, if you have `void test();`, it's completely okay to do
`test(2);`. The function will take in the argument, but just discard it
and throw it away. It's like a trash can, and a rude one at that. If you
declare it like `void test(void);`, this is prevented.
This is not a problem in C++ - doing `void test();` and `test(2);` is
guaranteed to result in a compile error (this also means that right now,
at least in all `.cpp` files, nobody is ever calling a void parameter
function with arguments and having their arguments be thrown away).
However, we may not be using C++ in the future, so I just want to lay
down the precedent that if a function takes in no arguments, you must
explicitly declare it as such.
I would've added `-Wstrict-prototypes`, but it produces an annoying
warning message saying it doesn't work in C++ mode if you're compiling
in C++ mode. So it can be added later.
2021-02-25 23:23:59 +01:00
|
|
|
binaryBlob(void);
|
2020-01-01 21:29:24 +01:00
|
|
|
|
|
|
|
#ifdef VVV_COMPILEMUSIC
|
|
|
|
void AddFileToBinaryBlob(const char* _path);
|
|
|
|
|
|
|
|
void writeBinaryBlob(const char* _name);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
bool unPackBinary(const char* _name);
|
|
|
|
|
|
|
|
int getIndex(const char* _name);
|
|
|
|
|
|
|
|
int getSize(int _index);
|
|
|
|
|
2021-02-18 08:48:41 +01:00
|
|
|
bool nextExtra(size_t* start);
|
2020-07-01 00:27:57 +02:00
|
|
|
|
2020-01-01 21:29:24 +01:00
|
|
|
char* getAddress(int _index);
|
|
|
|
|
Explicitly declare void for all void parameter functions (#628)
Apparently in C, if you have `void test();`, it's completely okay to do
`test(2);`. The function will take in the argument, but just discard it
and throw it away. It's like a trash can, and a rude one at that. If you
declare it like `void test(void);`, this is prevented.
This is not a problem in C++ - doing `void test();` and `test(2);` is
guaranteed to result in a compile error (this also means that right now,
at least in all `.cpp` files, nobody is ever calling a void parameter
function with arguments and having their arguments be thrown away).
However, we may not be using C++ in the future, so I just want to lay
down the precedent that if a function takes in no arguments, you must
explicitly declare it as such.
I would've added `-Wstrict-prototypes`, but it produces an annoying
warning message saying it doesn't work in C++ mode if you're compiling
in C++ mode. So it can be added later.
2021-02-25 23:23:59 +01:00
|
|
|
void clear(void);
|
2020-06-07 22:11:35 +02:00
|
|
|
|
2020-08-14 11:02:16 +02:00
|
|
|
static const int max_headers = 128;
|
|
|
|
|
2020-01-01 21:29:24 +01:00
|
|
|
private:
|
|
|
|
int numberofHeaders;
|
2020-08-14 11:02:16 +02:00
|
|
|
resourceheader m_headers[max_headers];
|
|
|
|
char* m_memblocks[max_headers];
|
2020-01-01 21:29:24 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* BINARYBLOB_H */
|