You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2026-01-04 19:21:46 +00:00
Merge pull request #79010 from bruvzg/set_native_icon_crash
[macOS] Fix `set_native_icon` crash with empty or invalid ICNS file.
This commit is contained in:
@@ -3588,16 +3588,22 @@ void DisplayServerMacOS::set_native_icon(const String &p_filename) {
|
||||
|
||||
Vector<uint8_t> data;
|
||||
uint64_t len = f->get_length();
|
||||
ERR_FAIL_COND_MSG(len < 8, "Error reading icon data."); // "icns" + 32-bit length
|
||||
|
||||
data.resize(len);
|
||||
f->get_buffer((uint8_t *)&data.write[0], len);
|
||||
|
||||
NSData *icon_data = [[NSData alloc] initWithBytes:&data.write[0] length:len];
|
||||
ERR_FAIL_COND_MSG(!icon_data, "Error reading icon data.");
|
||||
@try {
|
||||
NSData *icon_data = [[NSData alloc] initWithBytes:&data.write[0] length:len];
|
||||
ERR_FAIL_COND_MSG(!icon_data, "Error reading icon data.");
|
||||
|
||||
NSImage *icon = [[NSImage alloc] initWithData:icon_data];
|
||||
ERR_FAIL_COND_MSG(!icon, "Error loading icon.");
|
||||
NSImage *icon = [[NSImage alloc] initWithData:icon_data];
|
||||
ERR_FAIL_COND_MSG(!icon, "Error loading icon.");
|
||||
|
||||
[NSApp setApplicationIconImage:icon];
|
||||
[NSApp setApplicationIconImage:icon];
|
||||
} @catch (NSException *exception) {
|
||||
ERR_FAIL_MSG("NSException: " + String::utf8([exception reason].UTF8String));
|
||||
}
|
||||
}
|
||||
|
||||
void DisplayServerMacOS::set_icon(const Ref<Image> &p_icon) {
|
||||
|
||||
Reference in New Issue
Block a user