Skip to content

Commit

Permalink
Fix MacOS Content directory location. (MonoGame#8479)
Browse files Browse the repository at this point in the history
According to the docs [1] we now have the arm64 and x64 platforms
in a MacOS app bundle are now in their own subdirectories.

The problem is our code in the TitleContainer assumes the `Resources`
directory is only one level above the `MacOS` directory.

```
Contents/
       MacOS/
       Resources/
```

However with the new platform specific code the recommendation is to
place the arm64 and x64 code in their own folders.

```
Contents/
       MacOS/
          arm64/
          amd64/
       Resources/
```

The means that we can never find the `Resources` directory and it
defaults to the current directory. Which will cause a crash.

So lets add another backup path check to handle this situation.

[1] https://docs.monogame.net/articles/getting_started/packaging_games.html?tabs=macos
  • Loading branch information
dellis1972 authored Sep 8, 2024
1 parent 3dd1d56 commit 584eaa2
Showing 1 changed file with 4 additions and 1 deletion.
5 changes: 4 additions & 1 deletion MonoGame.Framework/Platform/TitleContainer.Desktop.cs
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,11 @@ static partial void PlatformInit()
#if DESKTOPGL
// Check for the package Resources Folder first. This is where the assets
// will be bundled.
if (CurrentPlatform.OS == OS.MacOSX)
if (CurrentPlatform.OS == OS.MacOSX) {
Location = Path.Combine (AppDomain.CurrentDomain.BaseDirectory, "..", "Resources");
if (!Directory.Exists (Location))
Location = Path.Combine (AppDomain.CurrentDomain.BaseDirectory, "..", "..", "Resources");
}
if (!Directory.Exists (Location))
#endif
Location = AppDomain.CurrentDomain.BaseDirectory;
Expand Down

0 comments on commit 584eaa2

Please sign in to comment.