X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=futatabi%2Fflags.cpp;h=211509890d69a93ba212152fe2985063b4f9e210;hb=b3a7a9eddd8b800f1b921332e8fdacb72e0d9b20;hp=7a8246030abf7d485836d467800612aaef5a7c95;hpb=dd7789d6d360ede408bec22f0f15c47fb08982df;p=nageru diff --git a/futatabi/flags.cpp b/futatabi/flags.cpp index 7a82460..2115098 100644 --- a/futatabi/flags.cpp +++ b/futatabi/flags.cpp @@ -4,18 +4,20 @@ #include #include #include - #include using namespace std; Flags global_flags; +int flow_initialized_interpolation_quality; // Long options that have no corresponding short option. enum LongOption { OPTION_HELP = 1000, OPTION_SLOW_DOWN_INPUT = 1001, - OPTION_HTTP_PORT = 1002 + OPTION_HTTP_PORT = 1002, + OPTION_TALLY_URL = 1003, + OPTION_CUE_POINT_PADDING = 1004 }; void usage() @@ -34,11 +36,13 @@ void usage() fprintf(stderr, " 2 = default (realtime 720p on fast embedded GPUs)\n"); fprintf(stderr, " 3 = good (realtime 720p on GTX 970 or so)\n"); fprintf(stderr, " 4 = best (not realtime on any current GPU)\n"); + fprintf(stderr, " --cue-point-padding SECS move cue-in/cue-out N seconds earlier/later on set\n"); fprintf(stderr, " -d, --working-directory DIR where to store frames and database\n"); fprintf(stderr, " --http-port PORT which port to listen on for output\n"); + fprintf(stderr, " --tally-url URL URL to get tally color from (polled every 100 ms)\n"); } -void parse_flags(int argc, char * const argv[]) +void parse_flags(int argc, char *const argv[]) { static const option long_options[] = { { "help", no_argument, 0, OPTION_HELP }, @@ -49,9 +53,11 @@ void parse_flags(int argc, char * const argv[]) { "interpolation-quality", required_argument, 0, 'q' }, { "working-directory", required_argument, 0, 'd' }, { "http-port", required_argument, 0, OPTION_HTTP_PORT }, + { "tally-url", required_argument, 0, OPTION_TALLY_URL }, + { "cue-point-padding", required_argument, 0, OPTION_CUE_POINT_PADDING }, { 0, 0, 0, 0 } }; - for ( ;; ) { + for (;;) { int option_index = 0; int c = getopt_long(argc, argv, "w:h:r:q:d:", long_options, &option_index); @@ -82,6 +88,7 @@ void parse_flags(int argc, char * const argv[]) break; case 'q': global_flags.interpolation_quality = atoi(optarg); + global_flags.interpolation_quality_set = true; break; case 'd': global_flags.working_directory = optarg; @@ -89,6 +96,13 @@ void parse_flags(int argc, char * const argv[]) case OPTION_HTTP_PORT: global_flags.http_port = atoi(optarg); break; + case OPTION_TALLY_URL: + global_flags.tally_url = optarg; + break; + case OPTION_CUE_POINT_PADDING: + global_flags.cue_point_padding_seconds = atof(optarg); + global_flags.cue_point_padding_set = true; + break; case OPTION_HELP: usage(); exit(0); @@ -105,4 +119,9 @@ void parse_flags(int argc, char * const argv[]) usage(); exit(1); } + if (global_flags.cue_point_padding_seconds < 0.0) { + fprintf(stderr, "Cue point padding cannot be negative.\n"); + usage(); + exit(1); + } }