Bug#1059449: game-data-packager: Fate of Atlantis fails to start without "scumm:" prefix
Simon McVittie
smcv at debian.org
Sun Jan 28 17:20:05 GMT 2024
On Wed, 27 Dec 2023 at 14:18:25 +0100, Alexandre Detiste wrote:
> We agreed that there is too much intelligence in the generated, "unfixable"
> (unless someone takes the time to repack the game), generated .deb's;
> and that some or most of this intelligence should be moved
> to automatically upgradable game-data-packager-runtime.
The more often I see bugs in our generated .deb that cannot be fixed
without regenerating and reinstalling the .deb, which we could have
fixed in a new upload if it was structured differently, the more sure
I am that this is the way we should be going.
As a design principle, we should be trying to make sure that each generated
.deb only contains:
- files that we cannot legally redistribute
- an absolute minimum of "glue" which is so simple that it cannot have bugs
(for example a symlink to an executable, icon or .desktop file provided
by g-d-p-runtime is usually better than shipping an executable, icon
or .desktop file in the generated .deb itself)
> So actually (option a) the .desktop file would looks like this:
> > > +Exec=/usr/share/games/game-data-packager[runtime] fate-of-atlantis-en-data
The .desktop file, itself, is something that can have bugs (for example
missing Keywords, or referencing an icon that no longer exists), and
there is no legal or technical reason why we can't write .desktop files
that are Free Software and put them in game-data-packager-runtime, which
would let us fix their bugs whenever we want to by uploading a new version
of g-d-p. So we might as well do that!
> [option c proposal]
> pre-generated .desktop files shipped in game-data-packager-runtime at a
> unusual place & a symlink in the generated .deb's to activate it
Yes, this is the way.
We already generate ut99.deb containing a symlink
/usr/share/applications/ut99.desktop -> ../games/game-data-packager-runtime/ut99.desktop
pointing to a .desktop file that we can change as much as we want to.
More of this, please!
I see that Sébastien has been contributing launcher glue for old
binary-only Loki games like Railroad Tycoon 2, and this seems a completely
reasonable way to handle such games.
But, having said that:
> option 'a' would implies that g-d-p-runtime has access to g-d-p data to
> make the magic happen; a dependency we don't currently have
Whenever we find a situation where we want this, we can ship a
subset of g-d-p data in g-d-p-runtime. We effectively already
*do* ship a subset of g-d-p data in g-d-p-runtime: the files
/usr/share/games/game-data-packager-runtime/launch-*.json contain inputs
for the gdp-launcher multi-engine launcher.
As an implementation choice, we've separated the data for g-d-p
(data/ut99.yaml) from the data for the launcher (data/launch-ut99.yaml.in),
but we can restructure that any time we want to - the exact division
between those two is private to the game-data-packager source package, and
does not form part of a stable API.
(For scummvm, where all the games follow a common pattern and have
more similarities than differences, it would perhaps be better to
have a dedicated scummvm launcher rather than reusing the multi-engine
gdp-launcher program, but either is fine.)
The closest thing to a stable API here is that iortcw and openjk rely on
the existence of /usr/share/games/game-data-packager-runtime/gdp-launcher,
and the fact that when run as "openjk_sp" or similar, it knows how to look
up what game to launch.
> That could be an extra, tiny, scummvm.json generated at build time
> with the absolute minimal required infos:
> the mapping from package name to scummvm-id-of-the-day,
> + ... ?
Yes, this.
smcv
More information about the Pkg-games-devel
mailing list