diff options
-rw-r--r-- | meson.build | 2 | ||||
-rw-r--r-- | project.conf | 2 | ||||
-rw-r--r-- | src/replay_buffer/replay_buffer_disk.c | 7 |
3 files changed, 7 insertions, 4 deletions
diff --git a/meson.build b/meson.build index 480eaa2..35c4984 100644 --- a/meson.build +++ b/meson.build @@ -1,4 +1,4 @@ -project('gpu-screen-recorder', ['c', 'cpp'], version : '5.5.0', default_options : ['warning_level=2']) +project('gpu-screen-recorder', ['c', 'cpp'], version : '5.5.1', default_options : ['warning_level=2']) add_project_arguments('-Wshadow', language : ['c', 'cpp']) if get_option('buildtype') == 'debug' diff --git a/project.conf b/project.conf index 8a97caf..a27e80a 100644 --- a/project.conf +++ b/project.conf @@ -1,7 +1,7 @@ [package] name = "gpu-screen-recorder" type = "executable" -version = "5.5.0" +version = "5.5.1" platforms = ["posix"] [config] diff --git a/src/replay_buffer/replay_buffer_disk.c b/src/replay_buffer/replay_buffer_disk.c index 12be089..3fff9f3 100644 --- a/src/replay_buffer/replay_buffer_disk.c +++ b/src/replay_buffer/replay_buffer_disk.c @@ -360,17 +360,20 @@ static gsr_replay_buffer_iterator gsr_replay_buffer_disk_find_keyframe(gsr_repla gsr_replay_buffer_disk *self = (gsr_replay_buffer_disk*)replay_buffer; gsr_replay_buffer_iterator keyframe_iterator = {(size_t)-1, 0}; gsr_replay_buffer_lock(&self->replay_buffer); + size_t packet_index = start_iterator.packet_index; for(size_t file_index = start_iterator.file_index; file_index < self->num_files; ++file_index) { const gsr_replay_buffer_file *file = self->files[file_index]; - for(size_t packet_index = start_iterator.packet_index; packet_index < file->num_packets; ++packet_index) { + for(; packet_index < file->num_packets; ++packet_index) { const gsr_av_packet_disk *packet = &file->packets[packet_index]; if((packet->packet.flags & AV_PKT_FLAG_KEY) && (invert_stream_index ? packet->packet.stream_index != stream_index : packet->packet.stream_index == stream_index)) { keyframe_iterator.packet_index = packet_index; keyframe_iterator.file_index = file_index; - break; + goto done; } } + packet_index = 0; } + done: gsr_replay_buffer_unlock(&self->replay_buffer); return keyframe_iterator; } |