1
0
mirror of https://github.com/VDR4Arch/vdr.git synced 2023-10-10 13:36:52 +02:00

Fixed the cutting mechanism to make it re-sync in case a frame is larger than the buffer

This commit is contained in:
Klaus Schmidinger 2002-05-18 09:24:10 +02:00
parent 7da1dc6e1d
commit 26a2d98524
3 changed files with 12 additions and 3 deletions

View File

@ -347,3 +347,7 @@ Rudi Hofer (Rudi.Hofer@cadsoft.de)
Gregoire Favre <greg@ulima.unil.ch> Gregoire Favre <greg@ulima.unil.ch>
for fixing some function headers to make them compile with gcc 3.x for fixing some function headers to make them compile with gcc 3.x
Sven Grothklags <sven@uni-paderborn.de>
for fixing the cutting mechanism to make it re-sync in case a frame is larger
than the buffer

View File

@ -1304,3 +1304,5 @@ Video Disk Recorder Revision History
started a plugin project, you may want to change this in your Makefile accordingly. started a plugin project, you may want to change this in your Makefile accordingly.
- Fixed some function headers to make them compile with gcc 3.x (thanks to - Fixed some function headers to make them compile with gcc 3.x (thanks to
Gregoire Favre). Gregoire Favre).
- Fixed the cutting mechanism to make it re-sync in case a frame is larger than the
buffer (thanks to Sven Grothklags).

View File

@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and * See the main source file 'vdr.c' for copyright information and
* how to reach the author. * how to reach the author.
* *
* $Id: dvbapi.c 1.175 2002/05/13 16:29:17 kls Exp $ * $Id: dvbapi.c 1.176 2002/05/18 09:21:39 kls Exp $
*/ */
#include "dvbapi.h" #include "dvbapi.h"
@ -1527,11 +1527,14 @@ void cCuttingBuffer::Action(void)
CurrentFileNumber = FileNumber; CurrentFileNumber = FileNumber;
} }
if (fromFile >= 0) { if (fromFile >= 0) {
Length = ReadFrame(fromFile, buffer, Length, sizeof(buffer)); int len = ReadFrame(fromFile, buffer, Length, sizeof(buffer));
if (Length < 0) { if (len < 0) {
error = "ReadFrame"; error = "ReadFrame";
break; break;
} }
if (len != Length)
CurrentFileNumber = 0; // this re-syncs in case the frame was larger than the buffer
Length = len;
} }
else { else {
error = "fromFile"; error = "fromFile";