浏览代码

libobs: Don't call width/height funcs if context invalid

Don't allow calling a source's custom get_width or get_height callbacks
unless the context is valid.  Fixes a bug where a null pointer could be
passed to those functions.
jp9000 7 年之前
父节点
当前提交
f1aa71bef1
共有 1 个文件被更改,包括 4 次插入2 次删除
  1. 4 2
      libobs/obs-source.c

+ 4 - 2
libobs/obs-source.c

@@ -1837,11 +1837,12 @@ void obs_source_video_render(obs_source_t *source)
 static uint32_t get_base_width(const obs_source_t *source)
 {
 	bool is_filter = !!source->filter_parent;
+	bool func_valid = source->context.data && source->info.get_width;
 
 	if (source->info.type == OBS_SOURCE_TYPE_TRANSITION) {
 		return source->enabled ? source->transition_actual_cx : 0;
 
-	} else if (source->info.get_width && (!is_filter || source->enabled)) {
+	} else if (func_valid && (!is_filter || source->enabled)) {
 		return source->info.get_width(source->context.data);
 
 	} else if (is_filter) {
@@ -1854,11 +1855,12 @@ static uint32_t get_base_width(const obs_source_t *source)
 static uint32_t get_base_height(const obs_source_t *source)
 {
 	bool is_filter = !!source->filter_parent;
+	bool func_valid = source->context.data && source->info.get_height;
 
 	if (source->info.type == OBS_SOURCE_TYPE_TRANSITION) {
 		return source->enabled ? source->transition_actual_cy : 0;
 
-	} else if (source->info.get_height && (!is_filter || source->enabled)) {
+	} else if (func_valid && (!is_filter || source->enabled)) {
 		return source->info.get_height(source->context.data);
 
 	} else if (is_filter) {