From 3c42da3785704d68ef800ac1d8f4b3fb890548e2 Mon Sep 17 00:00:00 2001 From: Exeldro Date: Tue, 16 Apr 2024 08:07:59 +0200 Subject: [PATCH] Fix crash stopping encoder --- CMakeLists.txt | 2 +- buildspec.json | 2 +- source-record.c | 6 +++--- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 0367839..0a8eb1e 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -9,7 +9,7 @@ else() cmake_minimum_required(VERSION 3.18) endif() -project(source-record VERSION 0.3.3) +project(source-record VERSION 0.3.4) set(PROJECT_FULL_NAME "Source Record") # Set new UUIDs when you start to create a new plugin. diff --git a/buildspec.json b/buildspec.json index 91bd9ac..870edc9 100644 --- a/buildspec.json +++ b/buildspec.json @@ -79,5 +79,5 @@ } }, "name": "source-record", - "version": "0.3.3" + "version": "0.3.4" } diff --git a/source-record.c b/source-record.c index 9fb7c10..14260d0 100644 --- a/source-record.c +++ b/source-record.c @@ -358,8 +358,8 @@ static void update_video_encoder(struct source_record_filter_context *filter, ob const char *enc_id = get_encoder_id(settings); filter->encoder = obs_video_encoder_create(enc_id, obs_source_get_name(filter->source), settings, NULL); obs_encoder_set_scaled_size(filter->encoder, 0, 0); - obs_encoder_set_video(filter->encoder, filter->video_output); } + obs_encoder_set_video(filter->encoder, filter->video_output); } if (filter->fileOutput && obs_output_get_video_encoder(filter->fileOutput) != filter->encoder) obs_output_set_video_encoder(filter->fileOutput, filter->encoder); @@ -674,11 +674,11 @@ static void source_record_filter_update(void *data, obs_data_t *settings) } if (!replay_buffer && !record && !stream) { - if (filter->encoder) { + if (filter->encoder && !obs_encoder_active(filter->encoder)) { obs_encoder_release(filter->encoder); filter->encoder = NULL; } - if (filter->aacTrack) { + if (filter->aacTrack && !obs_encoder_active(filter->aacTrack)) { obs_encoder_release(filter->aacTrack); filter->aacTrack = NULL; }