mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-22 08:17:01 +00:00
xdgmime: make xdg typefinder more conservative
The whole raison d'etre of this typefinder is to help avoid false positives when used in combination with our main typefinder in -base. Its task is not really to typefind audio/video files, even less so given that it detects *MIME* types, not GStreamer media types. Therefore, if this typefinder detects an audio or video type, don't even suggest it - our own typefinders are hopefully better at this and detect the right type of type on top of that, and even if they're not we really want to know about it and fix it. Fixes #575157.
This commit is contained in:
parent
4bff4266d5
commit
7a85af3ce6
1 changed files with 19 additions and 3 deletions
|
@ -36,7 +36,6 @@ xdgmime_typefind (GstTypeFind * find, gpointer user_data)
|
||||||
guint64 tf_length;
|
guint64 tf_length;
|
||||||
gint prio;
|
gint prio;
|
||||||
guint8 *data;
|
guint8 *data;
|
||||||
GstCaps *caps;
|
|
||||||
|
|
||||||
if ((tf_length = gst_type_find_get_length (find)) > 0)
|
if ((tf_length = gst_type_find_get_length (find)) > 0)
|
||||||
length = MIN (length, tf_length);
|
length = MIN (length, tf_length);
|
||||||
|
@ -57,8 +56,25 @@ xdgmime_typefind (GstTypeFind * find, gpointer user_data)
|
||||||
|
|
||||||
GST_DEBUG ("Got mimetype '%s' with prio %d", mimetype, prio);
|
GST_DEBUG ("Got mimetype '%s' with prio %d", mimetype, prio);
|
||||||
|
|
||||||
caps = gst_caps_new_simple (mimetype, NULL);
|
/* Ignore audio/video types:
|
||||||
gst_type_find_suggest (find, GST_TYPE_FIND_POSSIBLE, caps);
|
* - our own typefinders in -base are likely to be better at this
|
||||||
|
* (and if they're not, we really want to fix them, that's why we don't
|
||||||
|
* report xdg-detected audio/video types at all, not even with a low
|
||||||
|
* probability)
|
||||||
|
* - we want to detect GStreamer media types and not MIME types
|
||||||
|
* - the purpose of this xdg mime finder is mainly to prevent false
|
||||||
|
* positives of non-media formats, not to typefind audio/video formats */
|
||||||
|
if (g_str_has_prefix (mimetype, "audio/") ||
|
||||||
|
g_str_has_prefix (mimetype, "video/")) {
|
||||||
|
GST_LOG ("Ignoring audio/video mime type");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Again, we mainly want the xdg typefinding to prevent false-positives on
|
||||||
|
* non-media formats, so suggest the type with a probability that trumps
|
||||||
|
* uncertain results of our typefinders, but not more than that. */
|
||||||
|
GST_LOG ("Suggesting '%s' with probability POSSIBLE", mimetype);
|
||||||
|
gst_type_find_suggest_simple (find, GST_TYPE_FIND_POSSIBLE, mimetype, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
|
Loading…
Reference in a new issue