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

Crash if non-flatpak steam is missing #353

Closed
Keelhauled opened this issue Feb 9, 2024 · 8 comments · Fixed by #356
Closed

Crash if non-flatpak steam is missing #353

Keelhauled opened this issue Feb 9, 2024 · 8 comments · Fixed by #356
Labels
bug Something isn't working

Comments

@Keelhauled
Copy link

Describe the bug
Crash if non-flatpak steam is missing

To Reproduce
Start program without non-flatpak steam -> crash right away

Desktop (please complete the following information):

  • Platform: PC
  • System: Arch
  • Version: 2.9.0 and 2.9.1
  • How did you install ProtonUp-Qt?: Tested Flatpak and AppImage

Terminal output

Error: Could not get a list of all Steam apps: [Errno 2] No such file or directory: '/home/user/.local/share/Steam/config/libraryfolders.vdf'
Traceback (most recent call last):
  File "/usr/lib/python3.10/runpy.py", line 196, in _run_module_as_main
    return _run_code(code, main_globals, None,
  File "/usr/lib/python3.10/runpy.py", line 86, in _run_code
    exec(code, run_globals)
  File "/app/lib/python3.10/site-packages/pupgui2/__main__.py", line 2, in <module>
    main()
  File "/app/lib/python3.10/site-packages/pupgui2/pupgui2.py", line 571, in main
    MainWindow()
  File "/app/lib/python3.10/site-packages/pupgui2/pupgui2.py", line 109, in __init__
    self.update_ui()
  File "/app/lib/python3.10/site-packages/pupgui2/pupgui2.py", line 230, in update_ui
    global_ctool_name: str = get_steam_global_ctool_name(install_loc.get('vdf_dir'))
  File "/app/lib/python3.10/site-packages/pupgui2/steamutil.py", line 206, in get_steam_global_ctool_name
    d = get_steam_vdf_compat_tool_mapping(vdf.load(open(config_vdf_file)))
FileNotFoundError: [Errno 2] No such file or directory: '/home/user/.local/share/Steam/config/config.vdf'
@Keelhauled Keelhauled added the bug Something isn't working label Feb 9, 2024
@Keelhauled
Copy link
Author

Looks like it's happening because I still have files in the .local/share/Steam/compatibilitytools.d/. Probably a rare condition but could be worth checking for.

@sonic2kk
Copy link
Contributor

sonic2kk commented Feb 9, 2024

Having Steam files from a previous installation but no valid Steam install for that type is probably causing the crash as you point out, rather than anything to do with the Flatpak.

Although, I thought we'd be checking for a valid Steam install earlier:

# support different Steam root directories
# valid install dir should have config.vdf and libraryfolders.vdf, to ensure it is not an unused folder with correct directory structure
_POSSIBLE_STEAM_ROOTS = ['~/.local/share/Steam', '~/.steam/root', '~/.steam/steam', '~/.steam/debian-installation']
_STEAM_ROOT = _POSSIBLE_STEAM_ROOTS[0]
for steam_root in _POSSIBLE_STEAM_ROOTS:
ct_dir = os.path.join(os.path.expanduser(steam_root), 'config')
config_vdf = os.path.join(ct_dir, 'config.vdf')
libraryfolders_vdf = os.path.join(ct_dir, 'libraryfolders.vdf')
if os.path.exists(config_vdf) and os.path.exists(libraryfolders_vdf):
_STEAM_ROOT = steam_root
break

Oh, wait, we default to POSSIBLE_STEAM_ROOTS[0], which is the path you gave, ~/.local/share/Steam.

I guess there isn't a check for Steam being missing. We check for other launchers being missing, but I guess ProtonUp-Qt always expects Steam.

@sonic2kk
Copy link
Contributor

sonic2kk commented Feb 9, 2024

This could be the culprit:

if os.path.exists(install_dir):

Since ~/.local/share/Steam does exist. The above code in constants.py only exists to pick the right Steam install location and assumes Steam (non-flatpak) is installed, but needs to find it from a set of possible paths. However in your case, even though the check in constants.py fails, ~/.local/share/Steam does exist.

Perhaps we need a different helper function to call in util.py on the line linked to check for a valid installation depending on the launcher.

That line is part of a bigger loop that loops through all POSSIBLE_INSTALL_LOCATIONS:

POSSIBLE_INSTALL_LOCATIONS = [

Each install location is a dictionary with a display_name key, which distinguishes between different types, such as Steam, Steam Flatpak, and Steam Snap. We could pass this dictionary to a helper function instead of using os.path.exists, and the helper function will perform checks depending on the launcher type. We could further break this down, grabbing the path off this dictionary and then checking if certain files we need exist at a given path (such as grabbing the Steam install path and checking if a config.vdf exists). We don't actually care if Steam is installed per se, just if the files we need per-launcher exist (and usually, the files we need are removed if a given program is uninstalled, such as config.vdf).

@sonic2kk
Copy link
Contributor

I'll take a stab at getting a draft of something ready for this later tonight if no one else is looking at it. No guarantee I'll get the approach right but if I don't end up opening any PR I'll at least note the pitfalls I ran into :-)

@Bug23451
Copy link

Bug23451 commented Mar 5, 2024

Ran into the same issue here, if it helps I copied the missing file from another PC and it worked. The UI displays the native steam location as an option despite there not being a native installation.

@sonic2kk
Copy link
Contributor

sonic2kk commented Mar 5, 2024

Deleting the empty directories (i.e. removing all of ~/.local/share/Steam if it is entirely unused, or wherever your Steam path was) would've also solved the problem, instead of copying the files over. This would also resolve the UI displaying the install location.

The issue is that right now ProtonUp-Qt only looks to see if the Steam directories exist. If they do, it assumes Steam is installed, and when it tries to look for the VDF files it needs, they don't exist and it crashes. #356 is aiming to solve this by introducing a stricter check for these data files, with some other changes included (mainly refactoring some semi-related logic out of constants.py).


I am a bit curious though as to how a system can end up with these left behind directories. Did you uninstall regular Steam and replace it with Flatpak Steam, and this is just left-behind installation files? Nothing changed in the logic, so if this is the case, it seems there are more user switching to Flatpak Steam, that is, unistalling a previous Steam installation and switching. In other words, a use-case that has suddenly cropped up, which is why I ask. Just curiosity is all 😀

@Bug23451
Copy link

Bug23451 commented Mar 8, 2024

Arch linux was having a day the native package wasn't rendering so I uninstalled native and downloaded the flatpak version for troubleshooting.

@sonic2kk
Copy link
Contributor

Interesting, as an Arch user for many years I have never encountered that issue, but makes sense.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants