cinera.c: Validate timecode chronology

Also correctly skip .hmml files for credentials-related reasons
This commit is contained in:
Matt Mascarenhas 2018-02-05 23:57:17 +00:00
parent 1603245fad
commit 9d9d8a6332
1 changed files with 42 additions and 22 deletions

View File

@ -14,7 +14,7 @@ typedef struct
version CINERA_APP_VERSION = { version CINERA_APP_VERSION = {
.Major = 0, .Major = 0,
.Minor = 5, .Minor = 5,
.Patch = 31 .Patch = 32
}; };
// TODO(matt): Copy in the DB 3 stuff from cinera_working.c // TODO(matt): Copy in the DB 3 stuff from cinera_working.c
@ -1162,10 +1162,11 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
{ {
if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->member, "Host")) if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->member, "Host"))
{ {
printf("No credentials for %s. Please contact matt@handmadedev.org with their:\n" printf("No credentials for member %s. Please contact matt@handmadedev.org with their:\n"
" Full name\n" " Full name\n"
" Homepage URL (optional)\n" " Homepage URL (optional)\n"
" Financial support info, e.g. Patreon URL (optional)\n", Metadata->member); " Financial support info, e.g. Patreon URL (optional)\n", Metadata->member);
return CreditsError_NoCredentials;
} }
} }
else else
@ -1176,6 +1177,7 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
" </div>\n" " </div>\n"
" </div>\n"); " </div>\n");
} }
fprintf(stderr, "Missing \"member\" in the [video] node\n");
return CreditsError_NoHost; return CreditsError_NoHost;
} }
@ -1185,10 +1187,11 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
{ {
if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->co_hosts[i], "Co-host")) if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->co_hosts[i], "Co-host"))
{ {
printf("No credentials for %s. Please contact matt@handmadedev.org with their:\n" printf("No credentials for co-host %s. Please contact matt@handmadedev.org with their:\n"
" Full name\n" " Full name\n"
" Homepage URL (optional)\n" " Homepage URL (optional)\n"
" Financial support info, e.g. Patreon URL (optional)\n", Metadata->co_hosts[i]); " Financial support info, e.g. Patreon URL (optional)\n", Metadata->co_hosts[i]);
return CreditsError_NoCredentials;
} }
} }
} }
@ -1199,10 +1202,11 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
{ {
if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->guests[i], "Guest")) if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->guests[i], "Guest"))
{ {
printf("No credentials for %s. Please contact matt@handmadedev.org with their:\n" printf("No credentials for guest %s. Please contact matt@handmadedev.org with their:\n"
" Full name\n" " Full name\n"
" Homepage URL (optional)\n" " Homepage URL (optional)\n"
" Financial support info, e.g. Patreon URL (optional)\n", Metadata->guests[i]); " Financial support info, e.g. Patreon URL (optional)\n", Metadata->guests[i]);
return CreditsError_NoCredentials;
} }
} }
} }
@ -1213,10 +1217,11 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
{ {
if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->annotators[i], "Annotator")) if(SearchCredentials(CreditsMenu, HasCreditsMenu, Metadata->annotators[i], "Annotator"))
{ {
printf("No credentials for %s. Please contact matt@handmadedev.org with their:\n" printf("No credentials for annotator %s. Please contact matt@handmadedev.org with their:\n"
" Full name\n" " Full name\n"
" Homepage URL (optional)\n" " Homepage URL (optional)\n"
" Financial support info, e.g. Patreon URL (optional)\n", Metadata->annotators[i]); " Financial support info, e.g. Patreon URL (optional)\n", Metadata->annotators[i]);
return CreditsError_NoCredentials;
} }
} }
} }
@ -1228,6 +1233,7 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
" </div>\n" " </div>\n"
" </div>\n"); " </div>\n");
} }
fprintf(stderr, "Missing \"annotator\" in the [video] node\n");
return CreditsError_NoAnnotator; return CreditsError_NoAnnotator;
} }
@ -1238,7 +1244,7 @@ BuildCredits(buffer *CreditsMenu, bool *HasCreditsMenu, HMML_VideoMetaData *Meta
" </div>\n"); " </div>\n");
} }
return 0; return RC_SUCCESS;
} }
int int
@ -2275,6 +2281,16 @@ MediumExists(char *Medium)
return FALSE; return FALSE;
} }
#define HMMLCleanup() \
DeclaimBuffer(&FilterState); \
DeclaimBuffer(&CreditsMenu); \
DeclaimBuffer(&FilterMedia); \
DeclaimBuffer(&FilterTopics); \
DeclaimBuffer(&FilterMenu); \
DeclaimBuffer(&ReferenceMenu); \
DeclaimBuffer(&QuoteMenu); \
hmml_free(&HMML);
int int
HMMLToBuffers(buffers *CollationBuffers, template **BespokeTemplate, char *Filename) HMMLToBuffers(buffers *CollationBuffers, template **BespokeTemplate, char *Filename)
{ {
@ -2468,22 +2484,14 @@ HMMLToBuffers(buffers *CollationBuffers, template **BespokeTemplate, char *Filen
" <div class=\"video_container\" data-videoId=\"%s\"></div>\n" " <div class=\"video_container\" data-videoId=\"%s\"></div>\n"
" <div class=\"markers_container %s\">\n", HMML.metadata.id, StringsDiffer(Config.Theme, "") ? Config.Theme : HMML.metadata.project); " <div class=\"markers_container %s\">\n", HMML.metadata.id, StringsDiffer(Config.Theme, "") ? Config.Theme : HMML.metadata.project);
int CreditsErrorCode = BuildCredits(&CreditsMenu, &HasCreditsMenu, &HMML.metadata); switch(BuildCredits(&CreditsMenu, &HasCreditsMenu, &HMML.metadata))
if(CreditsErrorCode)
{
switch(CreditsErrorCode)
{ {
case CreditsError_NoHost: case CreditsError_NoHost:
fprintf(stderr, "%s: Missing \"member\" in the [video] node. Skipping...\n", Filename);
goto Cleanup;
break;
case CreditsError_NoAnnotator: case CreditsError_NoAnnotator:
fprintf(stderr, "%s: Missing \"annotator\" in the [video] node. Skipping...\n", Filename); case CreditsError_NoCredentials:
goto Cleanup; fprintf(stderr, "\e[1;31mSkipping\e[0m %s - %s\n", BaseFilename, HMML.metadata.title);
break; HMMLCleanup();
default: return RC_ERROR_HMML;
break;
}
} }
if(Config.Edition != EDITION_SINGLE) if(Config.Edition != EDITION_SINGLE)
@ -2500,6 +2508,7 @@ HMMLToBuffers(buffers *CollationBuffers, template **BespokeTemplate, char *Filen
printf("\n\n --- Entering Annotations Loop ---\n\n\n\n"); printf("\n\n --- Entering Annotations Loop ---\n\n\n\n");
#endif #endif
int PreviousTimecode = 0;
for(int AnnotationIndex = 0; AnnotationIndex < HMML.annotation_count; ++AnnotationIndex) for(int AnnotationIndex = 0; AnnotationIndex < HMML.annotation_count; ++AnnotationIndex)
{ {
#if DEBUG #if DEBUG
@ -2508,6 +2517,17 @@ HMMLToBuffers(buffers *CollationBuffers, template **BespokeTemplate, char *Filen
HMML_Annotation *Anno = HMML.annotations + AnnotationIndex; HMML_Annotation *Anno = HMML.annotations + AnnotationIndex;
if(TimecodeToSeconds(Anno->time) < PreviousTimecode)
{
fprintf(stderr, "%s:%d: Timecode %s is chronologically before previous timecode\n"
"\e[1;31mSkipping\e[0m %s - %s\n",
Filename, Anno->line, Anno->time,
BaseFilename, HMML.metadata.title);
HMMLCleanup();
return RC_ERROR_HMML;
}
PreviousTimecode = TimecodeToSeconds(Anno->time);
if(Config.Edition != EDITION_SINGLE) if(Config.Edition != EDITION_SINGLE)
{ {
CopyStringToBuffer(&CollationBuffers->Search, "\"%d\": \"", TimecodeToSeconds(Anno->time)); CopyStringToBuffer(&CollationBuffers->Search, "\"%d\": \"", TimecodeToSeconds(Anno->time));
@ -2530,6 +2550,7 @@ HMMLToBuffers(buffers *CollationBuffers, template **BespokeTemplate, char *Filen
// Text // Text
// CategoryIcons // CategoryIcons
// TODO(matt): Shouldn't all of these guys DeclaimBuffer() before returning?
if(ClaimBuffer(&Annotation, "Annotation", Kilobytes(8)) == RC_ARENA_FULL) { hmml_free(&HMML); return RC_ARENA_FULL; }; if(ClaimBuffer(&Annotation, "Annotation", Kilobytes(8)) == RC_ARENA_FULL) { hmml_free(&HMML); return RC_ARENA_FULL; };
if(ClaimBuffer(&AnnotationHeader, "AnnotationHeader", 512) == RC_ARENA_FULL) { hmml_free(&HMML); return RC_ARENA_FULL; }; if(ClaimBuffer(&AnnotationHeader, "AnnotationHeader", 512) == RC_ARENA_FULL) { hmml_free(&HMML); return RC_ARENA_FULL; };
if(ClaimBuffer(&AnnotationClass, "AnnotationClass", 256) == RC_ARENA_FULL) { hmml_free(&HMML); return RC_ARENA_FULL; }; if(ClaimBuffer(&AnnotationClass, "AnnotationClass", 256) == RC_ARENA_FULL) { hmml_free(&HMML); return RC_ARENA_FULL; };
@ -3626,7 +3647,6 @@ AppendedIdentifier:
// ReferenceMenu // ReferenceMenu
// QuoteMenu // QuoteMenu
Cleanup:
DeclaimBuffer(&FilterState); DeclaimBuffer(&FilterState);
DeclaimBuffer(&CreditsMenu); DeclaimBuffer(&CreditsMenu);