soup: Fix pre-processor macros in souploader for libsoup-3.0

Some of the preprocessor conditionals in the loader were very broken
with libsoup-3.0 + --default-library=static

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/1111

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2082>
This commit is contained in:
Nirbheek Chauhan 2022-03-26 00:56:04 +05:30 committed by Tim-Philipp Müller
parent 0425d60190
commit 2813e30392
2 changed files with 31 additions and 13 deletions

View file

@ -28,11 +28,13 @@
#if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_APP) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) #if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_APP) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
#define GST_WINAPI_ONLY_APP #define GST_WINAPI_ONLY_APP
#endif #endif
#endif #endif /* G_OS_WIN32 */
GST_DEBUG_CATEGORY_EXTERN (gst_soup_debug); GST_DEBUG_CATEGORY_EXTERN (gst_soup_debug);
#define GST_CAT_DEFAULT gst_soup_debug #define GST_CAT_DEFAULT gst_soup_debug
#ifndef STATIC_SOUP
/* G_OS_WIN32 is handled separately below */ /* G_OS_WIN32 is handled separately below */
#ifdef __APPLE__ #ifdef __APPLE__
#define LIBSOUP_3_SONAME "libsoup-3.0.0.dylib" #define LIBSOUP_3_SONAME "libsoup-3.0.0.dylib"
@ -165,7 +167,7 @@ gst_soup_load_library (void)
g_clear_pointer (&handle, dlclose); g_clear_pointer (&handle, dlclose);
} }
#else #else /* !HAVE_RTLD_NOLOAD */
#ifdef G_OS_WIN32 #ifdef G_OS_WIN32
@ -206,7 +208,7 @@ gst_soup_load_library (void)
} }
} }
} }
#else #else /* !G_OS_WIN32 */
libsoup_sonames[0] = LIBSOUP_3_SONAME; libsoup_sonames[0] = LIBSOUP_3_SONAME;
libsoup_sonames[1] = LIBSOUP_2_SONAME; libsoup_sonames[1] = LIBSOUP_2_SONAME;
#endif /* G_OS_WIN32 */ #endif /* G_OS_WIN32 */
@ -290,13 +292,16 @@ gst_soup_load_library (void)
return vtable->loaded; return vtable->loaded;
} }
#endif /* !STATIC_SOUP */
guint guint
gst_soup_loader_get_api_version (void) gst_soup_loader_get_api_version (void)
{ {
#ifdef STATIC_SOUP #ifdef STATIC_SOUP
return STATIC_SOUP; return STATIC_SOUP;
#endif #else
return gst_soup_vtable.lib_version; return gst_soup_vtable.lib_version;
#endif
} }
SoupSession * SoupSession *
@ -382,38 +387,49 @@ gst_soup_uri_new (const char *uri_string)
void void
gst_soup_uri_free (GstSoupUri * uri) gst_soup_uri_free (GstSoupUri * uri)
{ {
#if GLIB_CHECK_VERSION(2, 66, 0) #if (defined(STATIC_SOUP) && STATIC_SOUP == 3) || (!defined(STATIC_SOUP) && GLIB_CHECK_VERSION(2, 66, 0))
if (uri->uri) { if (uri->uri) {
g_uri_unref (uri->uri); g_uri_unref (uri->uri);
} }
#endif #endif
#if defined(STATIC_SOUP)
#if STATIC_SOUP == 2
if (uri->soup_uri) { if (uri->soup_uri) {
#if defined(STATIC_SOUP) && STATIC_SOUP == 2
soup_uri_free (uri->soup_uri); soup_uri_free (uri->soup_uri);
#else }
#endif
#else /* !STATIC_SOUP */
if (uri->soup_uri) {
g_assert (gst_soup_vtable._soup_uri_free_2 != NULL); g_assert (gst_soup_vtable._soup_uri_free_2 != NULL);
gst_soup_vtable._soup_uri_free_2 (uri->soup_uri); gst_soup_vtable._soup_uri_free_2 (uri->soup_uri);
#endif
} }
#endif /* STATIC_SOUP */
g_free (uri); g_free (uri);
} }
char * char *
gst_soup_uri_to_string (GstSoupUri * uri) gst_soup_uri_to_string (GstSoupUri * uri)
{ {
#if GLIB_CHECK_VERSION(2, 66, 0) #if (defined(STATIC_SOUP) && STATIC_SOUP == 3) || (!defined(STATIC_SOUP) && GLIB_CHECK_VERSION(2, 66, 0))
if (uri->uri) { if (uri->uri) {
return g_uri_to_string_partial (uri->uri, G_URI_HIDE_PASSWORD); return g_uri_to_string_partial (uri->uri, G_URI_HIDE_PASSWORD);
} }
#endif #endif
#if defined(STATIC_SOUP)
#if STATIC_SOUP == 2
if (uri->soup_uri) { if (uri->soup_uri) {
#if defined(STATIC_SOUP) && STATIC_SOUP == 2
return soup_uri_to_string (uri->soup_uri, FALSE); return soup_uri_to_string (uri->soup_uri, FALSE);
#else }
#endif
#else /* !STATIC_SOUP */
if (uri->soup_uri) {
g_assert (gst_soup_vtable._soup_uri_to_string_2 != NULL); g_assert (gst_soup_vtable._soup_uri_to_string_2 != NULL);
return gst_soup_vtable._soup_uri_to_string_2 (uri->soup_uri, FALSE); return gst_soup_vtable._soup_uri_to_string_2 (uri->soup_uri, FALSE);
#endif
} }
#endif /* STATIC_SOUP */
g_assert_not_reached (); g_assert_not_reached ();
return NULL; return NULL;
} }

View file

@ -41,10 +41,12 @@ void _soup_session_add_feature (SoupSession *session,
void _soup_session_add_feature_by_type (SoupSession *session, GType feature_type); void _soup_session_add_feature_by_type (SoupSession *session, GType feature_type);
typedef struct _GstSoupUri { typedef struct _GstSoupUri {
#if GLIB_CHECK_VERSION(2, 66, 0) #if (defined(STATIC_SOUP) && STATIC_SOUP == 3) || (!defined(STATIC_SOUP) && GLIB_CHECK_VERSION(2, 66, 0))
GUri *uri; GUri *uri;
#endif #endif
#if (defined(STATIC_SOUP) && STATIC_SOUP == 2) || !defined(STATIC_SOUP)
SoupURI *soup_uri; SoupURI *soup_uri;
#endif
} GstSoupUri; } GstSoupUri;
GstSoupUri *gst_soup_uri_new (const char *uri_string); GstSoupUri *gst_soup_uri_new (const char *uri_string);