Re: [Gimp-developer] PF_ENUM, SF_ENUM, dynamically defined enums for plugins
- From: Lloyd Konneker <konnekerl gmail com>
- To: gimp-developer <gimp-developer-list gnome org>
- Subject: Re: [Gimp-developer] PF_ENUM, SF_ENUM, dynamically defined enums for plugins
- Date: Fri, 12 Aug 2022 15:43:43 -0400
I continued to prototype this.
Proved that a plugin can cross the wire to GIMP with
gimp_procedure_add_enum.
It creates a dynamic GEnum on both sides of the wire.
But it revealed these problems:
1. GIMP crashes when it starts the second time after installation,
I suppose when it is reading plugins.rc, which contains the names of
dynamic enums,
that aren't defined types at the time.
2. The PDB Browser similarly crashes when it references dynamic enum types,
from the registered signatures of plugin procedures.
The PDB Browser is a plugin running in its own process,
and again the dynamic types are not defined yet,
in the GType runtime system.
I think a solution would be to keep a db of dynamic enums declared by
plugin procedures.
Similar to, or part of the PDB.
At startup, GIMP would dynamically define the enums from the db,
before reconstituting the procedure declarations in the PDB
(which reference the dynamic enums.)
This would make the dynamic enums defined by plugins available
to all GIMP processes, the app or plugins.
Again, there might be a better solution (the aux_argument solution proposed
by Jehan.)
But this solution is not inventing a new concept.
This solution uses a concept (plugins can dynamically define enums) that
GLib supports,
and GIMP already has the concept of dynamically defined procedures (into
the PDB)
In other words, its just more of the same or similar,
dynamically defining enum types as well as procedure types.
I will soon submit a draft MR of the prototype so you can see what it
entails, so far.
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]