code style, add bytes per second read statistic and a code comment about the sleeping

pull/2706/head
Isaac Connor 2019-09-14 10:48:39 -04:00
parent 306bda86c2
commit 675cbe8854
1 changed files with 31 additions and 20 deletions

View File

@ -22,10 +22,6 @@
#include <string.h>
#include <unistd.h>
#include <time.h>
#include <sys/time.h>
#include <syslog.h>
#include <signal.h>
#include <stdarg.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/time.h>
@ -45,8 +41,20 @@ FileCamera::FileCamera(
int p_hue,
int p_colour,
bool p_capture,
bool p_record_audio
) : Camera( p_id, FILE_SRC, p_width, p_height, p_colours, ZM_SUBPIX_ORDER_DEFAULT_FOR_COLOUR(p_colours), p_brightness, p_contrast, p_hue, p_colour, p_capture, p_record_audio )
bool p_record_audio)
: Camera(
p_id,
FILE_SRC,
p_width,
p_height,
p_colours,
ZM_SUBPIX_ORDER_DEFAULT_FOR_COLOUR(p_colours),
p_brightness,
p_contrast,
p_hue,
p_colour,
p_capture,
p_record_audio)
{
strncpy( path, p_path, sizeof(path)-1 );
if ( capture ) {
@ -62,8 +70,7 @@ FileCamera::~FileCamera() {
void FileCamera::Initialise() {
if ( !path[0] ) {
Error( "No path specified for file image" );
exit( -1 );
Fatal("No path specified for file image");
}
}
@ -74,19 +81,23 @@ int FileCamera::PreCapture() {
struct stat statbuf;
if ( stat(path, &statbuf) < 0 ) {
Error("Can't stat %s: %s", path, strerror(errno));
return( -1 );
return -1;
}
bytes += statbuf.st_size;
// This waits until 1 second has passed since it was modified. Effectively limiting fps to 60.
// Which is kinda bogus. If we were writing to this jpg constantly faster than we are monitoring it here
// we would never break out of this loop
while ( (time(0) - statbuf.st_mtime) < 1 ) {
usleep(100000);
}
return( 0 );
return 0;
}
int FileCamera::Capture(Image &image) {
return( image.ReadJpeg( path, colours, subpixelorder )?1:-1 );
return image.ReadJpeg(path, colours, subpixelorder)?1:-1;
}
int FileCamera::PostCapture() {
return( 0 );
return 0;
}