#include <stdio.h>
#include <math.h>
#include <tests.h>
#ifdef PRINT_AUDACITY_LABELS
void printAudacityLabel(FILE *outFile,
timeu start,
timeu end,
char *label) {
}
void printAudacityLabelForSamples(FILE *outFile,
SMPTEDecoder* d,
size_t startInt,
size_t endInt,
char *label) {
printAudacityLabel(outFile, start, end, label);
}
#endif
int main(int argc, char **argv) {
int debuglevel = 2;
int sampleRate = SAMPLE_RATE;
double framesPerSec = FRAME_RATE_NUM/(double)FRAME_RATE_DEN;
size_t n;
size_t total;
FILE* f;
char* filename;
int errors;
int printMissingFrameInfo;
if (argc > 1) {
filename = argv[1];
if (argc > 2) {
sscanf(argv[2], "%i", &sampleRate);
if (argc > 3) {
sscanf(argv[3], "%lf", &framesPerSec);
}
}
} else {
printf("Usage: %s <filename> [sample rate [frame rate]]\n", argv[0]);
printf("The decoder understands " SAMPLE_TYPE " native endian raw audio at currently %i Hz sampling rate.\n", sampleRate);
return -1;
}
#ifdef PRINT_AUDACITY_LABELS
debuglevel = 0;
printMissingFrameInfo = 1;
#else
printMissingFrameInfo = (debuglevel > 1);
#endif
if (debuglevel > 1)
printf("reading from: %s\n", filename);
f = fopen(filename, "r");
if (!f) {
printf("error opening %s\n", filename);
return -1;
}
double ltcFrameSamples = sampleRate / framesPerSec;
double ltcFramePlusFudge = (ltcFrameSamples * 101 / 100);
size_t ltcFrameSize = (size_t)ceil(ltcFrameSamples) *
sizeof(
sample_t);
if (debuglevel > 0)
{
printf("samples are %s native endian\n", SAMPLE_TYPE);
printf("sample rate = %i\n", sampleRate);
printf("frames/sec = %.2lf\n", framesPerSec);
printf("approx. SMPTE LTC frame size in bytes (samples) = %llu (%.2lf)\n\n", (unsigned long long)ltcFrameSize, ltcFrameSamples);
}
total = 0;
#ifndef PRINT_AUDACITY_LABELS
#ifdef ENABLE_DATE
printf("%-10s %-5s ",
"Date", "Zone"
);
#endif
printf("%-11s %8s %17s"" %4s\n",
"Timecode",
"(in ms)",
"Pos. (samples)",
"Errs");
#endif
#ifdef PRINT_AUDACITY_LABELS
#define TIME_CODE_STRING_SIZE 12
char timeCodeString[TIME_CODE_STRING_SIZE];
#endif
size_t prevRead = (size_t)round(ltcFrameSamples), frameStart, frameStartFudge;
do {
n = fread(sound,
sizeof(
sample_t), BUFFER_SIZE, f);
if (printMissingFrameInfo) {
frameStartFudge = (size_t)round(prevRead + ltcFramePlusFudge);
if (total > frameStartFudge) {
frameStart = (size_t)round(prevRead + ltcFrameSamples);
#ifdef PRINT_AUDACITY_LABELS
printAudacityLabelForSamples(stdout, decoder, prevRead, frameStart, "No LTC frame found");
#else
#ifdef ENABLE_DATE
printf("%-16s ", "");
#endif
printf("%-20s %8lu %8lu\n", "No LTC frame at pos:", (long unsigned) prevRead, (long unsigned) frameStart);
#endif
prevRead = total;
}
}
int ms;
#ifdef PRINT_AUDACITY_LABELS
snprintf(timeCodeString, TIME_CODE_STRING_SIZE,
"%02d:%02d:%02d%c%02d",
);
printAudacityLabelForSamples(stdout, decoder, frame.
startpos, frame.
endpos, timeCodeString);
#else
#ifdef ENABLE_DATE
printf("%04d-%02d-%02d %s ",
);
#endif
printf("%02d:%02d:%02d%c%02d %8d %8lu %8lu"" %4d\n",
(frame.
base.
dfbit) ? DF_DELIMITER : NDF_DELIMITER,
ms,
errors
);
#endif
}
total += n;
} while (n);
fclose(f);
return 0;
}