mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-26 05:56:14 +01:00
girepository: Skip GIRepository versions not matching GIRepository-3.0
A few applications such as gnome-music load the GIRepository typelib and use it to adjust their search paths. GLib 2.79.x now provides libgirepository-2.0.so.0 (GIRepository-3.0), but each OS distribution is likely to have a transitional period during which GLib's libgirepository-2.0.so.0 has become available, but bindings like PyGI and gjs are still linked to gobject-introspection's libgirepository-1.0.so.1 (GIRepository-2.0). During this transitional period, interpreted languages that load the GIRepository namespace could get the "wrong" version, which will result in adjusting a search path that will not actually affect the language binding's typelib lookup, and could also lead to symbol and type-system conflicts. We can avoid this collision by making GLib's GIRepository library refuse to load versions of the GIRepository typelib that are not 3.0, and similarly making gobject-introspection's GIRepository library refuse to load typelib versions that are not 2.0. A relatively neat way to achieve that is to make each version behave as if the other one doesn't exist. Signed-off-by: Simon McVittie <smcv@debian.org>
This commit is contained in:
parent
eddd04add1
commit
e6c8c75ccc
@ -57,6 +57,14 @@
|
|||||||
* Since: 2.80
|
* Since: 2.80
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* The namespace and version corresponding to libgirepository itself, so
|
||||||
|
* that we can refuse to load typelibs corresponding to the older,
|
||||||
|
* incompatible version of this same library in gobject-introspection. */
|
||||||
|
#define GIREPOSITORY_TYPELIB_NAME "GIRepository"
|
||||||
|
#define GIREPOSITORY_TYPELIB_VERSION "3.0"
|
||||||
|
#define GIREPOSITORY_TYPELIB_FILENAME \
|
||||||
|
GIREPOSITORY_TYPELIB_NAME "-" GIREPOSITORY_TYPELIB_VERSION ".typelib"
|
||||||
|
|
||||||
static GIRepository *default_repository = NULL;
|
static GIRepository *default_repository = NULL;
|
||||||
static GPtrArray *typelib_search_path = NULL;
|
static GPtrArray *typelib_search_path = NULL;
|
||||||
|
|
||||||
@ -1323,6 +1331,16 @@ find_namespace_version (const char *namespace,
|
|||||||
GMappedFile *mfile = NULL;
|
GMappedFile *mfile = NULL;
|
||||||
char *fname;
|
char *fname;
|
||||||
|
|
||||||
|
if (g_str_equal (namespace, GIREPOSITORY_TYPELIB_NAME) &&
|
||||||
|
!g_str_equal (version, GIREPOSITORY_TYPELIB_VERSION))
|
||||||
|
{
|
||||||
|
g_debug ("Ignoring %s-%s.typelib because this libgirepository "
|
||||||
|
"corresponds to %s-%s",
|
||||||
|
namespace, version,
|
||||||
|
namespace, GIREPOSITORY_TYPELIB_VERSION);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
fname = g_strdup_printf ("%s-%s.typelib", namespace, version);
|
fname = g_strdup_printf ("%s-%s.typelib", namespace, version);
|
||||||
|
|
||||||
for (size_t i = 0; i < n_search_paths; ++i)
|
for (size_t i = 0; i < n_search_paths; ++i)
|
||||||
@ -1477,6 +1495,15 @@ enumerate_namespace_versions (const char *namespace,
|
|||||||
const char *name_end;
|
const char *name_end;
|
||||||
int major, minor;
|
int major, minor;
|
||||||
|
|
||||||
|
if (g_str_equal (namespace, GIREPOSITORY_TYPELIB_NAME) &&
|
||||||
|
!g_str_equal (entry, GIREPOSITORY_TYPELIB_FILENAME))
|
||||||
|
{
|
||||||
|
g_debug ("Ignoring %s because this libgirepository "
|
||||||
|
"corresponds to %s",
|
||||||
|
entry, GIREPOSITORY_TYPELIB_FILENAME);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
name_end = strrchr (entry, '.');
|
name_end = strrchr (entry, '.');
|
||||||
last_dash = strrchr (entry, '-');
|
last_dash = strrchr (entry, '-');
|
||||||
version = g_strndup (last_dash+1, name_end-(last_dash+1));
|
version = g_strndup (last_dash+1, name_end-(last_dash+1));
|
||||||
|
Loading…
Reference in New Issue
Block a user