2023-05-17 04:11:51 +08:00
|
|
|
import zlib
|
|
|
|
|
|
|
|
|
2022-10-12 22:21:34 +08:00
|
|
|
def run(target, source, env):
|
|
|
|
src = source[0]
|
|
|
|
dst = target[0]
|
2023-05-17 04:11:51 +08:00
|
|
|
f = open(src, "rb")
|
2022-10-12 22:21:34 +08:00
|
|
|
g = open(dst, "w", encoding="utf-8")
|
|
|
|
|
2023-05-17 04:11:51 +08:00
|
|
|
buf = f.read()
|
|
|
|
decomp_size = len(buf)
|
|
|
|
|
|
|
|
# Use maximum zlib compression level to further reduce file size
|
|
|
|
# (at the cost of initial build times).
|
|
|
|
buf = zlib.compress(buf, zlib.Z_BEST_COMPRESSION)
|
|
|
|
|
2022-10-12 22:21:34 +08:00
|
|
|
g.write(
|
|
|
|
"""/* THIS FILE IS GENERATED DO NOT EDIT */
|
2022-12-07 19:11:28 +08:00
|
|
|
#ifndef GDEXTENSION_INTERFACE_DUMP_H
|
|
|
|
#define GDEXTENSION_INTERFACE_DUMP_H
|
2022-10-12 22:21:34 +08:00
|
|
|
|
|
|
|
#ifdef TOOLS_ENABLED
|
|
|
|
|
2023-05-17 04:11:51 +08:00
|
|
|
#include "core/io/compression.h"
|
2022-10-12 22:21:34 +08:00
|
|
|
#include "core/io/file_access.h"
|
|
|
|
#include "core/string/ustring.h"
|
|
|
|
|
2023-05-17 04:11:51 +08:00
|
|
|
"""
|
2022-10-12 22:21:34 +08:00
|
|
|
)
|
2023-05-17 04:11:51 +08:00
|
|
|
|
|
|
|
g.write("static const int _gdextension_interface_data_compressed_size = " + str(len(buf)) + ";\n")
|
|
|
|
g.write("static const int _gdextension_interface_data_uncompressed_size = " + str(decomp_size) + ";\n")
|
|
|
|
g.write("static const unsigned char _gdextension_interface_data_compressed[] = {\n")
|
|
|
|
for i in range(len(buf)):
|
|
|
|
g.write("\t" + str(buf[i]) + ",\n")
|
|
|
|
g.write("};\n")
|
2022-10-12 22:21:34 +08:00
|
|
|
|
|
|
|
g.write(
|
|
|
|
"""
|
2023-05-17 04:11:51 +08:00
|
|
|
class GDExtensionInterfaceDump {
|
2022-10-12 22:21:34 +08:00
|
|
|
public:
|
2022-12-07 19:11:28 +08:00
|
|
|
static void generate_gdextension_interface_file(const String &p_path) {
|
2022-10-12 22:21:34 +08:00
|
|
|
Ref<FileAccess> fa = FileAccess::open(p_path, FileAccess::WRITE);
|
2023-03-08 12:30:37 +08:00
|
|
|
ERR_FAIL_COND_MSG(fa.is_null(), vformat("Cannot open file '%s' for writing.", p_path));
|
2023-05-17 04:11:51 +08:00
|
|
|
Vector<uint8_t> data;
|
|
|
|
data.resize(_gdextension_interface_data_uncompressed_size);
|
|
|
|
int ret = Compression::decompress(data.ptrw(), _gdextension_interface_data_uncompressed_size, _gdextension_interface_data_compressed, _gdextension_interface_data_compressed_size, Compression::MODE_DEFLATE);
|
|
|
|
ERR_FAIL_COND_MSG(ret == -1, "Compressed file is corrupt.");
|
|
|
|
fa->store_buffer(data.ptr(), data.size());
|
2022-10-12 22:21:34 +08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // TOOLS_ENABLED
|
|
|
|
|
2022-12-07 19:11:28 +08:00
|
|
|
#endif // GDEXTENSION_INTERFACE_DUMP_H
|
2022-10-12 22:21:34 +08:00
|
|
|
"""
|
|
|
|
)
|
|
|
|
g.close()
|
|
|
|
f.close()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
from platform_methods import subprocess_main
|
|
|
|
|
|
|
|
subprocess_main(globals())
|