X-Git-Url: http://git.zerfleddert.de/cgi-bin/gitweb.cgi/record-dvb/blobdiff_plain/4710a9f88a22ea44ad4ec216e6c379783e1079e3..89ec024f927084cf53df08c246406a2551b3ad5c:/record-dvb.c diff --git a/record-dvb.c b/record-dvb.c index 02fcd51..9356348 100644 --- a/record-dvb.c +++ b/record-dvb.c @@ -6,22 +6,29 @@ #include #include #include +#include #include #include #include #include "http.h" #include "mcast.h" +#include "sap.h" -#define CHUNKSIZE 3000 -#define GTOD_INTERVAL 100 +#define CHUNKSIZE 3000 +#define GTOD_INTERVAL 100 +#define MAX_ERROR_SLEEP 60 void record(int(*open_fn)(char *), char *url, char *outfile, int duration) { struct timeval start, curr; int bytes, recvd, written, count = 0; + int error_sleep = 0; char buffer[CHUNKSIZE]; int in, out; + fd_set rfds; + struct timeval tv; + int retval; if ((in = (*open_fn)(url)) < 0) { fprintf(stderr,"Can't open url %s!\n",url); @@ -39,13 +46,44 @@ void record(int(*open_fn)(char *), char *url, char *outfile, int duration) curr = start; do { - if ((recvd = recv(in, buffer, CHUNKSIZE, 0)) < 1) { - /* TODO: Insert better connection-loss recovery here */ + if (error_sleep) { + sleep(error_sleep); + printf("Reconnecting... "); if ((in = (*open_fn)(url)) < 0) { - sleep(1); + if (error_sleep < MAX_ERROR_SLEEP) + error_sleep *= 2; + + if (error_sleep > MAX_ERROR_SLEEP) + error_sleep = MAX_ERROR_SLEEP; + + printf("failed\n"); continue; + } else { + printf("succeeded\n"); + error_sleep = 0; } } + + FD_ZERO(&rfds); + FD_SET(in, &rfds); + + tv.tv_sec = 1; + tv.tv_usec = 0; + + if ((retval = select(in + 1, &rfds, NULL, NULL, &tv)) == -1) { + error_sleep = 1; + continue; + } + + if (!retval) { + gettimeofday(&curr, NULL); + continue; + } + + if ((recvd = recv(in, buffer, CHUNKSIZE, 0)) < 1) { + error_sleep = 1; + continue; + } written = 0; do { if ((bytes = write(out, buffer, recvd-written)) < 0) { @@ -80,12 +118,20 @@ int main(int argc, char **argv) exit(EXIT_FAILURE); } + if (!is_http(url) && !is_mcast(url)) { + char *service_url; + if ((service_url = get_url_from_sap(url))) { + printf("SAP says: '%s' -> %s\n", url, service_url); + url = service_url; + } + } + if (is_http(url)) { open_fn = &open_http; } else if (is_mcast(url)) { open_fn = &open_mcast; } else { - printf("URL %s not supported!\n", url); + printf("URL '%s' not supported!\n", url); exit(EXIT_FAILURE); }