Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mac version crashes when launched from Steam but runs successfully from local .app. #120

Open
singlecolor opened this issue Sep 29, 2023 · 5 comments

Comments

@singlecolor
Copy link

singlecolor commented Sep 29, 2023

Hi, we've got a small word game built in React Native + Expo. For the desktop version, we're using webpack + Electron Forge. We've integrated steamworks.js as well. The PC version works fine.

The Mac version runs locally if we launch from the .app directly, with Steam open in the background (so the Steamworks API is at least working). However, if we install + launch from Steam, we get a crash:

mac-crash

It seems like Steam simply can't find the .app file or some other library.

We have uploaded the zip 3 different ways and target the .app at the root level in Steam:

  1. Sending the zipped .app that Electron Forge spits out without any changes
  2. Zipping the loose files including: .app, LICENSE, LICENSES.chromium.html, steam_appid.txt, version.
  3. Same as 2, but copying the steam_appid.txt into the MacOS folder as well.

Notably the PC version also had issues with the zip that Electron Forge spit out, but we resolved this by zipping the loose files ourselves. The zip that Electron Forge spit out for PC actually had a folder at the top level which Steam did not like. So we have a hunch that the Mac version also has some file structure issue.

Any thoughts here? I realize it's possible that this may not be a Steamworks.js issue, but in that case I figure some of you may have had similar experience with Steam setup.

Thanks!

@Snarling
Copy link

Snarling commented Oct 4, 2023

This could be totally unrelated, since our package (Bitburner) doesn't actually use steamworks yet, and we're using electron-packager and not electron forge.

However, we have run into issues with the Mac build so I figured I would share some info on the issues we had with that, in case your issues are related.

  1. When using a windows machine, attempting to build the "Darwin" version which is what we use for Mac tells us we can't do it from Windows due to needing admin permission to create symbolic links:
    image
  2. With admin permissions, the darwin version is packaged successfully, but zipping it seemed to also require admin permissions, and even when we finally were able to zip it, it did not run for mac users (I don't have info handy for the exact issues).
  3. We had no problems building the packages and zipping them from Linux/WSL (probably from mac is fine as well), and the game runs fine for our mac users now. However, the zipped size of the mac version is over twice as large as the windows and linux versions.
    image

@singlecolor
Copy link
Author

Thanks for the info - I did come also across some other threads with issues related to symlinks for this.

We did not try building the Mac version from PC (the failing Mac build was from Mac), and we don't have access to Linux/WSL to try that unfortunately. I am wondering if the Mac zip package is failing due to symlinks now rather than the arrangement of the file structure.

Another person in our Discord server successfully got Mac working via Steamworks SDK's ContentBuilder instead of ZIP upload though, so we may try that next.

@vsobotka
Copy link

Recently we have released a game on Steam, and we also found out that uploading the ZIP via Steamworks web breaks the symlinks. Automating the whole process is quite cumbersome due to the 2FA requirement, so we settled with a build in CircleCI, and manual upload via web for the time being. The Mac version unfortunately has 70% larger size than necessary. Uploading the same zip with symlinks via SteamCMD works.

@devlsh
Copy link

devlsh commented Oct 21, 2023

Also experiencing the same issue with GitHub Actions pipeline

@Slakinov
Copy link

For anyone else having this problem, I just spent the last 3 days tearing my hair out, trying all sorts of combinations of versions of Electron, different ways of signing the app. What finally got our app to work after being uploaded to Steam and launched from the Steam client was to uninstall the app from the Steam client and do a fresh install. It seems whenever you push an update to Steam, it tries to be clever (and save bandwidth $$$) and downloads an incremental update. I'm imagining this plays havoc with MacOS extremely brittle app signing requirements or something?

So the shitty solution is: get your Mac users to uninstall and reinstall your game every time you release an update. Not ideal but it works. Moving on from this issue before I go completely insane / drop dead from stress.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants