mirror of
https://github.com/Redot-Engine/redot-engine.git
synced 2025-12-06 07:17:42 -05:00
Merge commit godotengine/godot@a3b42d85d2
This commit is contained in:
@@ -101,6 +101,21 @@ def library_emitter(target, source, env):
|
||||
|
||||
|
||||
def configure(env: "SConsEnvironment"):
|
||||
env["CC"] = "emcc"
|
||||
env["CXX"] = "em++"
|
||||
|
||||
env["AR"] = "emar"
|
||||
env["RANLIB"] = "emranlib"
|
||||
|
||||
# Get version info for checks below.
|
||||
cc_version = get_compiler_version(env)
|
||||
cc_semver = (cc_version["major"], cc_version["minor"], cc_version["patch"])
|
||||
|
||||
# Minimum emscripten requirements.
|
||||
if cc_semver < (4, 0, 0):
|
||||
print_error("The minimum Emscripten version to build Godot is 4.0.0, detected: %s.%s.%s" % cc_semver)
|
||||
sys.exit(255)
|
||||
|
||||
env.Append(LIBEMITTER=[library_emitter])
|
||||
|
||||
env["EXPORTED_FUNCTIONS"] = ["_main"]
|
||||
@@ -149,10 +164,15 @@ def configure(env: "SConsEnvironment"):
|
||||
env.Append(LINKFLAGS=["-Wl,--fatal-warnings"])
|
||||
|
||||
# LTO
|
||||
|
||||
if env["lto"] == "auto": # Enable LTO for production.
|
||||
env["lto"] = "thin"
|
||||
|
||||
if env["lto"] == "thin" and cc_semver < (4, 0, 9):
|
||||
print_warning(
|
||||
'"lto=thin" support requires Emscripten 4.0.9 (detected %s.%s.%s), using "lto=full" instead.' % cc_semver
|
||||
)
|
||||
env["lto"] = "full"
|
||||
|
||||
if env["lto"] != "none":
|
||||
if env["lto"] == "thin":
|
||||
env.Append(CCFLAGS=["-flto=thin"])
|
||||
@@ -175,6 +195,13 @@ def configure(env: "SConsEnvironment"):
|
||||
env.Append(LINKFLAGS=["-sSAFE_HEAP=1"])
|
||||
|
||||
# Closure compiler
|
||||
if env["use_closure_compiler"] and cc_semver < (4, 0, 11):
|
||||
print_warning(
|
||||
'"use_closure_compiler=yes" support requires Emscripten 4.0.11 (detected %s.%s.%s), using "use_closure_compiler=no" instead.'
|
||||
% cc_semver
|
||||
)
|
||||
env["use_closure_compiler"] = False
|
||||
|
||||
if env["use_closure_compiler"]:
|
||||
# For emscripten support code.
|
||||
env.Append(LINKFLAGS=["--closure", "1"])
|
||||
@@ -201,12 +228,6 @@ def configure(env: "SConsEnvironment"):
|
||||
# Add method for creating the final zip file
|
||||
env.AddMethod(create_template_zip, "CreateTemplateZip")
|
||||
|
||||
env["CC"] = "emcc"
|
||||
env["CXX"] = "em++"
|
||||
|
||||
env["AR"] = "emar"
|
||||
env["RANLIB"] = "emranlib"
|
||||
|
||||
# Use TempFileMunge since some AR invocations are too long for cmd.exe.
|
||||
# Use POSIX-style paths, required with TempFileMunge.
|
||||
env["ARCOM_POSIX"] = env["ARCOM"].replace("$TARGET", "$TARGET.posix").replace("$SOURCES", "$SOURCES.posix")
|
||||
@@ -223,15 +244,6 @@ def configure(env: "SConsEnvironment"):
|
||||
env["LIBPREFIXES"] = ["$LIBPREFIX"]
|
||||
env["LIBSUFFIXES"] = ["$LIBSUFFIX"]
|
||||
|
||||
# Get version info for checks below.
|
||||
cc_version = get_compiler_version(env)
|
||||
cc_semver = (cc_version["major"], cc_version["minor"], cc_version["patch"])
|
||||
|
||||
# Minimum emscripten requirements.
|
||||
if cc_semver < (3, 1, 62):
|
||||
print_error("The minimum emscripten version to build Redot is 3.1.62, detected: %s.%s.%s" % cc_semver)
|
||||
sys.exit(255)
|
||||
|
||||
env.Prepend(CPPPATH=["#platform/web"])
|
||||
env.Append(CPPDEFINES=["WEB_ENABLED", "UNIX_ENABLED", "UNIX_SOCKET_UNAVAILABLE"])
|
||||
|
||||
|
||||
@@ -11,7 +11,6 @@ if (process && process.env && process.env.npm_command && !fs.existsSync('./platf
|
||||
}
|
||||
|
||||
const emscriptenGlobals = {
|
||||
'Browser': true,
|
||||
'ERRNO_CODES': true,
|
||||
'FS': true,
|
||||
'GL': true,
|
||||
@@ -22,6 +21,7 @@ const emscriptenGlobals = {
|
||||
'HEAPU32': true,
|
||||
'IDBFS': true,
|
||||
'LibraryManager': true,
|
||||
'MainLoop': true,
|
||||
'Module': true,
|
||||
'UTF8ToString': true,
|
||||
'UTF8Decoder': true,
|
||||
|
||||
@@ -410,7 +410,7 @@ class SampleNode {
|
||||
* @returns {void}
|
||||
*/
|
||||
static delete(id) {
|
||||
GodotAudio.sampleNodes.delete(id);
|
||||
GodotAudio.deleteSampleNode(id);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -778,15 +778,9 @@ class SampleNode {
|
||||
}
|
||||
|
||||
switch (self.getSample().loopMode) {
|
||||
case 'disabled': {
|
||||
const id = this.id;
|
||||
case 'disabled':
|
||||
self.stop();
|
||||
if (GodotAudio.sampleFinishedCallback != null) {
|
||||
const idCharPtr = GodotRuntime.allocString(id);
|
||||
GodotAudio.sampleFinishedCallback(idCharPtr);
|
||||
GodotRuntime.free(idCharPtr);
|
||||
}
|
||||
} break;
|
||||
break;
|
||||
case 'forward':
|
||||
case 'backward':
|
||||
self.restart();
|
||||
@@ -1177,6 +1171,15 @@ const _GodotAudio = {
|
||||
*/
|
||||
sampleNodes: null,
|
||||
SampleNode,
|
||||
deleteSampleNode: (pSampleNodeId) => {
|
||||
GodotAudio.sampleNodes.delete(pSampleNodeId);
|
||||
if (GodotAudio.sampleFinishedCallback == null) {
|
||||
return;
|
||||
}
|
||||
const sampleNodeIdPtr = GodotRuntime.allocString(pSampleNodeId);
|
||||
GodotAudio.sampleFinishedCallback(sampleNodeIdPtr);
|
||||
GodotRuntime.free(sampleNodeIdPtr);
|
||||
},
|
||||
|
||||
// `Bus` class
|
||||
/**
|
||||
|
||||
@@ -110,7 +110,8 @@ void print_web_header() {
|
||||
// Emscripten.
|
||||
char *emscripten_version_char = godot_js_emscripten_get_version();
|
||||
String emscripten_version = vformat("Emscripten %s", emscripten_version_char);
|
||||
memfree(emscripten_version_char);
|
||||
// `free()` is used here because it's not memory that was allocated by Godot.
|
||||
free(emscripten_version_char);
|
||||
|
||||
// Build features.
|
||||
String thread_support = OS::get_singleton()->has_feature("threads")
|
||||
|
||||
Reference in New Issue
Block a user