summaryrefslogtreecommitdiffstats
path: root/modules/mono
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-08-20 10:02:47 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-08-20 10:02:47 +0200
commit73d42411f07479da605024f78d1c697ca470b55b (patch)
tree5f2872c108d798e71d19a7b2e3abb6cf8dde5a06 /modules/mono
parent5e400c7bd979352e48237f8b491e6bc0c1498788 (diff)
parent3c0eaec39f62ba1d86ba12abdf3f95779e608c25 (diff)
downloadredot-engine-73d42411f07479da605024f78d1c697ca470b55b.tar.gz
Merge pull request #95808 from paulloz/bugfix/dotnet-globalclass-icon-relative-paths
Fix relative paths for global class icons in C#
Diffstat (limited to 'modules/mono')
-rw-r--r--modules/mono/glue/GodotSharp/GodotSharp/Core/Bridge/ScriptManagerBridge.cs10
1 files changed, 8 insertions, 2 deletions
diff --git a/modules/mono/glue/GodotSharp/GodotSharp/Core/Bridge/ScriptManagerBridge.cs b/modules/mono/glue/GodotSharp/GodotSharp/Core/Bridge/ScriptManagerBridge.cs
index 5cc2a8026e..901700067d 100644
--- a/modules/mono/glue/GodotSharp/GodotSharp/Core/Bridge/ScriptManagerBridge.cs
+++ b/modules/mono/glue/GodotSharp/GodotSharp/Core/Bridge/ScriptManagerBridge.cs
@@ -241,11 +241,17 @@ namespace Godot.Bridge
if (outIconPath != null)
{
- var iconAttr = scriptType.GetCustomAttributes(inherit: false)
+ IconAttribute? iconAttr = scriptType.GetCustomAttributes(inherit: false)
.OfType<IconAttribute>()
.FirstOrDefault();
- *outIconPath = Marshaling.ConvertStringToNative(iconAttr?.Path);
+ if (!string.IsNullOrEmpty(iconAttr?.Path))
+ {
+ string iconPath = iconAttr.Path.IsAbsolutePath()
+ ? iconAttr.Path.SimplifyPath()
+ : scriptPathStr.GetBaseDir().PathJoin(iconAttr.Path).SimplifyPath();
+ *outIconPath = Marshaling.ConvertStringToNative(iconPath);
+ }
}
if (outBaseType != null)