Dear all,
I recently faced the requirement to write a piece of code to test OpenGL options before adapting the rendering environment for my main program.
Thanks to the help of @ebassi it worked out nicely … for Linux … I had no chance to test this out for macOS but I am confident that it will also work properly (will check that tomorrow actually).
Today however I tried to test the new windows version of my program (build using meson on msys2), installed it and faced the following issue:
No way to launch the program when I double click on the desktop shortcut created for that purpose:
Where Prefix is the installation directory of my program.
And proc_name is the correct name of the program that should be launch but somehow is not found and the call fails, but the binary is indeed in the proper place.
But then when I try to run the same program via msys2 no problem at all:
Exact same information in the back, but different result … any idea what is going on ?
Just because most often people launch windows application via shortcuts not msys2
Instead of using GSubprocess directly, I recommend GSubprocessLauncher instead, in that sequence:
g_subprocess_launcher_new()
g_subprocess_launcher_set_cwd() → pass “C:\Program Files\Atomes\bin” here
g_subprocess_launcher_spawn()
The “spawn()” returns a GSubprocess, you can use “g_subprocess_wait()” on it like you already do.
The advantage of GSubprocessLauncher is that you can control the environment of the subprocess, including its current working directory. I used it on Windows too (from PyGObject), it worked great!
In that screen capture: proc_dir is the directory passed as argument to g_subprocess_launcher_set_cwd proc_name is the name of the binary to launch passed as argument to g_subprocess_launcher_spawn
And again I can start the application successfully if I use MSYS2 (see above)
and even if the directory is not in the PATH environment variable.
I am afraid that this is (once more) out of my league …
The thing is that I print the result of g_get_current_dir() after changing directory to proc_dir using g_subprocess_launcher_set_cwd but I guess current location and where to run subprocesses are not similar …
When I edit the properties of the shortcut, to start in C:\Program Files\Atomes\bin (instead of the default C:\Program Files\Atomes)
By the way, what do you pass to g_subprocess_launcher_set_cwd (...) ?
Is it a hardcoded path, or (better) do you dynamically detect the location of “atomes.exe” to use the path as cwd?
And again this work in MSYS2, I though about some environment variable that could affect this, but no way to know which one … nope that is not it, try to encode all environment from MSYS2 using a bunch of g_setenv() and it has no effect.
Ok, so the shortcut points to atomes.exe. During startup, atomes.exe launches atomes_startup_testing.exe as a subprocess to check a few OpenGL options. After a while atomes_startup_testing.exe exits and atomes.exe continues execution.
I have a few questions:
Are you sure that launching atomes_startup_testing.exe from File Explorer succeeds? Could it be that the process is terminated before reaching the main function? There are many ways to check, here’s how using PowerShell:
Navigate to C:\Program Files\Atomes\bin with File Explorer