cross-posted from: https://lemm.ee/post/38676431

A while back I ended up getting tired of making hacks to get custom binaries to launch in Steam for Windows titles. Primarily for modding, I would find a way to simply launch custom EXE files through Steam to ensure the modding tools and the game were contained neatly in the same prefix. My first ventures with this were Skyrim and Fallout: New Vegas. With these titles, I overrode the gamebryo/creation engine launcher EXE with Mod Organizer 2 (renamed to be the launcher). While this worked, the solution doesn’t work for other games without a secondary launcher that is targeted through Steam.

I eventually came to the conclusion that one can override launch targets entirely in Steam, and that tools like SteamTinkerLaunch could take advantage of this. However, STL certainly does a lot and honestly, that is way more than I really desired just to launch games with a custom EXE. Thus I made a shell script that essentially allows for the user to write in their own custom target and have it launch right through Steam.

The usage for this is simple. Just copy the ‘shim’ file into the game directory, override the Steam launch arguments to include “./shim %command%”, and all is good. Furthermore, environment variables (such as DRI_PRIME=1), additional launch wrappers (gamemoderun), and game launch arguments (-novid for Source Engine titles) all work. If one needed a combination of all of this, it would look something like “DRI_PRIME=1 gamemoderun ./shim %command% -novid”.

The way target editing currently works is on first launch the shim file grabs the default game target and writes it as the contents of ‘target’, another file in the game directory. From there, one can simply edit the target location in the file and shim will launch the custom executable.

So far, I have used this to get things like RaftModLoader and BeamMP working (mod loader for Raft and multiplayer for BeamNG.Drive respectively). I see no issue with this being able to also work for Bethesda titles and others that need custom executables. As I understand as well, the actual game install directories on a Steam Deck with SteamOS are mutable, and with a bit of tinkering through desktop mode should help get a seamless experience for launching modded Steam games for Deck users as well.

I hope someone finds as much use and utility that I have for getting a lot of modding tools for Windows games working without needing to mangle the prefix using protontricks in some cases or install the absolute multi-tool that is SteamTinkerLaunch.

  • Confetti Camouflage@pawb.social
    link
    fedilink
    English
    arrow-up
    0
    ·
    2 months ago

    Does this allow running multiple executables at the same time inside the game’s proton prefix? Like say, running the game and a widescreen memory patcher at the same time.

    • MentalEdge@sopuli.xyz
      link
      fedilink
      arrow-up
      0
      ·
      2 months ago

      Sounds like it does exactly that.

      I used a widescreen hack with FF7 to get a fullscreen aspect ratio on my steamdeck, and the way I did it was to make steam launch both the patcher and game at the same time.

        • MentalEdge@sopuli.xyz
          link
          fedilink
          arrow-up
          0
          ·
          2 months ago

          Obviously not. I said it sounds like that’s what I can do.

          And I obviously didn’t use this for my use case. That was ages ago.

          • braindefragger@lemmy.world
            link
            fedilink
            arrow-up
            0
            ·
            2 months ago

            4-5 years ago I was really into elite dangerous. I had no issue using something like protontricks to select the game’s proton prefix, install/launch the head tracking exe and the voice pack software first. Then launch elite dangerous with steam. Had all the apps working together under one prefix with a mildly annoying process.

                • MentalEdge@sopuli.xyz
                  link
                  fedilink
                  arrow-up
                  0
                  ·
                  2 months ago

                  Kinda.

                  If you want the applications to work on the memory interaction level, they have to be children of the same process. If you start a game launcher in wine, and then start a game from it, it can “see” that game process, close it, join friends, whatever.

                  But if you start the game exe directly, then separately start the launcher while the game is already running, then it won’t be able to see that there’s already a running game process.

                  It’s not always enough for the processes to just be part of the same file system (same prefix). If all you need is some input interactions like with voiceattack or trackIR, that doesn’t matter. But for memory hacks it does.

                  Wine has an internal task manager and if you just start processes without making sure they are running together, they’ll all end up in their own separate wine instances, even though they are on same prefix.

                  • braindefragger@lemmy.world
                    link
                    fedilink
                    arrow-up
                    0
                    ·
                    2 months ago

                    You just spent a whole lot of time thinking you’re splain’n to me something I don’t understand.

                    I played Elite Dangerous for years under proton. I was also able to launch all the third party apps like Voice Attack, Head Tracking and other tools requiring direct access to game, all within the same prefix. If I tried to execute them separately, they would not see the game and fail to initialize/work.

    • jrgd@lemm.eeOP
      link
      fedilink
      arrow-up
      0
      ·
      2 months ago

      It doesn’t currently allow for concurrent execution of EXE files, but that’s a good idea. I’ll see about implementing it.