mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 18:05:37 +00:00
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:
parent
0425d60190
commit
2813e30392
2 changed files with 31 additions and 13 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue