]> git.sesse.net Git - vlc/commitdiff
lib: check scale range in libvlc_video_set_scale()
authorRémi Denis-Courmont <remi@remlab.net>
Mon, 19 May 2014 11:11:04 +0000 (19:11 +0800)
committerRémi Denis-Courmont <remi@remlab.net>
Tue, 20 May 2014 11:10:22 +0000 (19:10 +0800)
lib/video.c

index d6c2f948e922204819b61ab638cc71f518586749..c8b371130e82c72c6df93b2ad3b2a620f158ec4d 100644 (file)
@@ -38,6 +38,7 @@
 #include <vlc_vout.h>
 
 #include "media_player_internal.h"
+#include <math.h>
 #include <assert.h>
 
 /*
@@ -237,7 +238,7 @@ float libvlc_video_get_scale( libvlc_media_player_t *mp )
 
 void libvlc_video_set_scale( libvlc_media_player_t *p_mp, float f_scale )
 {
-    if (f_scale != 0.)
+    if (isfinite(f_scale) && f_scale != 0.f)
         var_SetFloat (p_mp, "scale", f_scale);
     var_SetBool (p_mp, "autoscale", f_scale == 0.f);
 
@@ -248,7 +249,7 @@ void libvlc_video_set_scale( libvlc_media_player_t *p_mp, float f_scale )
     {
         vout_thread_t *p_vout = pp_vouts[i];
 
-        if (f_scale != 0.)
+        if (isfinite(f_scale) && f_scale != 0.f)
             var_SetFloat (p_vout, "scale", f_scale);
         var_SetBool (p_vout, "autoscale", f_scale == 0.f);
         vlc_object_release (p_vout);